安卓Webview网页秒开策略探索

本文探讨了安卓Webview加载缓慢的常见问题,包括内核初始化、js臃肿、图片过多等,并详细介绍了优化策略,如预加载、复用池、独立进程和使用第三方框架(VasSonic、TBS腾讯浏览服务、百度方案、今日头条方案)。重点分析了这些框架的工作原理和优化效果,提出前后端协同优化网页以实现秒开的目标。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

痛点是什么?
网页加载缓慢,白屏,使用卡顿。
为何有这种问题?
1.调用loadUrl()方法的时候,才会开始网页加载流程
2.js臃肿问题
3.加载图片太多
4.webview本身问题
webiew是怎么加载网页的呢?
webview初始化->DOM下载→DOM解析→CSS请求+下载→CSS解析→渲染→绘制→合成
优化方向是?
1.webview本身优化

提前内核初始化
代码:

public class App extends Application {

private WebView mWebView ;
@Override
public void onCreate() {
    super.onCreate();
    mWebView = new WebView(new MutableContextWrapper(this));
}

}
复制代码效果:初次内核初始化大概2000ms,第二次50ms以内

webview复用池
代码:

public class WebPools {
private final Queue mWebViews;
private Object lock = new Object();
private static WebPools mWebPools = null;
private static final AtomicReference mAtomicReference = new AtomicReference<>();
private static final String TAG=WebPools.class.getSimpleName();

private WebPools() {
    mWebViews = new LinkedBlockingQueue<>();
}
public static WebPools getInstance() {
    for (; ; ) {
        if (mWebPools != null)
            return mWebPools;
        if (mAtomicReference.compareAndSet(null, new WebPools()))
            return mWebPools=mAtomicReference.get();
    }
}
public void recycle(WebView webView) {
    recycleInternal(webView);
}
public WebView acquireWebView(Activity activity) {
    return acquireWebViewInternal(activity);
}
private WebView acquireWebViewInternal(Activity activity) {
    WebView mWebView = mWebViews.poll();
    LogUtils.i(TAG,"acquireWebViewInternal  webview:"+mWebView);
    if (mWebView == null) {
        synchronized (lock) {
            return new WebView(new MutableContextWrapper(activity));
        }
    } else {
        MutableContextWrapper mMutableContextWrapper = (MutableContextWrapper) mWebView.getContext();
        mMutableContextWrapper.setBaseContext(activity);
        return mWebView;
    }
}
private void recycleInternal(WebView webView) {
    try {
        if (webView.getContext() instanceof MutableContextWrapper) {
            MutableContextWrapper mContext = (MutableContextWrapper) webView.getContext();
         mContext.setBaseContext(mContext.getApplicationContext());
            LogUtils.i(TAG,"enqueue  webview:"+webView);
            mWebViews.offer(webView);
        }
        if(webView.getContext() instanceof  Activity){
            //throw new RuntimeException("leaked");
            LogUtils.i(TAG,"Abandon this webview  , It will cause leak if enqueue !");
        }
    }catch (Exception e){
        e.printStackTrace();
    }
}

}
复制代码带来的问题:内存泄漏

独立进程,进程预加载
代码:

    <service
        android:name=".PreWebService"
        android:process=":web"/>
    <activity
        android:name=".WebActivity"
        android:process=":web"/>

复制代码启动webview页面前,先启动PreWebService把[web]进程创建了,当启动WebActi

方案是为解决特定问题或达成特定目标而制定的一系列计划或步骤。它的作用是提供一种系统性的方法,以有效地应对挑战、优化流程或实现目标。以下是方案的主要作用: 问题解决: 方案的核心目标是解决问题。通过系统性的规划和执行,方案能够分析问题的根本原因,提供可行的解决方案,并引导实施过程,确保问题得到合理解决。 目标达成: 方案通常与明确的目标相关联,它提供了一种达成这些目标的计划。无论是企业战略、项目管理还是个人发展,方案的制定都有助于明确目标并提供达成目标的路径。 资源优化: 方案在设计时考虑了可用资源,以最大化其效用。通过明智的资源分配,方案可以在有限的资源条件下实现最大的效益,提高效率并减少浪费。 风险管理: 方案通常会对潜在的风险进行评估,并制定相应的风险管理策略。这有助于减轻潜在问题的影响,提高方案的可行性和可持续性。 决策支持: 方案提供了决策者所需的信息和数据,以便做出明智的决策。这种数据驱动的方法有助于减少不确定性,提高决策的准确性。 团队协作: 复杂的问题通常需要多个人的协同努力。方案提供了一个共同的框架,帮助团队成员理解各自的职责和任务,促进协作并确保整个团队朝着共同的目标努力。 监控与评估: 方案通常包括监控和评估的机制,以确保实施的有效性。通过定期的评估,可以及时调整方案,以适应变化的环境或新的挑战。 总体而言,方案的作用在于提供一种有序、有计划的方法,以解决问题、实现目标,并在实施过程中最大化资源利用和风险管理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值