注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

时间记录器

记录我的Linux、Android学习之路

 
 
 

日志

 
 

eclipse中android项目的编译过程分析 ZZ  

2012-05-25 14:47:38|  分类: Android |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |

http://www.cnblogs.com/trinea/archive/2012/03/19/2420105.html

本文主要对eclipse中android项目的编译过程进行分析

 

本文只做分析,关于加快eclipse下android项目编译速度请见下一篇博客

Ps:本文中编译过程输出都是以真机(htc g7)作为avd,项目名为AONE,测试项目名为AoneTestProject,api level为8。

 

1、查看eclipse下android项目的编译过程

选择Window > Preferences > Android > Build > Build output > Verbose. 在console窗口的显示类型(一个显示器样式的图标)选择android。

 

2、具体编译过程

2.1 如果一个项目未曾修改,第一次在真机运行(即直接Run)输出为

[2012-03-19 15:44:54 - AONE] ------------------------------ [2012-03-19 15:44:54 - AONE] Android Launch! [2012-03-19 15:44:54 - AONE] adb is running normally. [2012-03-19 15:44:54 - AONE] Performing com.trinea.sns.activity.AccountManageActivity activity launch [2012-03-19 15:44:54 - AONE] Automatic Target Mode: using device 'SH135PL00278' [2012-03-19 15:44:54 - AONE] Uploading AONE.apk onto device 'SH135PL00278' [2012-03-19 15:44:55 - AONE] Installing AONE.apk... [2012-03-19 15:45:06 - AONE] Success! [2012-03-19 15:45:06 - AONE] Starting activity com.trinea.sns.activity.AccountManageActivity on device SH135PL00278 [2012-03-19 15:45:07 - AONE] ActivityManager: Starting: Intent { act=android.intent.action.MAIN cat=[android.intent.category.LAUNCHER] cmp=com.trinea.sns.activity/.AccountManageActivity } 

从中可以看出install apk过程比较缓慢,但这一步优化的难度过高,而且只会第一次耗时较长优化的必要性不大,暂不作优化。

 

2.2 对于一般修改,build过程解析

修改一个java文件后保存(已勾选Build Automatically),build信息输出如下:

[2012-03-19 15:50:04 - AONE] Refreshing resource folders. [2012-03-19 15:50:04 - AONE] Starting incremental Pre Compiler: Checking resource changes. [2012-03-19 15:50:04 - AONE] Attribute minSdkVersion (3) is lower than the project target API level (8) [2012-03-19 15:50:04 - AONE] Nothing to pre compile! [2012-03-19 15:50:04 - AONE] Starting incremental Package build: Checking resource changes. [2012-03-19 15:50:04 - AONE] Dx ignored resource D:\Eclipse\google code\AONE\bin\.\.svn\text-base\resources.ap_.svn-base [2012-03-19 15:50:04 - AONE] Dx processing D:\Eclipse\google code\AONE\bin\.\com\trinea\sns\view\AccountView.class... …… [2012-03-19 15:50:19 - AONE] Using default debug key to sign package [2012-03-19 15:50:19 - AONE] Using keystore: C:\Users\Trinea\.android\debug.keystore [2012-03-19 15:50:19 - AONE] Packaging AONE.apk [2012-03-19 15:50:19 - AONE] D:\Eclipse\google code\AONE\bin\resources.ap_: [2012-03-19 15:50:19 - AONE] => res/drawable/aone.png …… [2012-03-19 15:50:19 - AONE] => res/layout/account_manage_list.xml …… [2012-03-19 15:50:19 - AONE] => AndroidManifest.xml [2012-03-19 15:50:19 - AONE] => resources.arsc [2012-03-19 15:50:19 - AONE] D:\Eclipse\google code\AONE\bin\classes.dex => classes.dex [2012-03-19 15:50:20 - AONE] D:\学习\Coding\Android\lib\signpost-commonshttp4-1.2.1.1.jar: …… [2012-03-19 15:50:20 - AONE] => javax/servlet/http/LocalStrings.properties …… [2012-03-19 15:50:20 - AONE] Build Success! [2012-03-19 15:50:21 - AONE] Refreshing resource folders. [2012-03-19 15:50:21 - AONE] Starting incremental Pre Compiler: Checking resource changes. [2012-03-19 15:50:21 - AONE] Attribute minSdkVersion (3) is lower than the project target API level (8) [2012-03-19 15:50:21 - AONE] Nothing to pre compile! [2012-03-19 15:50:21 - AoneTestProject] Starting incremental Package build: Checking resource changes. [2012-03-19 15:50:21 - AoneTestProject] Dx processing D:\Eclipse\google code\AoneTestProject\bin\.\com\trinea\sns\utilImpl\AutoGetDataCacheTest.class... …… [2012-03-19 15:50:29 - AoneTestProject] Using default debug key to sign package [2012-03-19 15:50:29 - AoneTestProject] Using keystore: C:\Users\Trinea\.android\debug.keystore [2012-03-19 15:50:29 - AoneTestProject] Packaging AoneTestProject.apk [2012-03-19 15:50:29 - AoneTestProject] D:\Eclipse\google code\AoneTestProject\bin\resources.ap_: …… [2012-03-19 15:50:29 - AoneTestProject] => resources.arsc [2012-03-19 15:50:29 - AoneTestProject] D:\Eclipse\google code\AoneTestProject\bin\classes.dex => classes.dex [2012-03-19 15:50:29 - AoneTestProject] D:\Eclipse\google code\qqTAndroidSdk\target\QqTAndroidSdk-1.0.0-jar-with-dependencies.jar: [2012-03-19 15:50:29 - AoneTestProject] => org/apache/log4j/lf5/config/defaultconfig.properties …… [2012-03-19 15:50:30 - AoneTestProject] => javax/servlet/http/LocalStrings.properties …… [2012-03-19 15:50:30 - AoneTestProject] D:\学习\Coding\Android\lib\trinea-sina-weibo.jar: …… [2012-03-19 15:50:30 - AoneTestProject] Build Success! [2012-03-19 15:50:30 - AoneTestProject] Refreshing resource folders. [2012-03-19 15:50:30 - AoneTestProject] Starting incremental Pre Compiler: Checking resource changes. [2012-03-19 15:50:30 - AoneTestProject] Nothing to pre compile! 

以上省略号表示与上一语句类似 

 

从上面我们可以发现

a. 源项目AONE和测试项目AoneTestProject会同时被编译

b. 源项目和测试项目的编译过程基本包括刷新资源文件、预编译、增量构建、dx class文件、对包进行签名、打包成apk文件

c. 其中dx class文件过程耗时最长,达到15秒左右。而dx过程不仅编译本项目class文件,同时会编译所有依赖包的class文件,所以会根据项目生成的class文件个数以及依赖个数而变。

 

由此可见对于优化的重点可以放在dx过程中,android adt提供的dx工具没有缓存上次dx信息,导致每次都需要重新dx所有class,性能表现实在差劲
  评论这张
 
阅读(1303)| 评论(0)
推荐 转载

历史上的今天

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2017