2

作为一名开发人员,在构建在 3G 连接的 Android webviewclient 上运行的应用程序(带有网页)时,我的经历非常糟糕。我的一些用户说有些页面需要 10 分钟才能加载。(我不知道他们是否因为沮丧而夸大其词。)就个人而言,我使用运行 Android 2.2 的 HTC Desire 并用我自己的手机测试了我的应用程序。事实上,即使对于使用本地存储的网页来发出 AJAX 请求的应用程序,它在 3G 上也非常慢。大多数时候,它只会超时并显示一个空白页面。当它在 WIFI 上时,它工作正常并且速度非常快。

我听很多人说Android 2.2 上的原生浏览器速度非常快。对我来说,我必须说原生浏览器应用程序在 3G 上也很慢。有时,谷歌移动主页甚至没有完成加载。我在新加坡,所以大多数地方的 3G 覆盖都应该没问题。

是导致问题的设备硬件吗?

4

1 回答 1

0

我不知道与 WebView 加载时间特别相关的设备特定性能问题。但是,您可能希望同时添加请求超时和网络连接更改侦听器。有关其他信息,您可以为请求计时并报告慢速请求的设备和连接信息。

handler = new Handler();
WebView webView = findViewById(R.id.webview);
webView.setWebViewClient(new WebViewClient() {
    final long WEBVIEW_REQUEST_TIMEOUT = ...;
    final long WEBVIEW_SLOW_REQUEST_THRESHOLD = ...;
    Runnable onRequestTimeout = null;
    @Override
    public void onPageStarted(WebView view, final String url, Bitmap favicon) {
        super.onPageStarted(view, url, favicon); // current impl is no op but be fwd compatible
        saveRequestStartTime();
        onRequestTimeout = new Runnable() {
            @Override
            public void run() {
                handleRequestComplete(url, WebViewClient.ERROR_TIMEOUT);
            }
        };
        handler.postDelayed(onRequestTimeout, WEBVIEW_REQUEST_TIMEOUT);
    }

    @Override
    public void onPageFinished(WebView view, String url) {
        super.onPageFinished(view, url); // current impl is no op but be fwd compatible
        handleRequestComplete(url, 0);   // Return 0 onSuccess. All WebViewClient defined errors < 0. 
    }

    @Override
    public void onReceivedError(WebView view, int errorCode, String description, String failingUrl) {
        super.onReceivedError(view, errorCode, description, failingUrl); // current impl is no op but be fwd compatible
        handleRequestComplete(failingUrl, errorCode);
    }

    private void handleRequestComplete(String url, int errorCode) {
        if (onRequestTimeout != null) {
            handler.removeCallbacks(onRequestTimeout);
        }
        onRequestTimeout = null;
        final long elapsedTime = getRequestElapsedTime();
        if (elapsedTime > WEBVIEW_SLOW_REQUEST_THRESHOLD) {
            reportSlowRequest(elapsedTime, url, errorCode);
        }
        clearRequestTime();
    }

    private void saveRequestStartTime() {...}
    private long getRequestElapsedTime() {...}
    private void clearRequestTime() {...}
    private void reportSlowRequest(long elapsedTime, String url, int errorCode) {...}
});
于 2013-12-16T07:36:40.277 回答