参考:http://blog.youkuaiyun.com/yjkwf/article/details/7162873
在上一篇(源代码的编译)基础上,做如下的工作
一、搭建Eclipse源码工程
1、 进入源码目录下的development/ide/eclipse,把android-formatting.xml ,android.importorder , .classpath拷贝到源码目录
Eclipse需要一个目录列表来搜索Java文件,称作"Java Build Path”,保存在.classpath文件中
2、 chmod +x .classpath 赋予执行权限
3、导入development/ide/eclipse下的文件(android-formatting.xml ,android.importorder后面有步骤),让Eclipse遵从Android的编码风格:
在eclipse工程菜单 window-->preferences-->java-->Code Style-->Formatter 导入android- formatting.xml文件,organize imports导入android.importorder文件
4、 新建一个java工程,导入android源码
必须注意两点:
1)、新建的工程必须是java project,不能是android project,否则会破坏android源码(一般是多添加文件/文件夹)。
2)、导入前最好检查.classpath里的文件在android源码中是否有相应的文件(文件夹),否则也会破坏android源码(一般是多添加文件/文件夹)。
出现的问题:
Project 'gingerbread' is missing required library: 'out/target/common/obj/JAVA_LIBRARIES/google-common_intermediates/javalib.jar'
Project 'gingerbread' is missing required library: 'out/target/common/obj/JAVA_LIBRARIES/gsf-client_intermediates/javalib.jar'
解决:删除.classpath中的这两行路径
<classpathentry kind="lib" path="out/target/common/obj/JAVA_LIBRARIES/google-common_intermediates/javalib.jar"/>
<classpathentry kind="lib" path="out/target/common/obj/JAVA_LIBRARIES/gsf-client_intermediates/javalib.jar"/>
添加:网上的其他解决方案只添加一个包,还是报错,这里应该添加3个。
<classpathentry kind="lib" path="out/target/common/obj/JAVA_LIBRARIES/android-common_intermediates/javalib.jar"/>
<classpathentry kind="lib" path="out/target/common/obj/JAVA_LIBRARIES/filterfw_intermediates/classes-jarjar.jar"/>
<classpathentry kind="lib" path="out/target/common/obj/JAVA_LIBRARIES/android-support-v13_intermediates/classes-jarjar.jar"/>
5、 Android工程很大,在编译时可能造成Eclipse的Java虚拟机内存耗光。我们可以通过修改eclipse.ini避免这一问题,在ubuntu下,eclipse.ini位于adt-bundle-linux-x86_64-20131030/eclipse,eclipse目录下的eclipse.ini文件,修改-Xms,-Xmx为128和512
-Xms128m
-Xmx512m
二、调试android源码
1. 退出Eclipse工程
2. 在android源码目录执行 . build/envsetup.sh(点后有空格)
3. 初始化环境变量lunch 1
3. 启动模拟器 emulator 出现模拟器运行界面
4. 等模拟器启动成功后,启动ddms ddms & 命令是‘ddms &’ 出现ddms
出现问题:开启ddms后,swt报错
16:23 D/ddms: Initializing
16:23 E/ddms: shutting down due to uncaught exception
16:23 E/ddms: java.lang.UnsatisfiedLinkError: Cannot load 32-bit SWT libraries on 64-bit JVM
at org.eclipse.swt.internal.Library.loadLibrary(Unknown Source)
at org.eclipse.swt.internal.Library.loadLibrary(Unknown Source)
at org.eclipse.swt.internal.C.<clinit>(Unknown Source)
at org.eclipse.swt.widgets.Display.createDisplay(Unknown Source)
at org.eclipse.swt.widgets.Display.create(Unknown Source)
at org.eclipse.swt.graphics.Device.<init>(Unknown Source)
at org.eclipse.swt.widgets.Display.<init>(Unknown Source)
at org.eclipse.swt.widgets.Display.<init>(Unknown Source)
at com.android.ddms.UIThread.runUI(UIThread.java:330)
at com.android.ddms.Main.main(Main.java:97)
解决:设置好64位swt.jar目录,可以从网上下载,或者sdk中的tools/lib/x86_64目录,或者编译后源代码的prebuilt/linux-x86_64/swt目录
我用的是prebuilt/linux-x86_64/swt中的
export ANDROID_SWT=/root/prebuilt/linux-x86_64/swt
(可选)然后修改ddms等等scripts,我不理解,没做
例如 androidSDK/tools/android, change the last line from:
exec "$java_cmd" -Xmx256M $os_opts $java_debug -Djava.ext.dirs="$frameworkdir" -Dcom.android.sdkmanager.toolsdir="$progdir" -jar "$jarpath" "$@"
to:
exec "$java_cmd" -d32 -Xmx256M $os_opts $java_debug -Djava.ext.dirs="$frameworkdir" -Dcom.android.sdkmanager.toolsdir="$progdir" -jar "$jarpath" "$@"
5. 在ddms上选择你需要调试的进程(点击一个就行了,变色),一般如果是调试系统自带的应用
注意不能选择多个进程,否则端口会冲突。
6. 打开Eclipse工程,设置调试端口
选择你的工程总的,右键打开菜单选择 Debug AS—Debug configuration 弹出窗口,选择Remote JAVA Application,右键在菜单选择NEW,弹出下面的视图,修改Port为8700(这个值可变)
7.debug后在选择的进程上(DDMS界面中)如果出现了bug绿虫 ,则表示成功进入调试了。可参照8进行
8、比如:调试拨打电话的功能
在DDMS上选择com.android.phone这个进程
找到frameworks/base/telephoney/java目录下的com.android.internal.telephony包,然后找到RIL.java文件。
在函数 public void dial(String address, int clirMode, UUSInfo uusInfo, Message result)中设置断点
然后在模拟器(模仿手机拨电话)中拨打电话,便可以在设置的断点处停下,进行查看变量等操作。
可参照本文和http://blog.youkuaiyun.com/yjkwf/article/details/7162873完成。
在上一篇(源代码的编译)基础上,做如下的工作
一、搭建Eclipse源码工程
1、 进入源码目录下的development/ide/eclipse,把android-formatting.xml ,android.importorder , .classpath拷贝到源码目录
Eclipse需要一个目录列表来搜索Java文件,称作"Java Build Path”,保存在.classpath文件中
2、 chmod +x .classpath 赋予执行权限
3、导入development/ide/eclipse下的文件(android-formatting.xml ,android.importorder后面有步骤),让Eclipse遵从Android的编码风格:
在eclipse工程菜单 window-->preferences-->java-->Code Style-->Formatter 导入android- formatting.xml文件,organize imports导入android.importorder文件
4、 新建一个java工程,导入android源码
必须注意两点:
1)、新建的工程必须是java project,不能是android project,否则会破坏android源码(一般是多添加文件/文件夹)。
2)、导入前最好检查.classpath里的文件在android源码中是否有相应的文件(文件夹),否则也会破坏android源码(一般是多添加文件/文件夹)。
出现的问题:
Project 'gingerbread' is missing required library: 'out/target/common/obj/JAVA_LIBRARIES/google-common_intermediates/javalib.jar'
Project 'gingerbread' is missing required library: 'out/target/common/obj/JAVA_LIBRARIES/gsf-client_intermediates/javalib.jar'
解决:删除.classpath中的这两行路径
<classpathentry kind="lib" path="out/target/common/obj/JAVA_LIBRARIES/google-common_intermediates/javalib.jar"/>
<classpathentry kind="lib" path="out/target/common/obj/JAVA_LIBRARIES/gsf-client_intermediates/javalib.jar"/>
添加:网上的其他解决方案只添加一个包,还是报错,这里应该添加3个。
<classpathentry kind="lib" path="out/target/common/obj/JAVA_LIBRARIES/android-common_intermediates/javalib.jar"/>
<classpathentry kind="lib" path="out/target/common/obj/JAVA_LIBRARIES/filterfw_intermediates/classes-jarjar.jar"/>
<classpathentry kind="lib" path="out/target/common/obj/JAVA_LIBRARIES/android-support-v13_intermediates/classes-jarjar.jar"/>
5、 Android工程很大,在编译时可能造成Eclipse的Java虚拟机内存耗光。我们可以通过修改eclipse.ini避免这一问题,在ubuntu下,eclipse.ini位于adt-bundle-linux-x86_64-20131030/eclipse,eclipse目录下的eclipse.ini文件,修改-Xms,-Xmx为128和512
-Xms128m
-Xmx512m
二、调试android源码
1. 退出Eclipse工程
2. 在android源码目录执行 . build/envsetup.sh(点后有空格)
3. 初始化环境变量lunch 1
3. 启动模拟器 emulator 出现模拟器运行界面
4. 等模拟器启动成功后,启动ddms ddms & 命令是‘ddms &’ 出现ddms
出现问题:开启ddms后,swt报错
16:23 D/ddms: Initializing
16:23 E/ddms: shutting down due to uncaught exception
16:23 E/ddms: java.lang.UnsatisfiedLinkError: Cannot load 32-bit SWT libraries on 64-bit JVM
at org.eclipse.swt.internal.Library.loadLibrary(Unknown Source)
at org.eclipse.swt.internal.Library.loadLibrary(Unknown Source)
at org.eclipse.swt.internal.C.<clinit>(Unknown Source)
at org.eclipse.swt.widgets.Display.createDisplay(Unknown Source)
at org.eclipse.swt.widgets.Display.create(Unknown Source)
at org.eclipse.swt.graphics.Device.<init>(Unknown Source)
at org.eclipse.swt.widgets.Display.<init>(Unknown Source)
at org.eclipse.swt.widgets.Display.<init>(Unknown Source)
at com.android.ddms.UIThread.runUI(UIThread.java:330)
at com.android.ddms.Main.main(Main.java:97)
解决:设置好64位swt.jar目录,可以从网上下载,或者sdk中的tools/lib/x86_64目录,或者编译后源代码的prebuilt/linux-x86_64/swt目录
我用的是prebuilt/linux-x86_64/swt中的
export ANDROID_SWT=/root/prebuilt/linux-x86_64/swt
(可选)然后修改ddms等等scripts,我不理解,没做
例如 androidSDK/tools/android, change the last line from:
exec "$java_cmd" -Xmx256M $os_opts $java_debug -Djava.ext.dirs="$frameworkdir" -Dcom.android.sdkmanager.toolsdir="$progdir" -jar "$jarpath" "$@"
to:
exec "$java_cmd" -d32 -Xmx256M $os_opts $java_debug -Djava.ext.dirs="$frameworkdir" -Dcom.android.sdkmanager.toolsdir="$progdir" -jar "$jarpath" "$@"
5. 在ddms上选择你需要调试的进程(点击一个就行了,变色),一般如果是调试系统自带的应用
注意不能选择多个进程,否则端口会冲突。
6. 打开Eclipse工程,设置调试端口
选择你的工程总的,右键打开菜单选择 Debug AS—Debug configuration 弹出窗口,选择Remote JAVA Application,右键在菜单选择NEW,弹出下面的视图,修改Port为8700(这个值可变)
7.debug后在选择的进程上(DDMS界面中)如果出现了bug绿虫 ,则表示成功进入调试了。可参照8进行
8、比如:调试拨打电话的功能
在DDMS上选择com.android.phone这个进程
找到frameworks/base/telephoney/java目录下的com.android.internal.telephony包,然后找到RIL.java文件。
在函数 public void dial(String address, int clirMode, UUSInfo uusInfo, Message result)中设置断点
然后在模拟器(模仿手机拨电话)中拨打电话,便可以在设置的断点处停下,进行查看变量等操作。
可参照本文和http://blog.youkuaiyun.com/yjkwf/article/details/7162873完成。