Android 安卓 Soong构建系统——Blueprint Android.bp配置文件解析

文章目录

    • Android.bp起源
    • Android.bp文件结构
    • 如何编写Android.bp文件
    • 实例详解
      • 实例1
      • 实例2
    • 常见问题解答
      • 1. 如何确定使用哪种模块类型?
      • 2. 如何指定模块的依赖项?
      • 其他疑问可参考官方文档

参考文章:Android.bp 语法和使用

在这里插入图片描述

Android.bp起源

早期的Android系统采用的是Makefile(Android.mk)作为其构建系统。这是一种广泛应用于Unix和Linux环境中的构建工具,它依赖于一系列以文本形式编写的指令(称为Makefiles)来自动构建程序。

然而,随着Android项目的规模逐渐扩大,Makefile开始显得不够灵活,而且构建速度相对较慢。特别是在处理复杂的依赖关系和条件编译时,Makefile的语法也显得过于复杂和笨重。

因此,Google决定开发一个新的构建系统——Soong,它使用Go语言编写,专门针对Android项目进行了优化。Soong引入了一种新的配置文件格式:Blueprint,即我们现在所说的Android.bp。

Android.bp是Blueprint配置文件的一种特殊形式,专门用于定义Android源代码树中的构建目标。Blueprint最初是由Google为其Soong构建系统开发的,并在Android Nougat(7.0)版本中首次引入。

Blueprint的设计理念是简单、易读、易写,它基于声明式语法,只需要描述要做什么,而不需要指定如何做。这使得配置文件更加简洁,便于开发者理解和维护。

Android.bp文件采用类似JSON的语法,但更为简洁。它主要包括模块类型、模块名称和模块属性等部分,用于定义如何构建一个模块。

自从引入Android.bp文件以来,Android的构建过程已经变得更加简单和高效。Android.bp提供了一种灵活的方式来配置构建参数,支持各种不同类型的构建目标,如二进制文件、库文件、测试用例等。

同时,由于Android.bp文件的语法简单明了,新手开发者也能快速上手。对于大型项目来说,使用Android.bp可以显著提升构建性能,减少构建时间,提高开发效率。

Android.bp文件结构

Android.bp文件通常包含以下部分:

  1. 模块类型:如cc_binary, cc_library等,定义了模块的类型。

  2. 模块名称:通过name字段定义,是模块的唯一标识。

  3. 模块属性:这些属性可用于控制模块的构建行为。例如,srcs属性指定了源代码文件,deps属性则指定了模块的依赖项。


如何编写Android.bp文件

一个基本的Android.bp文件可能看起来像这样:

cc_binary {name: "my_module",srcs: ["my_module.c"],deps: ["my_dependency"],
}

在这个例子中,cc_binary是模块类型,表示要构建的是一个C/C++可执行文件。name属性定义了模块名称,srcs属性指定了源代码文件,而deps属性则列出了依赖的模块。


实例详解

实例1

下面是一个更复杂的Android.bp文件示例,它涵盖了更多模块属性:

cc_library {name: "libmylibrary",srcs: ["my_file.cpp"],cflags: ["-Wall", "-Werror"],export_include_dirs: ["include"],static_libs: ["libmystaticlib"],shared_libs: ["libmysharedlib"],
}

在这个例子中,cflags属性用于指定编译器标志,export_include_dirs属性定义了其他模块可以访问的头文件目录,而static_libsshared_libs属性则分别列出了静态库和共享库的依赖项。

实例2

//
// Copyright (C) 2008 The Android Open Source Project
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
//      http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//// This makefile supplies the rules for building a library of JNI code for
// use by our example of how to bundle a shared library with an APK.package {default_applicable_licenses: ["Android-Apache-2.0"],
}cc_library_shared {name: "libsimplejni",// All of the source files that we will compile.srcs: ["native.cpp"],// All of the shared libraries we link against.shared_libs: ["liblog"],// No static libraries.static_libs: [],cflags: ["-Wall","-Werror",],header_libs: ["jni_headers"],stl: "none",sdk_version: "current",
}

这是一个用于构建 Android 平台上 JNI (Java Native Interface) 代码库的 android.bp 文件。Android.bp 是 Android 的构建系统 Soong 使用的脚本语言,用于描述如何构建源代码。

以下是各个部分的解读:

  1. CopyrightLicense 部分:此部分指定了此文件的版权信息和许可证信息,说明该文件遵循 Apache License 2.0 许可证。

  2. package 部分:此处指定了默认适用的许可证,即 Android-Apache-2.0。

  3. cc_library_shared 部分:定义了一个名为 “libsimplejni” 的共享 C/C++ 库。

    • name: "libsimplejni":定义了库的名称为 libsimplejni。

    • srcs: ["native.cpp"]:要编译的源文件列表,这里只有一个文件 “native.cpp”。

    • shared_libs: ["liblog"]:要链接的共享库列表,这里只链接了一个名为 “liblog” 的库。

    • static_libs: []:静态库列表为空,表示没有需要链接的静态库。

    • cflags: ["-Wall", "-Werror"]:要传递给 C/C++ 编译器的选项,“-Wall” 开启所有警告,“-Werror” 将所有警告视为错误。

    • header_libs: ["jni_headers"]:头文件库列表,包含了 “jni_headers”。

    • stl: "none":指定不使用任何 STL (Standard Template Library) 库。

    • sdk_version: "current":指定了 SDK 版本为当前版本。


常见问题解答

1. 如何确定使用哪种模块类型?

模块类型取决于你要构建的项目。例如,如果你正在构建一个C/C++的可执行文件,应该使用cc_binary;如果你正在构建一个Java库,应该使用java_library

2. 如何指定模块的依赖项?

你可以在deps属性中列出所有直接依赖的模块名称。Soong构建系统将自动处理这些依赖项,并确保在构建当前模块之前先构建它们。

其他疑问可参考官方文档

Android官方文档

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/165116.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

项目构建工具maven的基本配置+idea 中配置 maven

👑 博主简介:知名开发工程师 👣 出没地点:北京 💊 2023年目标:成为一个大佬 ——————————————————————————————————————————— 版权声明:本文为原创文…

操作系统 day06(进程控制、原语)

进程控制的概念 原语 怎么实现进程控制—用原语实现 如果不能一气呵成,那么会出现操作系统中的某些关键数据结构信息不统一的情况,这会影响操作系统进行别的管理工作,如下图所示: 原语的原子性怎么实现 正常情况下&#xff…

阿里云中的云服务器的ubuntu中的vim没有显示行号

没有行号: 在终端输入命令: vim ~/.vimrc set nu

装修服务预约小程序的内容如何

大小装修不断,市场中大小品牌也比较多,对需求客户来说,可以线下咨询也可以线上寻找品牌,总是可以找到满意的服务公司,而对装修公司来说如今线下流量匮乏,很多东西也难以通过线下方式承载,更需要…

socket编程中的EINTR是什么?

socket编程中的EINTR是什么? 在socket编程中&#xff0c;我们时常在accept/read/write等接口调用的异常处理的部分看到对于EINTR的处理&#xff0c;例如下面这样的语句&#xff1a; repeat: if(read(fd, buff, size) < 0) {if(errno EINTR)goto repeat;elseprintf("…

【配置】如何在打包Spring Boot项目时按需使用日常、测试、预发、正式环境的配置文件

文章目录 前言1. 创建5个配置文件2. 在pom.xml文件中如下配置3. 在application.properties中加入环境变量 前言 在我们开发项目的时候&#xff0c;一般有四套环境&#xff1a;日常、测试、预发、正式。日常环境作为我们开发环境&#xff1b;测试环境给测试同学测试功能&#x…

npm发布自己的包

npm发布自己的包 1. 首先在npm官网注册一个自己的账户(有账号的可以直接登录) 注册地址 2. 创建一个自己的项目(如果已有自己的项目, 跳过这一步) npm init -y3. 确认自己的npm下载源, 只能使用npm官方的地址 npm config get registry修改地址源 npm config set registr…

两个String案例

我的思考&#xff1a; 用户名和密码可以分别用一个字符串保存&#xff0c;再与输入的字符串分别比较&#xff0c;先比较用户名&#xff0c;成功后再比较密码&#xff0c;注意比较字符串不能直接用 &#xff0c;而是要用String类的方法实现。 我的代码&#xff1a; //User.…

C语言——从键盘任意输人一个三位数的自然数,求该数个位、十位、百位上的数字之和

#define _CRT_SECURE_NO_WARNINGS 1#include<stdio.h> int main() {int i,ge,shi,bai;printf("输入一个三位数整数&#xff1a;\n");scanf("%d",&i);gei%10; //个位shii%100/10; //十位baii/100; //百位printf("个位:%d,十位:%d,百位:…

Bitget Wallet:使用 Base 链购买 ETH 的简明教程

Base 链是一种 Layer 2&#xff08;L2&#xff09;公链&#xff0c;它可以为用户提供以太坊&#xff08;ETH&#xff09;代币&#xff0c;而 Bitget Wallet 是一款多功能加密货币钱包&#xff0c;支持 Base 链以及其他主要区块链。

模块化之CJS, AMD, UMD 和 ESM

[[toc]] 模块化优点 防止命名冲突代码复用高维护性CJS, AMD, UMD 和 ESM 历史 ES6之前,JS一直没有自己的模块体系后来社区出现了CommonJS和AMD,CommonJS 主要用于服务器(Node)AMD 主要用于浏览器ES6引入了ESM到此,JS终于有了自己的模块体系,基本上可以完全取代CJS和AMD…

kubernetes集群编排——k8s调度

nodename vim nodename.yaml apiVersion: v1 kind: Pod metadata:name: nginxlabels:app: nginxspec:containers:- name: nginximage: nginxnodeName: k8s2 nodeName: k8s2 #找不到节点pod会出现pending&#xff0c;优先级最高 kubectl apply -f nodename.yamlkubectl get pod …