Android开发中遇到的深渊巨坑

作者: 彭普蓝 | 来源:发表于2018-03-05 16:41 被阅读696次

前言:Android生态一向不尽人意,我作为Android万千开发者中的不起眼的一个,在此记录我目前遇到过的深渊巨坑,此文长期更新。

OPPO手机(系统)无法后台弹窗、弹页面

通常后台弹窗的做法为:

Intent it = new Intent(context,activity.class);
it.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
startActivity(it);

这是很正常也很官方的调用方法,Android原生系统没有任何问题,但在OPPO手机(系统)上表现为后台无法弹出页面。具体原因可参考:http://bbs.coloros.com/thread-466208-1-1.html
解决方法:提示用户去开启自启动权限,或者在交互中添加通知栏的弹出通知(建议通过极光弹本地通知栏),用户可以点击通知栏跳转至相应的页面。


OPPO手机(系统)无法进入debug调试模式

通过数据线连接OPPO手机(系统),打开对应的开发者选项和USB调试,在IDE中调试手机时无法进入debug模式。有时表现为进入debug模式一小段时间后,系统强制弹出app安装成功界面打断debug模式。参考:http://bbs.coloros.com/thread-424228-1-1.html
解决办法:换手机开发,赶紧换。


系统更换语言、方向、分屏等导致app崩溃

用户在更换语言、方向、分屏等操作时,系统有可能会强制更新app的UI界面,从而引发空指针异常导致app崩溃。
解决办法:在AndroidManifast的Activity中声明在这些操作时不需要更新UI。

<activity
  android:name="xxxx"
  android:configChanges="orientation|keyboardHidden|smallestScreenSize|screenLayout|screenSize|locale|layoutDirection"
/>

锁屏状态弹页面“闪退”

要想实现在锁屏状态下弹界面并且点亮屏幕等操作,需要在Activity中设置属性:

WindowManager.LayoutParams.FLAG_SHOW_WHEN_LOCKED

点亮屏幕后,系统认为还在休眠状态,故将Activity Finish掉了。
解决办法:参考:http://blog.csdn.net/gaowenboms/article/details/8754916


荣耀部分手机(或部分系统版本)容易OOM

这是比较诡异的问题,我当时用了很多其他品牌的手机进行测试均为发现OOM,唯独在荣耀V10手机上容易OOM,经过不断的Google,终于找到了参考资料:
https://juejin.im/entry/59f7ea06f265da43143ffee4。原因竟然是荣耀部分机型上的线程数限制非常严苛。
解决办法:加入线程池控制app所有的线程执行,或者减少线程数。


后台保活复活对应的service抛出IllegalStateException

由于需求需要,app做了后台保活措施,但在Android O(或Android One)上表现为一直抛出IllegalStateException,导致app一直崩在后台(虽然用户不知道)。原因为Android8.0之后不再允许app在后台启动service。
解决办法:把工程中所有的service变成jobservice,并做好系统版本判断,针对不同的android版本做不同的保活措施。


OPPO手机(系统),有时app退至后台即被杀死

OPPO手机(系统)有后台冻结机制,有时对于小厂app不会留存任何后台,退至后台即被杀死,从而导致无法再为用户提供服务。
解决办法:手机中加入常见问题解决方法,指引用户给app留后台


加入重力感应后,可能导致部分手机频繁ANR

在部分手机上,重力感应监听会导致手机卡顿。
解决办法:尽量让app的方向跟随系统,用户没开重力感应开关时不去监听手机重力感应。


JobService的onStartJob()方法不会立即执行

android5.0之后Google官方推荐将所有的Service替换为JobService的方式去实现相应的需求,android8.0之后更是不再允许app在后台startService。所以,为了更好的适配,大部分开发者工程中都会加入JobService。但是执行JobService之后,onStartJob并不会立即执行,可能会等到10多分钟之后才执行。代码如下:

JobInfo.Builder builder - new JobInfo.Builder(ID,new ComponentName(context,xxxJobService.class));
builder.setPeriodic(3000);//每3s执行一次
builder.setPersisted(true);//设备重启时执行
builder.setRequiresCharging(true);//插入充电器时执行
JobInfo info = builder.build();
mJobScheduler.schedule(info);//以系统调度的方式执行

运行之后可以发现,JobService中的onStartJob方法不会立即执行,注意Logcat中的打印,有这么一句话:

W/JobInfo:Specified interval for 1 is + 2s0ms.Clamped to +15m0s0ms

也就是onStartJob至少会在15分钟之后才会执行。
解决办法:换种调用方法,代码如下:

builder.setPeriodic(3000)换成builder.setOverrideDeadline(2000),或者换成builder.setMinimumLatency()。
注意:两个方法不能同时使用!

AndroidStudio报方法过时等错误

我在创建解耦组件化工程的时候遇到的莫名其妙的问题,同样的代码和gradle配置在另一个工程上不会报任何错误,Google了两天,尝试了各种办法,都没有很好的解决。实际报错如下:


lint类型检查报错
lint过时方法报错

虽然都是警告,不影响打包,但是作为强迫症表示各种不适。尝试在gradle配置的android{ }中加入:

lintOptions {
        checkReleaseBuilds false
        abortOnError false
}
allprojects {
        gradle.projectsEvaluated {
                tasks.withType(JavaCompile) {
                        options.compilerArgs << "-Xlint:unchecked" << "-Xlint:deprecation"
                }
        }
}

依然没有得到解决。

相关文章

网友评论

    本文标题:Android开发中遇到的深渊巨坑

    本文链接:https://www.haomeiwen.com/subject/fvrhfftx.html