Android开发 常见异常和解决办法(一)


Android Studio是Android开发的理想工具,但是由于版本的更新和配置的差异,会出现很多问题,下面是以《第一行代码 第二版》为基础进行开发学习可能遇见的一些问题及其解决办法。

1.Android Studio 3.0及以上版本找不到Android Device Monitor:

解决办法:
(1)在Android Studio中打开终端,如下:
打开终端界面
(2)跳到SDK目录下的tools目录
跳到SDK目录下的tools
查看SDK的目录可以在设置中依次找到:File → Settings → Appearance & Behavior → System Settings → Android SDK
SDK路径查看
(3)执行monitor命令
执行monitor命令
即出现以下弹窗
Android Device Monitor
即可进行需要的操作。
在网上出现的解决此问题的方法一般是在CMD中解决,但是会出现问题,如
CMD问题
可能是由于在Studio外部的命令行没有打开的权限,所以最好在Studio自带的命令行打开。

2.在Android Device Monitor无法打开文件读取权限

在第1部分中打开Android Device Monitor并点开File Explorer是不能读取文件的,如下:
Android Device Monitor界面
因为进行了权限设置,需要先打开权限,步骤如下:
(1)打开cmd
(2)在platform-tools路径下输入adb shell,回车(adb.exe位于SDK目录下的platform-tools文件夹下,如下图):
adb
(3)输入su,回车
(4)输入chmod 777 /data, 回车(该步骤设置data文件夹权限为777(drwxrwxrwx),也即administrators、power users和users组都有对该文件夹的读、写、运行权限)
(5)输入chmod 777 /data/data 回车(该步骤设置/data/data文件夹权限为777,依次类推)
此类方法是逐渐往下设置,很麻烦。
有一种更为简洁的方法,直接在platform-tools路径下输入adb root,即可获取所有文件夹权限。

打开权限后效果如图
打开访问权限
如需要导出数据,如图
导出数据
直接点击所框PULL按钮,可能会出现如下报错
报错
此时重新选择一下 Android Device Monitor 左侧面板的设备,即能解决。
解决办法
最后数据文件会被导入到你所指定的位置,如图
导出的文件

3.Androidstudio中添加jar包的方法

到网上下载你需要的jar包,下载下来后,将你Androidstudio中的项目视图切换为project,找到app下的libs,将你下载的jar包复制粘贴进去
复制文件
jar包复制进去后,选中你的jar包,比如我这里放了一个logback-classic-1.0.11的jar包进去,选中logback-classic-1.0.11,右键选择Add As Library,放进你的module中(要是有多个module,要注意自己要放进哪个module),然后加载同步下就可以了。
Add As Library
下图所示,说明jar包添加成功了。

验证

4.Android studio卡在waiting for target device to come online

首先要保证模拟器没有打开,接下来打开模拟器
打开模拟器
选择cold boot now,就可以发现模拟器已经启动,然后运行要运行的项目,就能正常显示了。
点击cold boot now
一定要保证模拟器没有启动的情况来这样使用,否则就会出现下面的情况:
异常提示

5.studio3以后的版本重写父类的方法出现androidx.annotation.NonNull包找不到的问题

这是androidX的问题:
AndroidX 是一个新的扩展库,用于向下兼容支持,在28稳定版库将所有的v4、v7后续功能将被整合到 androidx 包中,即从 API 28(Android 9.0,Pie)开始,Google 推荐开发者从原来的各种支持库转移到一个新版本的名为 AndroidX 的支持库。
解决办法:
(1)在gradle.properties文件里面添加如下代码

android.useAndroidX=true  #表示当前项目启用 androidx
android.enableJetifier=true   #表示将依赖包也迁移到androidx。如果取值为false,表示不迁移依赖包到androidx,但在使用依赖包中的内容时可能会出现问题,当然了,如果你的项目中没有使用任何三方依赖,那么,此项可以设置为false

(2)在module的gradle文件的dependencies 里面添加

dependencies { 
   implementation 'androidx.annotation:annotation:1.0.2'
}

重新同步编译即可。

6.Android Studio引用Module时报错:Unable to resolve dependency for ':app@debug/…

错误示意
造成上图错误的可能原因有

  1. Module模块的SdkVersion高于主项目的SdkVersion;
  2. Module模块被定义为application,而不是library。

解决办法:

  1. 对于第一种情况造成的错误,我们需要统一主模块和Module模块的SdkVersion,保持SdkVersion一致。
  2. 对于第二种情况造成的错误,我们需要把Module模块定义为library:
    (1)打开引用的模块的build.gradle文件:
    打开.gradle文件
    (2)修改application为library,同时删除applicationId:
    修改、删除

    7.Execution failed for task ‘:app:processDebugManifest’. Manifest merger failed with multiple errors, see logs

    在完成一个Project运行时,出现build failed的报错,就很迷茫,到底是哪里出问题了,错误提示一大堆:错误提示
    这时可点击左侧,用以显示具体运行情况和出错位置,点击
    出现如下所示界面
    界面
    还是很懵逼,此时,我们找到Android Studio菜单下的Build, 选择Clean Project,等Clean Project好了之后,我们再点击ReBuild Project。
    并且在项目build.gradle(app)中添加
    allprojects { gradle.projectsEvaluated { tasks.withType(JavaCompile) { options.compilerArgs << "-Xlint:unchecked" << "-Xlint:deprecation" } }}
    显示出详细错误位置,此时再运行即可查看错误出在什么地方,
    错误点
    大意是说,在app里的Manifast配置文件和ocr_ui中的Manifast配置文件的参数出现冲突,改成一致即可(这里的ocr_ui是和app同级的文件夹,用来实现特定UI效果)
    修改之后再运行,成功build,
    成功

8.Attempt to invoke virtual method ‘void android.widget.Button.setOnClickListener(android.view.View$OnClickListener)’ on a null object reference

是在点击Button组件时出现的,详细错误如下,

java.lang.RuntimeException: Unable to start activity ComponentInfo{xxx.OCRActivity}: java.lang.NullPointerException: Attempt to invoke virtual method 'void android.widget.Button.setOnClickListener(android.view.View$OnClickListener)' on a null object reference
...
Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'void android.widget.Button.setOnClickListener(android.view.View$OnClickListener)' on a null object reference
...

意思大概是说调用了一个空对象的不存在的方法,但是我的Button明明是存在的啊,为什么会这样呢?
原来是因为在Project中有多个活动,一个MainActivity和其他活动,我这个Button是在其他活动,这里是在OCRActivity中调用的,每个活动都有一个对应的.xml文件,来对里面的组建进行布局,所以每个活动都必须用setContentView()方法设置自己对应的布局,但是由于疏忽,把OCRActivity活动的对应布局文件也设成了activity_main,所以导致在生成OCRActivity的时候在activity_main.xml中找不到Button对应的布局,才会报错,在setContentView()方法中的参数改为activity_ocr即可正常运行。
正常运行
如图,出现这样的提示信息即表明在活动间正常切换了,对APP的操作也可正常进行,如此便可以在不同活动中随意切换了。
这个小异常也告诉我们在Android开发的时候要兼顾各方面,从活动到布局,再到配置,包括外部包的引入都要统一、匹配,各个活动、组件、之间的调用,以及与系统的交互等等,都要格外细心,甚至代码有时错一个字母、大小写不服,都会导致很大的问题,所以一定要谨慎、谨慎、再谨慎,细心、细心、再细心!!!

9.解决android.os.NetworkOnMainThreadException

在Android开发时,因为代码没有问题但总是报错。最后查阅资料了解到,在Android 4.0以上,网络连接不能放在主线程上,不然就会报错android.os.NetworkOnMainThreadException。但是4.0下版本不会报错。
官方解释为
官方解释
在Android4.0以后,会发现,只要是写在主线程(就是Activity)中的HTTP请求,运行时都会报错,这是因为Android在4.0以后为了防止应用的ANR(Aplication Not Response)异常,Android这个设计是为了防止网络请求时间过长而导致界面假死的情况发生。
解决此问题有两种方法:

(1)可以在Activity的onCreate()方法中加入一段代码,适用于网络请求数据量很小的情况,如下

if (android.os.Build.VERSION.SDK_INT > 9) {
    StrictMode.ThreadPolicy policy = new StrictMode.ThreadPolicy.Builder().permitAll().build();
    StrictMode.setThreadPolicy(policy);
}

(2)启动一条子线程进行你的网络请求(推荐使用)

// Android 4.0 之后不能在主线程中请求HTTP请求
new Thread(new Runnable(){
    @Override
    public void run() {
        cachedImage = asyncImageLoader.loadDrawable(imageUrl, position);
        imageView.setImageDrawable(cachedImage);
    }
}).start();

10.Android stdio 引用so错误问题:Could not get unknown property ‘jniLibs’ for source set ‘main’ of type

在Android studio 中为了让目录结构中显示出libs对应的目录结构如下:
目录结构
需要在模块对应的build.gradle 文件中添加如下配置:

sourceSets{
    main{
        jniLibs.srcDirs = ['libs']
    }
}

但是,添加完成后依然报错:

Could not get unknown property 'jniLibs' for source set 'main' of type org.gradle.api.internal.tasks.DefaultSourceSet.

原因可能是这个配置放的位置不对,正确的方法如下图所示:
解决办法

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

东哥说AI

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值