四月工作内容

来源:互联网 发布:淘宝代购比旗舰店便宜 编辑:程序博客网 时间:2024/05/01 10:47
第6周:编译.c文件获得可执行文件,执行之后设备和PC都没有响应,不知道是不是自己漏掉了一些步骤,这里先总结一下这几天学习的内容,收藏有用的网址:
1、有用的网址

http://heaven.branda.to/~thinker/GinGin_CGI.py/show_id_doc/393
Android Building System 分析

http://www.ibm.com/developerworks/cn/opensource/os-cn-android-build/

理解android build系统

编译源码时,第一句指令:source build/envsetup.sh

以上的主要流程都是由 build/core/main.mk 所安排。

了解一个系统可以从它的makefile文件或building system下手,了解系统的组成元素和目录结构。

Android building system 包括幾種重要的設定檔,

  • Android.mk
  • AndroidProducts.mk
  • target_<os>-.mk, host_-.mk and -.mk
  • BoardConfig.mk
  • buildspec.mk

android.mk在后面会提到

AndroidProducts.mk 則設定 product 配置。 product 即特定 系統版本,透過編譯不同 product ,產生不同軟體配置內容,安裝不同的 application。 Product 可視為特定專案,產生特定規格系統。

BoardConfig.mk 是為 product 主板做設定,像是 driver 選擇、 設定。*-.mk 則是針對選擇的作業系統和 CPU 架構,進行相關設定。

buildspec.mk 是位於 source 根目錄下,為進行編譯者所做之額外設定。 例如,可在此選擇要產生的 product 、平台、額外的 module/package 等。

添加新的模块

在源码树中,一个模块的所有文件通常都位于同一个文件夹中。为了将当前模块添加到整个 Build 系统中,每个模块都需要一个专门的 Make 文件,该文件的名称为“Android.mk”。Build 系统会扫描名称为“Android.mk”的文件,并根据该文件中内容编译出相应的产物。

Android.mk 是 module 和 package 的設定檔,每個 module/package 的目錄下都會有一個Android.mk。 所謂的 module 是指系統的 native code ,相對於用 Java 寫成的 Androidapplication 稱為 package。

需要注意的是:在 Android Build 系统中,编译是以模块(而不是文件)作为单位的,每个模块都有一个唯一的名称,一个模块的依赖对象只能是另外一个模块,而不能是其他类型的对象。对于已经编译好的二进制库,如果要用来被当作是依赖对象,那么应当将这些已经编译好的库作为单独的模块。对于这些已经编译好的库使用 BUILD_PREBUILT 或 BUILD_MULTI_PREBUILT。例如:当编译某个 Java 库需要依赖一些 Jar 包时,并不能直接指定 Jar 包的路径作为依赖,而必须首先将这些 Jar 包定义为一个模块,然后在编译 Java 库的时候通过模块的名称来依赖这些 Jar 包。

下面,我们就来讲解 Android.mk 文件的编写:

Android.mk 文件通常以以下两行代码作为开头:

 LOCAL_PATH := $(call my-dir)  include $(CLEAR_VARS)

这两行代码的作用是:

  1. 设置当前模块的编译路径为当前文件夹路径。
  2. 清理(可能由其他模块设置过的)编译环境中用到的变量。

为了方便模块的编译,Build 系统设置了很多的编译环境变量。要编译一个模块,只要在编译之前根据需要设置这些变量然后执行编译即可。它们包括:

  • LOCAL_SRC_FILES:当前模块包含的所有源代码文件。
  • LOCAL_MODULE:当前模块的名称,这个名称应当是唯一的,模块间的依赖关系就是通过这个名称来引用的。
  • LOCAL_C_INCLUDES:C 或 C++ 语言需要的头文件的路径。
  • LOCAL_STATIC_LIBRARIES:当前模块在静态链接时需要的库的名称。
  • LOCAL_SHARED_LIBRARIES:当前模块在运行时依赖的动态库的名称。
  • LOCAL_CFLAGS:提供给 C/C++ 编译器的额外编译参数。
  • LOCAL_JAVA_LIBRARIES:当前模块依赖的 Java 共享库。
  • LOCAL_STATIC_JAVA_LIBRARIES:当前模块依赖的 Java 静态库。
  • LOCAL_PACKAGE_NAME:当前 APK 应用的名称。
  • LOCAL_CERTIFICATE:签署当前应用的证书名称。
  • LOCAL_MODULE_TAGS:当前模块所包含的标签,一个模块可以包含多个标签。标签的值可能是 debug, eng, user,development 或者 optional。其中,optional 是默认标签。标签是提供给编译类型使用的。不同的编译类型会安装包含不同标签的模块。

除此以外,Build 系统中还定义了一些便捷的函数以便在 Android.mk 中使用,包括:

  • $(call my-dir):获取当前文件夹路径。
  • $(call all-java-files-under, <src>):获取指定目录下的所有 Java 文件。
  • $(call all-c-files-under, <src>):获取指定目录下的所有 C 语言文件。
  • $(call all-Iaidl-files-under, <src>) :获取指定目录下的所有 AIDL 文件。
  • $(call all-makefiles-under, <folder>):获取指定目录下的所有 Make 文件。
  • $(call intermediates-dir-for, <class>, <app_name>, <host or target>, <common?> ):获取 Build 输出的目标文件夹路径。

清单 2 和清单 3 分别是编译 APK 文件和编译 Java 静态库的 Make 文件示例:

清单 2. 编译一个 APK 文件
  LOCAL_PATH := $(call my-dir)   include $(CLEAR_VARS)   # 获取所有子目录中的 Java 文件  LOCAL_SRC_FILES := $(call all-subdir-java-files)                        # 当前模块依赖的静态 Java 库,如果有多个以空格分隔  LOCAL_STATIC_JAVA_LIBRARIES := static-library   # 当前模块的名称  LOCAL_PACKAGE_NAME := LocalPackage   # 编译 APK 文件  include $(BUILD_PACKAGE)
清单 3. 编译一个 Java 的静态库
  LOCAL_PATH := $(call my-dir)   include $(CLEAR_VARS)      # 获取所有子目录中的 Java 文件  LOCAL_SRC_FILES := $(call all-subdir-java-files)      # 当前模块依赖的动态 Java 库名称  LOCAL_JAVA_LIBRARIES := android.test.runner      # 当前模块的名称  LOCAL_MODULE := sample      # 将当前模块编译成一个静态的 Java 库  include $(BUILD_STATIC_JAVA_LIBRARY)


*************************************************************

这是由于SoundRecorder默认并不在Lancher的category中。

如果想让SoundRecorder在主菜单上显示出来,需要修改AndroidManifest.xml,把SoundRecorder添加到Lancher的category中。

添加如下红色部分:

 

        <activity android:name="SoundRecorder"
                android:configChanges="orientation|keyboardHidden">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER " /
*********************************************************************

http://blog.csdn.net/lambol_8309/article/details/4524964
int main(int argc,char* argv[])详解





0 0