27 Mart 2025'ten itibaren AOSP'yi derlemek ve AOSP'ye katkıda bulunmak için aosp-main
yerine android-latest-release
kullanmanızı öneririz. Daha fazla bilgi için AOSP'de yapılan değişiklikler başlıklı makaleyi inceleyin.
Merhaba Rust örneği
Koleksiyonlar ile düzeninizi koruyun
İçeriği tercihlerinize göre kaydedin ve kategorilere ayırın.
Aşağıda, Rust kitaplığına bağımlı bir Rust ikili dosyası oluşturma örneği verilmiştir.
Rust modülleri şu anda build/soong/rust/config/allowed_list.go dosyasında tanımlanan belirli dizinlerle sınırlıdır. Aşağıdaki helloWorld
modülü, bu listeyi değiştirmemek için external/rust
dizinini kullanır.
AOSP kaynak kökünden
mkdir -p external/rust/hello_rust/src/
mkdir -p external/rust/libsimple_printer/src/
Aşağıdaki içeriklerle external/rust/hello_rust/src/hello_rust.rs
oluşturun:
use simple_printer;
fn main() {
simple_printer::print_hello_rust();
}
Aşağıdaki içeriklerle external/rust/libsimple_printer/src/lib.rs
dosyası oluşturun:
pub fn print_hello_rust() {
println!("Hello Rust!");
}
Aşağıdaki içerikleri içeren bir external/rust/hello_rust/Android.bp
dosyası oluşturun:
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.
}
Aşağıdaki içerikleri içeren bir external/rust/libsimple_printer/Android.bp
dosyası oluşturun:
// 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"],
}
Son olarak hello_rust
modülünüzü oluşturun:
source build/envsetup.sh
lunch aosp_arm64-eng
m hello_rust
Bu sayfadaki içerik ve kod örnekleri, İçerik Lisansı sayfasında açıklanan lisanslara tabidir. Java ve OpenJDK, Oracle ve/veya satış ortaklarının tescilli ticari markasıdır.
Son güncelleme tarihi: 2025-07-27 UTC.
[[["Anlaması kolay","easyToUnderstand","thumb-up"],["Sorunumu çözdü","solvedMyProblem","thumb-up"],["Diğer","otherUp","thumb-up"]],[["İhtiyacım olan bilgiler yok","missingTheInformationINeed","thumb-down"],["Çok karmaşık / çok fazla adım var","tooComplicatedTooManySteps","thumb-down"],["Güncel değil","outOfDate","thumb-down"],["Çeviri sorunu","translationIssue","thumb-down"],["Örnek veya kod sorunu","samplesCodeIssue","thumb-down"],["Diğer","otherDown","thumb-down"]],["Son güncelleme tarihi: 2025-07-27 UTC."],[],[],null,["# Hello Rust example\n\nThe following is an example of constructing a Rust binary that depends on\na Rust library.\n\nRust modules are currently confined to specific directories defined in\n[build/soong/rust/config/allowed_list.go](https://android.googlesource.com/platform/build/soong/+/41461f36604948ef72855d56093d8b3e45f1d19c/rust/config/allowed_list.go).\nThe following `helloWorld` module uses the `external/rust` directory to avoid\nmodifying this list.\n\nFrom the AOSP source root \n\n mkdir -p external/rust/hello_rust/src/\n mkdir -p external/rust/libsimple_printer/src/\n\nCreate `external/rust/hello_rust/src/hello_rust.rs` with the following contents: \n\n use simple_printer;\n fn main() {\n simple_printer::print_hello_rust();\n }\n\nCreate `external/rust/libsimple_printer/src/lib.rs` file with the following contents: \n\n pub fn print_hello_rust() {\n println!(\"Hello Rust!\");\n }\n\nCreate an `external/rust/hello_rust/Android.bp` file with the following contents: \n\n rust_binary {\n name: \"hello_rust\",\n\n // srcs must contain a single source file, the entry point source.\n srcs: [\"src/hello_rust.rs\"],\n\n // rustlibs are Rust library dependencies. The type, rlib (static) or dylib\n // (dynamic), are chosen automatically based on module type and target\n // to avoid linkage issues.\n rustlibs: [\"libsimple_printer\"],\n\n // define any additional compilation flags\n flags: [\n \"-C debug-assertions=yes\",\n ],\n\n // cc libraries can be linked in to rust binaries and libraries through the\n // shared_libs and static_libs properties. These are not needed for this\n // simple example, so they are not included.\n }\n\nCreate an `external/rust/libsimple_printer/Android.bp` file with the following contents: \n\n // rust_library provides dylib and rlib variants.\n rust_library {\n //name or stem properties must be of the form lib\u003ccrate_name\u003e\u003cany_suffix\u003e\n name: \"libsimple_printer\",\n\n //crate_name must match the name used in source (e.g. extern crate \u003cname\u003e)\n crate_name: \"simple_printer\",\n\n //srcs must contain a single source file, the entry point source\n srcs: [\"src/lib.rs\"],\n }\n\nFinally, build your `hello_rust` module: \n\n source build/envsetup.sh\n lunch aosp_arm64-eng\n m hello_rust"]]