Xây dựng Android

Làm theo hướng dẫn trên trang này để tạo Android.

Thiết lập môi trường bản dựng

Trong thư mục đang hoạt động, hãy lấy nguồn tập lệnh envsetup.sh để thiết lập môi trường bản dựng:

source build/envsetup.sh

Tập lệnh này nhập một số lệnh cho phép bạn làm việc với mã nguồn Android, bao gồm các lệnh được sử dụng trên trang này. Để xem nguồn của tập lệnh, hãy tham khảo platform/build/envsetup.sh. Để xem trợ giúp được tích hợp sẵn, hãy nhập hmm.

Chọn mục tiêu

Trước khi xây dựng Android, bạn phải xác định mục tiêu cần xây dựng. Mục tiêu phản ánh nền tảng mục tiêu mà bạn đang xây dựng. Để xác định mục tiêu cần tạo, hãy sử dụng lệnh lunch, theo sau là một chuỗi đại diện cho mục tiêu. Ví dụ:

lunch aosp_cf_x86_64_phone-trunk_staging-userdebug

Bạn sẽ thấy một bản tóm tắt về mục tiêu và môi trường xây dựng:

============================================
PLATFORM_VERSION_CODENAME=VanillaIceCream
PLATFORM_VERSION=VanillaIceCream
PRODUCT_INCLUDE_TAGS=com.android.mainline
TARGET_PRODUCT=aosp_arm
TARGET_BUILD_VARIANT=eng
TARGET_ARCH=arm
TARGET_ARCH_VARIANT=armv7-a-neon
TARGET_CPU_VARIANT=generic
HOST_OS=linux
HOST_OS_EXTRA=Linux-6.5.13-1rodete2-amd64-x86_64-Debian-GNU/Linux-rodete
HOST_CROSS_OS=windows
BUILD_ID=AOSP.MAIN
OUT_DIR=out
============================================

Chuỗi biểu thị mục tiêu có định dạng như sau:

lunch product_name-release-build_variant

Các thành phần của chuỗi này là:

  • product_name là tên của sản phẩm bạn muốn tạo, chẳng hạn như aosp_cf_x86_64_phone hoặc aosp_husky. product_name cụ thể của bạn có thể tuân theo định dạng của riêng bạn cho thiết bị, nhưng định dạng mà Google sử dụng cho các thiết bị của mình có các thành phần sau:

    • aosp đề cập đến Nền tảng nguồn mở Android.
    • (không bắt buộc) cf được đưa vào khi mục tiêu dự kiến sẽ chạy trong trình mô phỏng cá mực.
    • Cấu trúc và phần cứng (tên mã), chẳng hạn như x86_64_phone hoặc husky là tên mã của Pixel 8 Pro. Để biết danh sách tên mã cho các thiết bị của Google, hãy xem phần Tên mã của thiết bị.
  • release được đặt thành trunk_staging.

  • Phần build_variant của chuỗi có thể là một trong ba giá trị trong bảng sau:

    build_variant Mô tả
    user Biến thể bản dựng này cung cấp quyền truy cập bảo mật hạn chế và phù hợp để phát hành công khai.
    userdebug Biến thể bản dựng này giúp nhà phát triển thiết bị nắm được hiệu suất và sức mạnh của bản phát hành đang trong quá trình phát triển. Khi phát triển bằng bản dựng userdebug, hãy tuân thủ Nguyên tắc gỡ lỗi người dùng.
    eng Biến thể bản dựng này có thời gian tạo bản dựng nhanh hơn và phù hợp nhất với hoạt động phát triển hằng ngày nếu bạn không quan tâm đến hiệu suất và nguồn điện.

Nếu chạy lunch mà không có đối số nào, bạn sẽ thấy một danh sách các mục tiêu phổ biến. Bạn cũng có thể tạo chuỗi mục tiêu của riêng mình bằng cách kết hợp các phần tử của chuỗi mục tiêu lại với nhau bằng cách sử dụng thông tin trên trang này và tên mã thể hiện phần cứng cụ thể của Google trong phần Tên mã của thiết bị.

Xem mục tiêu hiện tại

Để xem chế độ cài đặt hiện tại cho bữa trưa, hãy chạy:

$ echo "$TARGET_PRODUCT-$TARGET_BUILD_VARIANT"

Tạo mã

Chạy lệnh sau để tạo mục tiêu. Tuỳ thuộc vào thông số kỹ thuật của máy trạm, bản dựng đầu tiên có thể mất chưa đến một giờ và lên đến vài giờ. Các bản dựng tiếp theo sẽ mất ít thời gian hơn đáng kể.

m

Kết quả của bản dựng sẽ xuất hiện trong $OUT_DIR. Nếu bạn tạo nhiều mục tiêu khác nhau, thì mỗi bản dựng mục tiêu sẽ xuất hiện trong $OUT_DIR.

Lệnh m tạo từ đầu cây, vì vậy, bạn có thể chạy m từ trong các thư mục con. Nếu bạn đã đặt biến môi trường TOP, lệnh m sẽ sử dụng biến đó. Nếu bạn không đặt TOP, lệnh m sẽ tra cứu cây trong thư mục hiện tại để cố gắng tìm phần trên cùng của cây.

Lệnh m có thể xử lý các tác vụ song song với một đối số -jN. Nếu bạn không cung cấp đối số -j, hệ thống xây dựng sẽ tự động chọn số lượng tác vụ song song mà hệ thống cho là tối ưu cho hệ thống của bạn.

Bạn có thể tạo các mô-đun cụ thể thay vì hình ảnh đầy đủ của thiết bị bằng cách liệt kê tên mô-đun trong dòng lệnh m. Ngoài ra, lệnh m cung cấp một số mục tiêu giả, được gọi là mục tiêu. Ví dụ: m nothing không tạo bất cứ thứ gì nhưng phân tích cú pháp và xác thực cấu trúc bản dựng. Để xem danh sách các mục tiêu hợp lệ, hãy nhập m help.

Khắc phục lỗi bản dựng (8.0 trở xuống)

Nếu bạn đang tạo AOSP 8 trở xuống, m có thể huỷ khi gặp vấn đề với phiên bản Java của bạn. Ví dụ: bạn có thể nhận được thông báo sau:

************************************************************
You are attempting to build with the incorrect version
of java.

Your version is: WRONG_VERSION.
The correct version is: RIGHT_VERSION.

Please follow the machine setup instructions at
    https://source.android.com/source/initializing.html
************************************************************

Sau đây là các nguyên nhân và giải pháp có thể xảy ra:

  • Bạn không cài đặt được JDK chính xác như đã chỉ định trong các phần về JDK của bài viết Thiết lập để phát triển AOSP (2.3 – 8.0) .
  • Có một JDK khác đã cài đặt trước đó đang xuất hiện trong đường dẫn của bạn. Đặt JDK chính xác vào đầu đường dẫn hoặc xoá JDK có vấn đề.