ต่อไปนี้เป็นตัวอย่างการสร้างไบนารี Rust ที่ขึ้นอยู่กับไลบรารี Rust
ปัจจุบันโมดูล Rust จำกัดไว้ในไดเรกทอรีที่เฉพาะเจาะจงซึ่งกำหนดไว้ใน
build/soong/rust/config/allowed_list.go
โมดูล helloWorld ต่อไปนี้ใช้ไดเรกทอรี external/rust เพื่อหลีกเลี่ยง
การแก้ไขรายการนี้
จากรูทของแหล่งที่มาของ AOSP
mkdir -p external/rust/hello_rust/src/mkdir -p external/rust/libsimple_printer/src/
สร้าง external/rust/hello_rust/src/hello_rust.rs ที่มีเนื้อหาต่อไปนี้
use simple_printer;
fn main() {
 simple_printer::print_hello_rust();
}
สร้างexternal/rust/libsimple_printer/src/lib.rsที่มีเนื้อหาต่อไปนี้
pub fn print_hello_rust() {
  println!("Hello Rust!");
}
สร้างexternal/rust/hello_rust/Android.bpไฟล์ที่มีเนื้อหาต่อไปนี้
rust_binary {
    name: "hello_rust",
    // srcs must contain a single source file, the entry point source.
    srcs: ["src/hello_rust.rs"],
    // rustlibs are Rust library dependencies. The type, rlib (static) or dylib
    // (dynamic), are chosen automatically based on module type and target
    // to avoid linkage issues.
    rustlibs: ["libsimple_printer"],
    // define any additional compilation flags
    flags: [
        "-C debug-assertions=yes",
    ],
    // cc libraries can be linked in to rust binaries and libraries through the
    // shared_libs and static_libs properties. These are not needed for this
    // simple example, so they are not included.
}
สร้างexternal/rust/libsimple_printer/Android.bpไฟล์ที่มีเนื้อหาต่อไปนี้
// rust_library provides dylib and rlib variants.
rust_library {
    //name or stem properties must be of the form lib<crate_name><any_suffix>
    name: "libsimple_printer",
    //crate_name must match the name used in source (e.g. extern crate <name>)
    crate_name: "simple_printer",
    //srcs must contain a single source file, the entry point source
    srcs: ["src/lib.rs"],
}
สุดท้าย ให้สร้างโมดูล hello_rust ดังนี้
source build/envsetup.shlunch aosp_arm64-engm hello_rust