在GitHub上下载了一个demo,自己编译运行时,v8a的so是可以正常编译运行的,但是就是v7a的不能也一直报错,最后发现在Android.mk文件里去掉-Werror
字段就可以了。于是上网了解了一下关于-Werror
的意思,这里记录一下
Android源码下编译Native源码采用Android.mk或者Android.bp,由于源码编译选项越来越严格,特别是Android O平台以后,默认编译选项都使用了-Wall -Werror字段,现在简要说明下
1. -Wall和-Werror字段
- Wall:编译阶段显示所有警告。
- Werror:将所有的警告当成错误进行处理,使出现警告时就停止编译,这种错误是最常见的。
2. LOCAL_CFLAGS
LOCAL_CFLAGS
是Android.mk
中定义的一个编译选项,稍微总结下常用:
-
-D
选项,相当于添加宏定义,例如:LOCAL_CFLAGS += -DXXX
相当于在所有源文件中增加一个宏定义#define XXX
-
-O
代表默认优化,可选:-O0
不优化,-O1
低级优化,-O2
中级优化,-O3
高级优化,-Os
代码空间优化,用得少,暂不在讨论范围之内。 -
-g
是生成调试信息,生成的可执行文件具有和源代码关联的可调试的信息
-W[no-]<警告选项> no- 表示诊断时忽略这个警告 ,这个是本文的重点地方,划重点了
编译器的警告设置参数,拥有众多的选项,下面举一些常用的例子:-Woption 让编译器给出option指定的编译警告,常用的一些如下: unused-function: 遇到仅声明过但尚未定义的静态函数时发出警告 unused-parameter: 从未用过的函数参数的警告。 unused-variable: 在本地声明但从未用过的变量的警告。 unused-value: 经计算但从未用过的值得警告。 return-type: 对函数返回类型不当的警告。 uninitialized:在初始化之前就使用自动变量。 float-equal: 比较两个浮点数是否相等。 -Wall 给出“几乎”所有的编译器警告,注意是“几乎”。下面是一些-Wall没有输出的警告类型: sign-compare:将有符号类型和无符号类型数据进行比较时发出警告。 unreachable-code:如果发现从未执行的代码时给出警告。 inline:如果某函数不能按要求内嵌(inline),则无论是函数声明为inline或者是指定了 -finline-functions 选项,编译都将发出警告。 -Werror 把所有的警告都视为错误处理。 -Wno-option 如果我们不想输出某些警告信息,可以使用此参数形式, 比如:LOCAL_CFLAGS := -Wno-unused-parameter