android工具链与GNU工具链的比较
如果下载了完整的Android项目的源代码,则可以在prebuilt/linux-x86/toolchain/arm-eabi-4.2.1/bin目录下找到交叉编译工具,比如Android所用的arm-eabi-gcc-4.2.1。
Android并没有采用glibc作为C库,而是采用了Google自己开发的Bionic Libc。官方自带的Toolchain(prebuilt)也是基于Bionic Libc而并非glibc的。这使得其他Toolchain来用于Android要比较麻烦。
多数的Linux爱好者使用的Toolchain是在http://www.codesourcery.com/gnu_toolchains/arm/download.html下载的一个通用的Toolchain。
它用来编译和移植Android的Linux内核是可行的,因为内核并不需要C库,但是开发Android应用程序时,直接采用其他的Toolchain都比较麻烦。
而只有编译的应用程序采用静态编译的方式才能运行于Android模拟器中,这显然是实际开发中所不能接受的方式。目前尚没有看到说明成功移植其他交叉编译器来编译Android应用程序的资料。(???)
与glibc相比,Bionic Libc有如下一些特点:
[cpp]
-1 采用BSD License,而不是glibc的GPL License;
-2 大小只有大约200k,比glibc差不多小一半,且比glibc更快;
-3 实现了一个更小、更快的pthread;
-4 提供了一些Android所需要的重要函数,如”getprop”,“LOGI”等;
-5 不完全支持POSIX标准,比如C++ exceptions,wide chars等;
-6 不提供libthread_db和libm的实现。(???)
另外,Android中所用的其他一些二进制工具也比较特殊:
[cpp]
-1 加载动态库时使用的是/system/bin/linker,而不是常用的/lib/ld.so;
-2 prelink工具不是常用的prelink,而是 apriori,其源代码位于build/tools/apriori;
-3 strip工具也没有采用常用的strip,即prebuilt/linux-x86/toolchain/arm-eabi-4.2.1/bin目录下的arm-eabi-strip,而是位于out/host/linux-x86/bin/的soslim工具。
解决底层问题方法:解除Android系统的耦合
[cpp]
1 将Dalvik于bionic以及硬件驱动剥离开
2 修改Dalvik以支持标准glibc和GNU/Linux
3 把Dalvik当作普通应用程序
4 Dalvik可被单独优化和改进
补充:移动开发 , Android ,