运行android的程序,看到这个红色字体以为程序出错,想一探究竟。
[2015-05-30 10:23:32 - autoim] ActivityManager: Starting: Intent { act=android.intent.action.MAIN cat=[android.intent.category.LAUNCHER] cmp=com.example.autoim/.MainActivity }
[2015-05-30 10:23:32 - autoim] ActivityManager: Warning: Activity not started, its current task has been brought to the front
看资料后的个人理解:这是一种android,在不同硬件档次下(内存充足,cpu性能高)的一个机制。你本次要退出的程序,我在硬件ok下先将它缓存,
你下次启动(if program not changed)直接从缓存启动,这样速度就会快很多,而且不会重新运行activity。实现资源的重复利用。假如硬件比较差的情况下,
这个机制就会关闭activity。
资料如下:
我们在Android平台下,通过返回按钮,或者程序本身的退出操作,去结束一个进程的时候,实际上Android虚拟机未必会将这个进程真正的结束掉,在内存允许的情况下,这个程序会以缓存的形式存在Android虚拟机中。只有在内存不足的情况下时,Android系统会清理长时间不被激活的任务,以为其他程序提供内存。
Android这样做,是为了你下一次更加快速的启动这个程序。
所以,出现楼主这种情况,是在你的程序没有发生任何变化,并且内存足够的情况下,会将上一次执行的程序,从缓存Cached状态直接放置到任务栈的顶端,则你的程序又可以继续执行了。
消除警告解决办法:
退出虚拟机的程序从新运行一遍。