在前面我简单的描述了Android的启动过程http://blog.csdn.net/codectq/article/details/7383231,但终究是不够完善。

现在在工程中遇到了实际的问题,反过来阅读下代码,再重新审视一下在kernel启动之后的ANDROID启动过程。

在frameworks/base/services/java/com/android/server文件夹下的SystemServer.cpp文件。在此文件中调用了init1()函数,文件中对次函数的描述为:这个方法是从Zygote中调用来初始化系统。这将引起本地的服务(Surfaceflinger,audioflinger等)开启。在这些完成之后将回调init2()来开始android服务。

从上面的描述中我们可以得知两个方面:一是在android的服务中,我们分两种服务,一种是native服务,另一种是android服务。二是我们的本地服务是在init1()的过程中完成的,而android服务是在init2()的过程中完成的。

从实际的真机的启动过程的打印信息我们也能够看出,在启动的过程中,我们首先会启动SurfaceFlinger,AudioFlinger然后开始启动dalikvm,从而进入对Zygote和System并且通过调用system_init()函数和sysproc来启动Android runtime 启动native service。通过回调init2(),Android service\thread pool从而进入systemserver,运行systemserver线程,将注册到systemserver中的服务启动。

如果我们想借助Android本身的架构来完成添加我们的服务的目的的情况下我们不妨就利用这些。

在我们通过使用JNI机制使得上层的java应用能够调用native service。而具体的实现就是将.cpp文件放在JNI文件夹下,而将.java文件放在java文件夹下。具体步骤如下:

在上文中,我们说过我们可以借助Android自身架构的东西来完成我们的JNI服务,而不必每个细节都自己完成。并且我们提到我们会调用AndroidRuntime所以我们可以将服务注册到AndroidRuntime.cpp文件中。下面是个经典的例子,此处做个摘抄地址为http://dongyulong.blog.51cto.com/1451604/545496(但是不知道是不是原作者)

frameworks/base/core/jni路径下创建例子android_mytest_hellojni.cpp文件,这个文件就是在JNI层实现接口。文件内容如下:(可参考同一目录下的android_debug_JNITest.cpp文件编写)

#defineLOG_TAG"HelloJNI"
#include"jni.h"
#include"nativehelper/JNIHelp.h"
#include"utils/Log.h"
#include"utils/misc.h"

namespaceandroid{
staticjstring android_mytest_hellojni_displayString(JNIEnv*env,jclass clazz)
{
returnenv->NewStringUTF("Hello from JNI!");
}

/*
* JNI registration.
*/

staticJNINativeMethod gMethods[]={
/* name, signature, funcPtr */
{"displayString","()Ljava/lang/String;",
(void*)android_mytest_hellojni_displayString},

};
intregister_android_mytest_hellojni(JNIEnv*env)
{//此处的目录结构就是在Javaframework层的文件目录,且必须一致

returnjniRegisterNativeMethods(env,"android/mytest/hellojni",
gMethods,NELEM(gMethods));
}
};

2.JNI层:对编译的修改配置

2.1修改/Android/android-1.6_r2/frameworks/base/core/jni目录下的Android.mk文件,在LOCAL_SRC_FILES:= \下面加上
android_mytest_hellojni.cpp \
2.2修改/Android/android-1.6_r2/frameworks/base/core/jni目录下的AndroidRuntime.cpp文件在extern int后面添加
extern int register_android_mytest_hellojni(JNIEnv* env);
然后在static const RegJNIRec gRegJNI[] ={下面添加
REG_JNI(register_android_mytest_hellojni),
这样,JNI层的修改就到此为止了。

frameworks/base/core/java/android/新建文件目录mytest,在该目录下新建文件hellojni.java声明接口。内容如下:(可以参考android-1.6_r2/frameworks/base/core/java/android/debug目录下的JNITest.java文件编写)

packageandroid.mytest;
publicclasshellojni{
publichellojni(){}
//此处声明为public所以才可以被application调用

publicstaticnativeStringdisplayString();
}

4.下面我们要对我们做过更改的libandroid_runtime.so和framework.jar进行重新编译。

在源代码工程目录下输入make libandroid_runtime重新编译生成libandroid_runtime.so

target thumb C++: libandroid_runtime <= frameworks/base/core/jni/android_mytest_hellojni.cpp

target thumb C++: libandroid_runtime <= frameworks/base/core/jni/AndroidRuntime.cpp

target SharedLib: libandroid_runtime (out/target/product/generic/obj/SHARED_LIBRARIES/libandroid_runtime_intermediates/LINKED/libandroid_runtime.so)

target Prelink: libandroid_runtime (out/target/product/generic/symbols/system/lib/libandroid_runtime.so)

target Strip: libandroid_runtime (out/target/product/generic/obj/lib/libandroid_runtime.so)

Install:out/target/product/generic/system/lib/libandroid_runtime.so

然后再输入make framework重新编译生成framework.jar

Install:out/target/product/generic/system/framework/framework.jar


更多相关文章

  1. Android(安卓)SDK相关介绍
  2. android九宫格实现
  3. Android对话框里面的输入值获取不到,空指针异常
  4. Android高手进阶教程(四)之----Android(安卓)中自定义属性(attr.
  5. [gitbook] Android框架分析系列之Android(安卓)stagefright框架
  6. Android(安卓)核心分析 之七------Service深入分析
  7. android process information
  8. android studio 新建项目 界面一直停在 【“building ‘ 项目名
  9. ubuntu 使用adb shell命令识别android设备

随机推荐

  1. android sd卡状态、路径、可用空间,内存
  2. android 显示特殊符号
  3. android apk执行shell脚本
  4. Android(安卓)KITKAT 以上实现沉浸式状态
  5. How to edit the init.rc in android
  6. android orientationchange的问题
  7. 2011.09.26(5)——— android sample之Note
  8. 布局技巧:使用ViewStub
  9. [原创] Android(安卓)SDK 安装全记录
  10. Eclipse中使用Ant打Android包报错及解决