webview之独立进程

2018-11-22 21:13:28

为什么webview要独立进程


Webview的问题:


 


1、内存占用巨大


 


app内存占用大,被系统回收的概率就高,当每次把app切到后台再回到app时,可能每次app都会重启,最常见的是activity或fragment被回收了,导致fragment使用activity的数据时,出现NullPointerException。内存占用大,app越不稳定。运行性能差。webview加载页面后会占用更多的内存,从而导致app内存占用大,最终导致出现以上问题。


 


2、内存泄漏


 


本来Webview的内存占用就大,还内存泄漏,OOM是经常的了。


 


3、Webview崩溃率高


 


Android版本不同,采用了不同的内核,兼容性crash;不同版本实现不同,甚至URI不规范也会引起不同程度的问题。在同一个进程中,Webview崩溃,会导致整个app闪退,这个很不好。


 


webview单独进程会很好的解决上面的问题:


 


android对单个应用所使用的最大内存做了限制,早期一些版本可能是16m,也有32m,不同的设备有不同的大小,所以不同的手机出现的内存泄漏情况也不一样。但android对应用内存分配的限制是按进程来的,因为进程是作为资源分配的基本单位,所以,想要为一个应用增加内存,可以通过多进程实现。webview单进程的使用,就会使得主进程的内存没那么容易泄漏,同时也会减少,activity和fragment被回收的情况。


因为是不同的进程,webview进程出现作何崩溃都不会导致app闪退。webview崩溃的问题是非常多的(不然uc也不会招两千多人来做android优化了),对于小公司来说,没有财力也没有必要消耗这么多人力去为这些问题做支持,所以webview使用单进程最适合不过了。


进程间通信

跨进程通信的方式有很多:bundle、文件共享、messenger、aidl、contentprovider、socket;对于我们的应用(千聊),因为主进程跟webview没有实时的通信,也没有数据回调,所以我选择了使用bunde来打开webview和webview跳转原生activity,使用文件共享来获取用户信息和下发参数。


 


遇到的问题

1、MyApplication instance不能使用,为null


 


原因:在MyApplication做了非主进程return处理,导致instance没有初始化


解决方案:在需要context的地方,添加一个方法传递webview的context


2、ACache初始化失败


 


原因:cacheDir.getAbsoluteFile()异常….


解决方案:使用SharedPreferences保存数据。


3、获取本地文件的json后,不能转换成对象。


 


原因:在调用fromJson时异常,提示创建对象时失败


解决方案:使用JSONObject和JSONArray解析json数据

--------------------- 

作者:火鸡哥 

来源:CSDN 

原文:https://blog.csdn.net/u012587024/article/details/75575072 

版权声明:本文为博主原创文章,转载请附上博文链接!

  • 2017-01-19 00:45:56

    nodejs之process进程

    虽然node对操作系统做了很多抽象的工作,但是你还是可以直接和他交互,比如和系统中已经存在的进程进行交互,创建工作子进程。node是一个用于事件循环的线程,但是你可以在这个事件循环之外创建其他的进程(线程)参与工作。

  • 2017-01-19 01:05:32

    process对象

    process对象是Node的一个全局对象,提供当前Node进程的信息。它可以在脚本的任意位置使用,不必通过require命令加载。该对象部署了EventEmitter接口。

  • 2017-01-20 21:59:11

    WEBPACK DEV SERVER

    webpack-dev-server是一个小型的node.js Express服务器,它使用webpack-dev-middleware中间件来为通过webpack打包生成的资源文件提供Web服务。它还有一个通过Socket.IO连接着webpack-dev-server服务器的小型运行时程序。

  • 2017-01-21 10:32:29

    Vue-cli proxyTable 解决开发环境的跨域问题

    和后端联调时总是会面对恼人的跨域问题,最近基于Vue开发项目时也遇到了这个问题,两边各自想了一堆办法,查了一堆资料,加了一堆参数,最后还得我把自己的localhost映射成上线时将要使用的域名。

  • 2017-01-21 21:44:29

    详解 ESLint 规则,规范你的代码

    在很久之前就想通过工具来规范自己的代码风格,减少程序出错的概率,如果看过我的 一个前端程序猿的Sublime Text3的自我修养 ,这篇博客的朋友,肯定知道在当时我使用 SublimeLinter-jshint 插件来规范风格,但是实际上一直懒癌发作也没去看它的文档,使用着它默认的规则。不过现在是时候切换到 ESLint 了!

  • 2017-01-23 23:09:16

    使用 CSS3 实现超炫的 Loading(加载)动画效果

     SpinKit 是一套网页动画效果,包含8种基于 CSS3 实现的很炫的加载动画。借助 CSS3 Animation 的强大功能来创建平滑,易于定制的动画。SpinKit 的目标不是提供一个每个浏览器都兼容的解决方案,而是给现代浏览器提供更优的技术实现方案和更佳的使用体验。(为保证最佳的效果,请在 Chrome、Firefox 和 Safari 等现代浏览器中浏览)