淘宝客api调用到网站,wordpress+左侧导航,seo专业推广,网站做的好不好看什么零. 前言
由于Bluedroid的介绍文档有限#xff0c;以及对Android的一些基本的知识需要了(Android 四大组件/AIDL/Framework/Binder机制/JNI/HIDL等)#xff0c;加上需要掌握的语言包括Java/C/C等#xff0c;加上网络上其实没有一个完整的介绍Bluedroid系列的文档#xff0… 零. 前言
由于Bluedroid的介绍文档有限以及对Android的一些基本的知识需要了(Android 四大组件/AIDL/Framework/Binder机制/JNI/HIDL等)加上需要掌握的语言包括Java/C/C等加上网络上其实没有一个完整的介绍Bluedroid系列的文档所以不管是蓝牙初学者还是蓝牙从业人员都有不小的难度学习曲线也相对较陡所以我有了这个想法专门对Bluedroid做一个系统性的介绍尽可能的涵盖所有内容。
-------------------------------------------------------------------------------------------------------------------------
蓝牙视频教程(跟韦东山老师合作), 其中专题21就是专门针对Bluedroid做的系统介绍
https://item.taobao.com/item.htm?spma1z10.1-c-s.w4004-22329603896.20.5aeb41f98e267jid693788592796
--------------------------------------------------------------------------------------------------------------------------
一. Android mk
1. 介绍
Android.mk是Android提供的一种makefile文件用来指定诸如编译生成so库名、引用的头文件目录、需要编译的.c/.cpp文件和.a静态库文件等。要掌握jni就必须熟练掌握Android.mk的语法规范。
LOCAL_PATH : $(call my-dir)
include $(CLEAR_VARS)
................
LOCAL_xxx : xxx
LOCAL_MODULE : hello-jni
LOCAL_SRC_FILES : hello-jni.c
LOCAL_xxx : xxx
................
include $(BUILD_SHARED_LIBRARY)LOCAL_PATH变量指定了该.mk的路径$(call my-dir)调用NDK内部的函数获得当前.mk文件的路径
include $(CLEAR_VARS)清空了除了LOCAL_PATH之外的所有LOCAL_xxx变量的值
省略号中间就是对于模块参数的设置主要包括模块名字、模块源文件、模块类型、编译好的模块存放位置、以及编译的平台等
include $(BUILD_xxx_xxx)执行NDK的默认脚本它会收集include $(CLEAR_VARS)脚本后所有定义的LOCAL_xxx变量然后根据它们来生成模块。
2. Android.mk语法详解
LOCAL_PATH : $(call my-dir) 每个Android.mk文件必须以定义LOCAL_PATH为开始。它用于在开发tree中查找源文件。宏my-dir 则由Build System提供。返回包含Android.mk的目录路径。 include $(CLEAR_VARS) CLEAR_VARS 变量由Build System提供。并指向一个指定的GNU Makefile由它负责清理很多LOCAL_xxx. 例如LOCAL_MODULE, LOCAL_SRC_FILES, LOCAL_STATIC_LIBRARIES等等。但不清理LOCAL_PATH. 这个清理动作是必须的因为所有的编译控制文件由同一个GNU Make解析和执行其变量是全局的。所以清理后才能避免相互影响。 LOCAL_MODULE : hello-jni
LOCAL_MODULE模块必须定义以表示Android.mk中的每一个模块。名字必须唯一且不包含空格。Build System会自动添加适当的前缀和后缀。例如foo要产生动态库则生成libfoo.so. 但请注意如果模块名被定为libfoo.则生成libfoo.so. 不再加前缀 LOCAL_MODULE_PATH :$(TARGET_ROOT_OUT) 指定最后生成的模块的目标地址
TARGET_ROOT_OUT:根文件系统路径为out/target/product/generic/root
TARGET_OUT:system文件系统路径为out/target/product/generic/system
TARGET_OUT_DATA:data文件系统路径为out/target/product/generic/data
除了上面的这些NDK还提供了很多其他的TARGET_XXX_XXX变量用于将生成的模块拷贝到输出目录的不同路径
默认是TARGET_OUT
LOCAL_SRC_FILES : hello-jni.c
LOCAL_SRC_FILES变量必须包含将要打包如模块的C/C 源码。不必列出头文件build System 会自动帮我们找出依赖文件。缺省的C源码的扩展名为.cpp. 也可以修改通过LOCAL_CPP_EXTENSION include $(BUILD_SHARED_LIBRARY) BUILD_SHARED_LIBRARY是Build System提供的一个变量指向一个GNU Makefile Script。 它负责收集自从上次调用 include $(CLEAR_VARS) 后的所有LOCAL_XXX信息。并决定编译为什么。
BUILD_STATIC_LIBRARY 编译为静态库。 BUILD_SHARED_LIBRARY 编译为动态库 BUILD_EXECUTABLE 编译为Native C可执行程序
BUILD_PREBUILT 该模块已经预先编译
NDK还定义了很多其他的BUILD_XXX_XXX变量它们用来指定模块的生成方式。
三. Android.mk实战
1.编译静态库
首先我们把vendor下创建一个Study的目录然后再Study创建一个test1的目录tree如下 我们的目标是把test.c编译成一个静态库
test.c代码如下
#include stdio.hint test(void)
{printf(hello Androoid.mk\r\n);return 0;
}
Android.mk代码如下
LOCAL_PATH : $(call my-dir)
include $(CLEAR_VARS)
LOCAL_SRC_FILES : test.c
LOCAL_MODULE : test1
include $(BUILD_STATIC_LIBRARY)
编译方法
方法1在android 跟目录下敲指令make test1
方法2在vendor/Study/test1目录下敲指令mm
注意两个方法都需要先source build/envsetup.sh - lunch选择41
test.a生成在out/target/product/rk3399_roc_pc_plus/obj_arm/STATIC_LIBRARIES/test1_intermediates/test1.a
NOTED我们发现生成的并不是libtest1.a而是test1.a这个要注意下
2.编译动态库
首先我们把vendor下创建一个Study的目录然后再Study创建一个test2的目录tree如下 我们的目标是把test.c编译成一个静态库
test.c代码如下
#include stdio.hint test(void)
{printf(hello Androoid.mk\r\n);return 0;
}
Android.mk代码如下
LOCAL_PATH : $(call my-dir)
include $(CLEAR_VARS)
LOCAL_SRC_FILES : test.c
LOCAL_MODULE : test2
include $(BUILD_SHARED_LIBRARY)
编译方法
方法1在android 跟目录下敲指令make test2
方法2在vendor/Study/test2目录下敲指令mm
注意两个方法都需要先source build/envsetup.sh - lunch选择41
test.so生成在out/target/product/rk3399_roc_pc_plus/obj_arm/SHARED_LIBRARIES/test2_intermediates/test2.so
NOTED我们发现生成的并不是libtest2.so而是test2.so这个要注意下
二. Android bp
1. Android.bp概念
Android.bp 文件首先是 Android 系统的一种编译配置文件是用来代替原来的 Android.mk文件的。在Android7.0 以前Android 都是使用 make 来组织各模块的编译对应的编译配置文件就是 Android.mk。 在 Android7.0 开始Google 引入了 ninja 和 kati 来编译为啥引入 ninja因为随着 Android 越来越庞大module 越来越多编译时间也越来越久而使用 ninja 在编译的并发处理上较 make 有很大的提升。Ninja 的配置文件就是Android.bpAndroid 系统使用 Blueprint 和 Soong 工具来解析 Android.bp 转换生成 ninja文件。为了兼容老的 mk 配置文件Android 当初也开发了 Kati 工具来转换 mk 文件生成ninja目前 Android Q 里边还是支持 Android.mk 方式的。相信在将来的版本中会彻底让 mk 文件废弃同时 Kati 也就淘汰了只保留 bp 配置方式所以我们要提前学习bp。 这里涉及到Ninja, kati, Soong, bp概念接下来分别简单介绍一下。
Ninja
ninja是一个编译框架会根据相应的ninja格式的配置文件进行编译但是ninja文件一般不会手动修改而是通过将Android.bp文件转换成ninja格文件来编译。
Android.bp
Android.bp的出现就是为了替换Android.mk文件。bp跟mk文件不同它是纯粹的配置没有分支、循环等流程控制不能做算数逻辑运算。如果需要控制逻辑那么只能通过Go语言编写。
Soong
Soong类似于之前的Makefile编译系统的核心负责提供Android.bp语义解析并将之转换成Ninja文件。Soong还会编译生成一个androidmk命令用于将Android.mk文件转换为Android.bp文件不过这个转换功能仅限于没有分支、循环等流程控制的Android.mk才有效。
Blueprint
Blueprint是生成、解析Android.bp的工具是Soong的一部分。Soong负责Android编译而设计的工具而Blueprint只是解析文件格式Soong解析内容的具体含义。Blueprint和Soong都是由Golang写的项目从Android 7.0prebuilts/go/目录下新增Golang所需的运行环境在编译时使用。
Kati
kati是专为Android开发的一个基于Golang和C的工具主要功能是把Android中的Android.mk文件转换成Ninja文件。代码路径是build/kati/编译后的产物是ckati。 重要的事情说三遍Android.mk可以引用Android.bp中的模块反之Android.bp不能引用Android.mk中的模块。
重要的事情说三遍Android.mk可以引用Android.bp中的模块反之Android.bp不能引用Android.mk中的模块。
重要的事情说三遍Android.mk可以引用Android.bp中的模块反之Android.bp不能引用Android.mk中的模块。
2. Android mk转换成Android bp
1.安装androidmk 工具
我们以rk3399来举例说明
source build/envsetup.sh
lunch rk3399_roc_pc_plus-userdebug
make androidmk
生成androidmk转换工具路径为/out/soong/host/linux-x86/bin/androidmk
2.转换
androidmk Android.mk Android.bp
3.Android bp语法
1.编译静态库
首先我们把vendor下创建一个Study的目录然后再Study创建一个test1的目录tree如下 我们的目标是把test.c编译成一个静态库
test.c代码如下
#include stdio.hint test(void)
{printf(hello Androoid.mk\r\n);return 0;
}
Android.bp代码如下
cc_library_static {name: test3,srcs: [test.c],
}
编译方法
方法1在android 跟目录下敲指令make test3
方法2在vendor/Study/test3目录下敲指令mm
注意两个方法都需要先source build/envsetup.sh - lunch选择41
test.a生成在out/target/product/rk3399_roc_pc_plus/obj_arm/STATIC_LIBRARIES/test3_intermediates/test3.a
NOTED我们发现生成的并不是libtest3.a而是test3.a这个要注意下
其中cc_library_static就是编译成c/c 静态库可以有以下类型 name就是模组的名称
srcs就是源文件
2.编译动态库
首先我们把vendor下创建一个Study的目录然后再Study创建一个test2的目录tree如下 我们的目标是把test.c编译成一个静态库
test.c代码如下
#include stdio.hint test(void)
{printf(hello Androoid.mk\r\n);return 0;
}
Android.bp代码如下
cc_library_shared {name: test4,srcs: [test.c],
}
编译方法
方法1在android 跟目录下敲指令make test4
方法2在vendor/Study/test4目录下敲指令mm
注意两个方法都需要先source build/envsetup.sh - lunch选择41
test.so生成在out/target/product/rk3399_roc_pc_plus/obj_arm/SHARED_LIBRARIES/test4_intermediates/test4.so
NOTED我们发现生成的并不是libtest4.so而是test4.so这个要注意下