"android:process"---由日志引发的大灾难!
2013-11-14 10:56
225 查看
本人菜鸟一枚,这几天在修改一个项目,昨天在一个问题上卡住了,直接卡了一天,后来问了问高手才知道是个小问题。
这是一个由android:process不同进程导致的大灾难!写下来警戒自己。
其中要由notification打开一个activity,但是总是一闪而过,而且activity中的打印信log一直没有(oncreate一开始就打印了),所有本能怀疑是activity没成功打开。研究notification的构建好长时间,觉得应该没问题。debug一下发现进activity了,遇到错误关闭了,但是log一直没有。正是因为没有log,我才没想到原来已经在acitivity里运行了。觉得这是个大问题,为啥没log呢,其他log都能打印出来。
仔细看了看logcat,发现了一点小问题,自己重新创建了一个过滤,这下能看清楚了。
可以看到有俩个不同的application标签,而运行程序自动显示的是带.action的过滤,所以下面的就不显示了,这样有些日志就隐藏了。。。。。
但这只是表面的问题,是什么原因导致这样的?包名是没有.action的,为啥会出现第一个标签?看了好久,上午查了也没有看到有用的信息,后来问一个高手,问题立解!
android:process!!!
在main.xml文件中,这个程序为一个receiver添加了android:process标签,内容就是包名+.action!!目的是开启一个不同的进程来运行下面的代码,这样application就不同了。当调用其他的activity时,由于那个acticvity没有这个标签,所以就是默认的进程,application就是包名。这样就导致了不同的日志!!
在网上查了查android:process有关信息,多学了一点东西。下面是引用网上的:
“
定义activity运行所在的进程名称。一般情况下,应用的所有组件都运行在为应用创建的默认的进程中,该默认进程的名称应用包名称一致。通过定义<application>元素的“process”属性可以为所有组件指定一个不同的默认进程。但是任意组件都可以重写默认进程,以便实现多进程操作。
如果该属性指定名称以“:”开头,则一个新的专属于该应用的进程将会被创建。如果该进程名以小写字母开头,则为该activity提供权限以让其在一个全局的进程中运行。这样会允许多个应用的不同组件共用一个进程,以便节省资源。
Android是支持多进程的,每个进程的内存使用限制一般为24MB的内存,所以当完成一些很耗费内存的操作如处理高分辨率图片时,需要单独开一个进程来执行该操作(上面的配置可以用来实现该操作)。即便如此,开发者还是不要随意多开进程来耗费用户的资源。(内存限制,有16MB,24MB,
32MB,很老的机型的内存限制会是16MB,这个具体还要再搜索下资料。。
”
这是一个由android:process不同进程导致的大灾难!写下来警戒自己。
其中要由notification打开一个activity,但是总是一闪而过,而且activity中的打印信log一直没有(oncreate一开始就打印了),所有本能怀疑是activity没成功打开。研究notification的构建好长时间,觉得应该没问题。debug一下发现进activity了,遇到错误关闭了,但是log一直没有。正是因为没有log,我才没想到原来已经在acitivity里运行了。觉得这是个大问题,为啥没log呢,其他log都能打印出来。
仔细看了看logcat,发现了一点小问题,自己重新创建了一个过滤,这下能看清楚了。
可以看到有俩个不同的application标签,而运行程序自动显示的是带.action的过滤,所以下面的就不显示了,这样有些日志就隐藏了。。。。。
但这只是表面的问题,是什么原因导致这样的?包名是没有.action的,为啥会出现第一个标签?看了好久,上午查了也没有看到有用的信息,后来问一个高手,问题立解!
android:process!!!
在main.xml文件中,这个程序为一个receiver添加了android:process标签,内容就是包名+.action!!目的是开启一个不同的进程来运行下面的代码,这样application就不同了。当调用其他的activity时,由于那个acticvity没有这个标签,所以就是默认的进程,application就是包名。这样就导致了不同的日志!!
在网上查了查android:process有关信息,多学了一点东西。下面是引用网上的:
“
定义activity运行所在的进程名称。一般情况下,应用的所有组件都运行在为应用创建的默认的进程中,该默认进程的名称应用包名称一致。通过定义<application>元素的“process”属性可以为所有组件指定一个不同的默认进程。但是任意组件都可以重写默认进程,以便实现多进程操作。
如果该属性指定名称以“:”开头,则一个新的专属于该应用的进程将会被创建。如果该进程名以小写字母开头,则为该activity提供权限以让其在一个全局的进程中运行。这样会允许多个应用的不同组件共用一个进程,以便节省资源。
Android是支持多进程的,每个进程的内存使用限制一般为24MB的内存,所以当完成一些很耗费内存的操作如处理高分辨率图片时,需要单独开一个进程来执行该操作(上面的配置可以用来实现该操作)。即便如此,开发者还是不要随意多开进程来耗费用户的资源。(内存限制,有16MB,24MB,
32MB,很老的机型的内存限制会是16MB,这个具体还要再搜索下资料。。
”
相关文章推荐
- <错误处理> Error:Execution failed for task ':app:dexDebug'. > com.android.ide.common.process.ProcessExc
- 2毛钱引发的"youni血案!!"
- android:process=":remote"属性解说
- 解开Android应用程序组件Activity的"singleTask"之谜
- <ListView android:id="@+id/android:list" 在 list 前加 android: 的原因
- "google play 已停止运行","com.google.process.gapps已停止运行"问题的解决办法
- Android使用"中国天气网"API数据通过城市名称获取天气情况
- C#开发日志[2013-12-5]创建Bitmap引发"参数无效"异常
- 解开Android应用程序组件Activity的"singleTask"之谜
- ubuntu 64 运行android sdk 发生错误 "../android-sdks/build-tools/aapt 文件不存在"
- android工程出现"The method * of type * must override a superclass method"的解决方法
- "Selenium for Android"的Robotium 二 概述
- 解开Android应用程序组件Activity的"singleTask"之谜
- android:process=":remote" .
- "Only the original thread that created a view hierarchy can touch its views"引发的思考_Handler的使用
- Linux权限引发的"血案"
- android:process=":remote"
- 由一本缺页的"书"引发出一系列思考
- Android应用程序组件Activity的"singleTask"
- 解开Android应用程序组件Activity的"singleTask"之谜