android p关于qickstep launcher anr分析

手机在开机后,有概率出现qickstep anr
通过main log,查找anr 发现;

07-03 14:53:10.395084  1557  1557 D ImsVT Util: onRecevied feature changed phoneId: 1, feature: 1, status: 0
07-03 14:53:10.395459  1557  1599 D ImsVT Util: switchFeatureInternal, feature = -16777216isOn = false
07-03 14:53:10.406055   966  2619 D AES     : ExceptionLog: notify aed, process:com.android.launcher3 pid:1646 cause:system_app_anr 
07-03 14:53:10.406098   966  2619 W AES     : skip for Exp level 0
07-03 14:53:10.451880  2311  2420 D RePlugin.ms-parser: 

pid 为:1646 ,cause:system_app_anr

分析events log
查找 pid 1646 发现

07-03 14:52:57.940124   966   983 I am_pss  : [1646,10008,com.android.launcher3,30533632,22552576,0,139821056,2,2,67]
07-03 14:52:58.028849   966   983 I am_pss  : [1552,10041,com.google.android.gms.persistent,97369088,54759424,0,242229248,2,4,74]
07-03 14:52:58.108234   966   983 I am_pss  : [1271,1000,com.android.settings,24253440,18759680,0,122155008,2,18,63]
07-03 14:52:58.201945   966   983 I am_pss  : [1530,1000,com.android.deskclock,14680064,10285056,0,104685568,2,18,63]
07-03 14:52:58.270552   966   983 I am_pss  : [1730,10018,com.google.android.dialer,23999488,13770752,0,93999104,2,18,60]
07-03 14:52:58.339146   966   983 I am_pss  : [2021,10025,com.google.android.partnersetup,6447104,3850240,0,82792448,2,14,60]
07-03 14:52:58.407313   966   983 I am_pss  : [1918,10041,com.google.process.gapps,7537664,3719168,0,90046464,2,14,61]
07-03 14:52:58.464204   966   983 I am_pss  : [1964,10061,com.android.chrome,16489472,7041024,0,80994304,2,18,55]
07-03 14:52:58.468691   966   984 I am_anr  : [0,1646,com.android.launcher3,885767749,executing service com.android.launcher3/com.android.quickstep.TouchInteractionService]
07-03 14:52:58.468000   315   315 I auditd  : type=1400 audit(0.0:253): avc: denied { write } for comm="aee_aed" name="tracing_on" dev="tracefs" ino=1070 scontext=u:r:aee_aed:s0 tcontext=u:object_r:debugfs_tracing:s0 tclass=file permissive=0
07-03 14:52:58.528901   966   983 I am_pss  : [1975,1000,com.android.keychain,5301248,2760704,0,80433152,2,18,58]
07-03 14:52:58.595113   966   983 I am_pss  : [1800,10085,com.android.smspush,5281792,2727936,0,80056320,2,5,60]
07-03 14:52:58.674423   966   983 I am_pss  : [1557,1001,com.mediatek.ims,19093504,13299712,0,118251520,2,0,66]
07-03 14:52:58.745133   966   983 I am_pss  : [1456,10014,com.google.android.ext.services,6716416,3387392,0,89808896,2,4,60]
07-03 14:52:58.809310   966   983 I am_pss  : [1700,1068,com.android.se,5518336,2953216,0,80834560,2,0,58]
07-03 14:52:58.933443   966   983 I am_pss  : [1695,1027,com.android.nfc,17113088,13012992,0,110776320,2,0,63]
07-03 14:52:59.011380   966   983 I am_pss  : [1676,10042,com.google.android.googlequicksearchbox:interactor,28567552,8327168,0,130703360,2,4,64]
07-03 14:52:59.682292   966   983 I am_pss  : [1259,1001,com.android.phone,37395456,30257152,0,144834560,2,0,87]
07-03 14:53:00.068361   966   983 I am_pss  : [1120,10015,com.android.systemui,74951680,60864512,0,190590976,2,0,90]
07-03 14:53:00.207046   966   983 I am_pss  : [1107,10084,com.google.android.inputmethod.latin,71525376,61792256,0,183468032,2,6,87]
07-03 14:53:00.392010   966   983 I am_pss  : [966,1000,system,126214144,108988416,0,269701120,2,0,126]
07-03 14:53:00.484223   966   983 I am_pss  : [1646,10008,com.android.launcher3,38275072,30007296,0,149057536,0,2,70]
07-03 14:53:00.531287   966   983 I service_manager_slow: [14,phone]

07-03 14:52:58.468691 966 984 I am_anr : [0,1646,com.android.launcher3,885767749,executing service com.android.launcher3/com.android.quickstep.TouchInteractionService]
发现TouchInteractionService 做成的anr

这个TouchInteractionService 是在systemui 里面启动的,主要是将recent view 移到launcher3里面
具体的启动类为OverviewProxyService.java

    private void internalConnectToCurrentUser() {
        disconnectFromLauncherService();

        // If user has not setup yet or already connected, do not try to connect
        if (!mDeviceProvisionedController.isCurrentUserSetup() || !isEnabled()) {
            Log.v(TAG_OPS, "Cannot attempt connection, is setup "
                + mDeviceProvisionedController.isCurrentUserSetup() + ", is enabled "
                + isEnabled());
            return;
        }
        mHandler.removeCallbacks(mConnectionRunnable);
        Intent launcherServiceIntent = new Intent(ACTION_QUICKSTEP)
                .setPackage(mRecentsComponentName.getPackageName());
        boolean bound = false;
        try {
            bound = mContext.bindServiceAsUser(launcherServiceIntent,
                    mOverviewServiceConnection, Context.BIND_AUTO_CREATE,
                    UserHandle.of(mDeviceProvisionedController.getCurrentUser()));
        } catch (SecurityException e) {
            Log.e(TAG_OPS, "Unable to bind because of security error", e);
        }
        if (bound) {
            // Ensure that connection has been established even if it thinks it is bound
            mHandler.postDelayed(mDeferredConnectionCallback, DEFERRED_CALLBACK_MILLIS);
        } else {
            // Retry after exponential backoff timeout
            final long timeoutMs = (long) Math.scalb(BACKOFF_MILLIS, mConnectionBackoffAttempts);
            mHandler.postDelayed(mConnectionRunnable, timeoutMs);
            mConnectionBackoffAttempts++;
            Log.w(TAG_OPS, "Failed to connect on attempt " + mConnectionBackoffAttempts
                    + " will try again in " + timeoutMs + "ms");
        }
    }
 try {
            bound = mContext.bindServiceAsUser(launcherServiceIntent,
                    mOverviewServiceConnection, Context.BIND_AUTO_CREATE,
                    UserHandle.of(mDeviceProvisionedController.getCurrentUser()));
        } catch (SecurityException e) {
            Log.e(TAG_OPS, "Unable to bind because of security error", e);
        }
        if (bound) {
            // Ensure that connection has been established even if it thinks it is bound
            mHandler.postDelayed(mDeferredConnectionCallback, DEFERRED_CALLBACK_MILLIS);
        } else {
            // Retry after exponential backoff timeout
            final long timeoutMs = (long) Math.scalb(BACKOFF_MILLIS, mConnectionBackoffAttempts);
            mHandler.postDelayed(mConnectionRunnable, timeoutMs);
            mConnectionBackoffAttempts++;
            Log.w(TAG_OPS, "Failed to connect on attempt " + mConnectionBackoffAttempts
                    + " will try again in " + timeoutMs + "ms");
        }
--------------------- 
作者:王大锤扛刀 
来源:CSDN 
原文:https://blog.csdn.net/wangjicong_215/article/details/94572944 
版权声明:本文为博主原创文章,转载请附上博文链接!

上面的code就是造成anr的原因。具体怎么解决,按项目需求了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
### 回答1: Android LauncherAndroid系统中的一个应用程序,它是用户与设备交互的主要界面。它提供了桌面、应用程序列表、小部件等功能,用户可以通过它来启动应用程序、查看通知、管理设备等。 Android Launcher的源码分析主要包括以下几个方面: 1. 桌面布局:Android Launcher的桌面布局是通过GridView实现的,它可以显示应用程序图标和小部件。在源码中,可以看到GridView的相关代码,包括布局、适配器等。 2. 应用程序列表:Android Launcher的应用程序列表是通过ListView实现的,它可以显示所有安装的应用程序。在源码中,可以看到ListView的相关代码,包括布局、适配器等。 3. 搜索功能:Android Launcher提供了搜索功能,用户可以通过输入关键字来搜索应用程序、联系人等。在源码中,可以看到搜索框的相关代码,包括布局、事件处理等。 4. 桌面小部件:Android Launcher支持桌面小部件,用户可以在桌面上添加各种小部件,如天气、时钟、日历等。在源码中,可以看到小部件的相关代码,包括布局、事件处理等。 5. 动画效果:Android Launcher提供了各种动画效果,如应用程序图标的放大缩小、桌面的滑动等。在源码中,可以看到动画效果的相关代码,包括属性动画、插值器等。 总之,Android Launcher的源码分析涉及到很多方面,需要深入研究才能掌握。 ### 回答2: Android launcher是一个重要的应用程序,它是用户的桌面界面,负责管理应用程序、小部件、壁纸等的展示和操作。在Android开发中,我们可以使用默认的系统Launcher也可以自定义Launcher,下面就来分析一下Android Launcher的源码。 1. Launcher的结构分析 Launcher的展示分为三个层次:桌面、工作区和屏幕。在源码中,它们分别对应着Launcher、Workspace和CellLayout。Launcher类是整个应用程序的外壳,它管理了整个应用程序的生命周期。Workspace管理着桌面上的工作区,它可以管理多个屏幕。而CellLayout则是每个工作区上的单元格容器,用于展示应用程序和小部件的图标。 2. Launcher的主界面 Launcher的主界面一般包括一个搜索栏、一个Dock栏和一个应用程序列表。其中搜索栏和Dock栏是Launcher的核心部分,它们的实现都是需要注意的: 2.1 搜索栏 Launcher的搜索栏是通过SearchView实现的,需要处理SearchView的监听事件和搜索逻辑。其中监听事件可以根据具体需求进行定制,比如支持模糊搜索、联想搜索等。 2.2 Dock栏 Dock栏是一个固定在桌面底部的横向图标栏,它可以管理常用的应用程序和快捷方式。Dock栏的实现需要考虑如下几个问题: - 图标的布局 - 图标的拖动 - 图标的排序 - 图标的管理 3. Workspace实现分析 Workspace是Launcher的核心部分,它基本实现了所有的界面交互逻辑。在Workspace上,用户可以添加、移动、删除应用程序和小部件。Workspace的实现需要考虑如下几个问题: 3.1 桌面上的应用程序和小部件布局 Workspace上的每个屏幕都是通过CellLayout实现的,它负责管理应用程序和小部件的布局和显示。 3.2 图标的拖动和排序 用户可以通过拖动来移动和排序图标,需要考虑如下几个问题: - 拖动的实现逻辑 - 滑动过程的动画效果 - 拖动时的图标缩放效果 3.3 图标的删除和添加 用户可以通过长按图标来触发删除操作,也可以通过添加菜单来添加新的应用程序和小部件。 4. 总结 以上是针对Android Launcher源码的分析,这些内容只是基础的使用方法和思路,具体的实现还需要根据自己的需求和场景进行定制和优化。在实现Launcher的时候,需要注意性能问题,尽量避免不必要的计算和操作;同时,还需要考虑到用户的交互体验,保证操作的流畅和直观。 ### 回答3: Android LauncherAndroid手机主屏幕上最常见的应用,它提供了一个桌面环境和一些关键功能,如快速访问应用程序、设置壁纸、小部件和通知中心等。本文将对Android Launcher源码进行分析,重点关注Launcher的核心组件:Workspace、Folder、App Drawer和Widget。 首先,Workspace是Launcher中最核心的组件之一,它是桌面上的容器,用于展示应用程序图标和小部件。Workspace是一个基于GridView组件自定义的ViewGroup,用于支持滑动手势和快捷方式的编辑管理。Framework层通过Workspace类读取和更新数据,它通过扩展Adapter来创建UI元素,并通过GridLayoutManager装填与交换元素。 其次,Folder是Launcher用于存储和管理应用程序快捷方式的组件。Folder的UI元素扩展自ViewGroup,可以包含多个应用快捷方式,在Folder中用户可以自由地添加、删除和排序快捷方式。Folder同时提供一个搜索框,用于帮助用户快速搜索自己的应用程序。 其次,App Drawer是Launcher的另一个核心组件,它是一个垂直滚动的列表,用于展示所有的应用程序。App Drawer是按字母排序的,同时可以通过搜索框查找用户需要的特定应用程序。App Drawer实现类似于Workspace,只不过它只横向的有一个方向轴且没有操作修改排序功能。 最后,Widget是一个独特的组件,它是一些非小部件的快捷方式,用户可以将它们放置在桌面上。Widget允许用户在主屏幕上快速访问特定功能或信息,例如天气、电子邮件和日历等。Widget UI元素的设计与Folder和App Drawer不同,它们提供更多信息和控制,通常需要桌面空间大才能放下。 总体而言,Android Launcher的源码分析需要涉及多个关键组件,Workspace、Folder、App Drawer和Widget是其中最重要的几个。这些组件深度整合在Launcher中,可以帮助用户快速访问他们需要的应用程序和信息。因此,熟练掌握这些核心组件的基本实现和逻辑是Android开发者不可或缺的技能之一。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值