应用做的匆忙,很多地方只顾实现功能,没有兼顾好性能,所以停下来重构代码优化性能,结果在打log看启动时间的时候,发现
Application的onCreate执行了多次,这样导致重复初始化资源,初始化了3次导致接近1s时间。
发现这个是由独立进程引起的。即:process这个属性。
android:process
一般情况下一个服务没有自己独立的进程,它一般是作为一个线程运行于它所在的应用的进程中。但是也有例外,Android声明文件中的android:process属性却可以为任意组件包括应用指定进程,换句话说,通过在声明文件中设置android:process属性,我们可以让组件(例如Activity, Service等)和应用(Application)创建并运行于我们指定的进程中。
如果我们需要让一个服务在一个远端进程中运行(而不是标准的它所在的apk的进程中运行),我们可以在声明文件中这个服务的标签中通过android:process属性为其指定一个进程。
<service android:name="com.baidu.location.f" android:enabled="true" android:process=":baiduMap" > </service>
在DDMS中可以看到这个进程为
com.example.hello:baiduMap
(如果声明文件中的组件或者应用没有指定这个属性则默认应用和其组件将相应运行在以其包名命名的进程中)
解决方法如下:
@Override public void onCreate() { super.onCreate(); mApplication = this; long s1 = System.currentTimeMillis(); String processName = OsUtils.getProcessName(this, android.os.Process.myPid()); L.d(WModel.Time, "进程名称"+processName); if (processName != null) { boolean defaultProcess = processName .equals(WMapConstants.REAL_PACKAGE_NAME); if (defaultProcess) { //必要的初始化资源操作 } } L.d(WModel.Time, "onCreate耗时" + (System.currentTimeMillis() - s1)); }
/**
* @return null may be returned if the specified process not found
*/
public static String getProcessName(Context cxt, int pid) {
ActivityManager am = (ActivityManager) cxt.getSystemService(Context.ACTIVITY_SERVICE);
List<RunningAppProcessInfo> runningApps = am.getRunningAppProcesses();
if (runningApps == null) {
return null;
}
for (RunningAppProcessInfo procInfo : runningApps) {
if (procInfo.pid == pid) {
return procInfo.processName;
}
}
return null;
}