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

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

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

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

BennuCTech

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值