应用做的匆忙,很多地方只顾实现功能,没有兼顾好性能,所以停下来重构代码优化性能,结果在打log看启动时间的时候,发现
Application的onCreate执行了多次,这样导致重复初始化资源,初始化了3次导致接近1s时间。
发现这个是由独立进程引起的。即:process这个属性。
android:process
一般情况下一个服务没有自己独立的进程,它一般是作为一个线程运行于它所在的应用的进程中。但是也有例外,Android声明文件中的android:process属性却可以为任意组件包括应用指定进程,换句话说,通过在声明文件中设置android:process属性,我们可以让组件(例如Activity, Service等)和应用(Application)创建并运行于我们指定的进程中。
注意:这里选择”remote”这个名字是随意主观的,你能用其他名字来让这个服务在另外的进程中运行。冒号’:’这个前缀将把这个名字附加到你的包所运行的标准进程名字的后面作为新的进程名称。比如我这里有一个百度地图的服务,设置如下:
- <service
- android:name="com.baidu.location.f"
- android:enabled="true"
- android:process=":baiduMap" >
- </service>
- com.example.hello:baiduMap
解决方法如下:
- <span style="font-size:14px;">@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));
- }</span>
- /**
- * @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;
- }
这样一来只初始化一次,不会导致很长时间的浪费。
From : http://blog.youkuaiyun.com/jason0539