๋กœ๊น…

log ํฌ๋ ˆ์ดํŠธ๋ฅผ ์‚ฌ์šฉํ•˜๋ฉด ์•ˆ๋“œ๋กœ์ด๋“œ ๋””๋ฐ”์ด์Šค ์•ˆ์—์„œ ์ˆ˜ํ–‰๋  ๋•Œ์—๋Š” logcat์œผ๋กœ, ํ˜ธ์ŠคํŠธ์—์„œ ์ˆ˜ํ–‰๋  ๋•Œ์—๋Š” stdout์œผ๋กœ ๋กœ๊ทธ๊ฐ€ ์ž๋™์œผ๋กœ ์ถœ๋ ฅ์ด ๋˜๋„๋ก ํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค:

hello_rust_logs/Android.bp:

rust_binary {
    name: "hello_rust_logs",
    crate_name: "hello_rust_logs",
    srcs: ["src/main.rs"],
    rustlibs: [
        "liblog_rust",
        "liblogger",
    ],
    host_supported: true,
}

hello_rust_logs/src/main.rs:

//! Rust ๋กœ๊น… ๋ฐ๋ชจ์ž…๋‹ˆ๋‹ค.

use log::{debug, error, info};

/// ์ธ์‚ฌ๋ง์„ ๊ธฐ๋กํ•ฉ๋‹ˆ๋‹ค.
fn main() {
    logger::init(
        logger::Config::default()
            .with_tag_on_device("rust")
            .with_min_level(log::Level::Trace),
    );
    debug!("ํ”„๋กœ๊ทธ๋žจ์„ ์‹œ์ž‘ํ•˜๋Š” ์ค‘์ž…๋‹ˆ๋‹ค.");
    info!("์ž˜ ์ง„ํ–‰๋˜๊ณ  ์žˆ์Šต๋‹ˆ๋‹ค.");
    error!("๋ฌธ์ œ๊ฐ€ ๋ฐœ์ƒํ–ˆ์Šต๋‹ˆ๋‹ค!");
}

๋นŒ๋“œํ•˜๊ณ , ๊ฐ€์ƒ ๋””๋ฐ”์ด์Šค์— ๋„ฃ๊ณ , ์‹คํ–‰ํ•ฉ๋‹ˆ๋‹ค:

m hello_rust_logs
adb push "$ANDROID_PRODUCT_OUT/system/bin/hello_rust_logs" /data/local/tmp
adb shell /data/local/tmp/hello_rust_logs

adb logcat์ปค๋งจ๋“œ๋กœ ๋กœ๊ทธ๋ฅผ ํ™•์ธํ•ฉ๋‹ˆ๋‹ค:

adb logcat -s rust
09-08 08:38:32.454  2420  2420 D rust: hello_rust_logs: Starting program.
09-08 08:38:32.454  2420  2420 I rust: hello_rust_logs: Things are going fine.
09-08 08:38:32.454  2420  2420 E rust: hello_rust_logs: Something went wrong!