"android:process"---由日志引发的大灾难!

来源:互联网 发布:windows一键还原密码 编辑:程序博客网 时间:2024/05/16 12:19

    本人菜鸟一枚,这几天在修改一个项目,昨天在一个问题上卡住了,直接卡了一天,后来问了问高手才知道是个小问题。

    这是一个由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,这个具体还要再搜索下资料。。

原创粉丝点击