Android-studio与Android常见的Error问题与坑总结

Android-studio与Android常见的Error与坑总结

1 Error plugin
在某些情况下,比如你的android-studio没有关闭,然后你强制关机,当再次打开android-studio时,会出现这个问题

Plugin "Google Analytics Uploader" was not loaded: required plugin "Android Support" is disabled  
       Plugin "SDK Updater" was not loaded: required plugin "Android Support" is disabled.  
       Plugin "Android NDK Support" was not loaded: required plugin "Android Support" is disabled.  
       Plugin "Google App Indexing" was not loaded: required plugin "Android Support" is disabled.  
       Plugin "Google Cloud Tools For Android Studio" was not loaded: required plugin "Android Support" is disabled.  
       Plugin "Google Cloud Testing" was not loaded: required plugin "Android Support" is disabled  
       Plugin "Google Services" was not loaded: required plugin "Android Support" is disabled.  

解决方法:
点击File下面的Settings(快捷键 alt+ctrl+s)
找到plugin 发现有一些插件为红色
点击这些红色插件的后面的勾勾
再重启 就OK了


2 Write access is allowed from event dispatch thread only

解决方式:
File->project structure->Android sdk -> embedded
给当前的android studio的jdk换个版本,使用android studio 自带的jre。JDK版本 和 sdk版本冲突。
仍点击不了运行按钮,则在右上角的锤子图标和运行图标之间的一个下拉三角形,选择app,则运行图标可点击了


3 Unsupported Modules Detected: Compilation is not supported for following modules
File->invalidate caches/Reset->invalidate and reset
重新运行就OK


4 XML文件打不开
也是
File->invalidate caches/Reset->invalidate and reset
清理一下caches


5 点不了install
看install什么,如果是要install API 则可以去SDK Manager中install相应的API版本


6文件不能删除 复制粘贴
右键磁盘 工具 检查 修复


7 Execution failed for task ‘:app:clean’. > Unable to delete directory
将app目录下的 build删除 然后重新clean rebuild


8 无法连接真机设备
(1)检查是否开启开发者模式->USB调试 并且为MTP模式
(2)检查是否是线的问题 有的线是只能充电不能传数据的
(3)检查是否是驱动没有安装的问题 可以下载 豌豆荚 或者360手机助手进行驱动安装
(4)若豌豆荚等软件能识别手机,但是Android studio还是不能运行,
出现:

adb.exe start-server' failed -- run manually if necessary (moments ago)

可能是 adb需要的端口被占用了 比如你通过豌豆荚或者 360手机助手去安装驱动,然后没有关闭这个程序,它占用了adb的端口
可以尝试关闭这个程序
若还是不行 则可以:

// 重启adb
adb kill-server
adb start-server

或者

adb nodaemon server  

找到端口名
再用

tasklist | findstr "xxxx"

找到这个端口的pid
再结束这个pid

taskkill /pid xxxx /f

再去Android studio 试试


9 design 界面显示不了
1 重启AndroidStudio(所有都要关了)
2 或者是 引入了错误的布局或者控件


10 android studio Received status code 403 from server: Forbidden
android studio 使用的http代理未被所访问的网址授权
换一个代理


11 apk装不上
It is possible that this issue is resolved by uninstalling an existing version of the apk if it is present, and then re-installing

1 存在重复包名的apk 把他卸载掉 可能删了图标但是并没有删除,去文件管理中查看对应包名删除

2 根据以下路径,找到Instant Run中的选项
File —— Settings——Build,Execution,Deployment——Instant Run
将Enable Instant Run to hot swap code/resource changes on deploy(default enabled)的选择框取消。

3 手机运存不足

4 用了系统权限 如manifest中声明了 sharedId
但是没有Root或者该APK没有受到该设备的签名认证
解决:删掉系统权限 或者签名apk

5 若使用的是小米手机 得去开发者中心关闭MIUI 优化

6 clean project rebuild project

7 打开USB安装和允许USB调试以及 通过USB验证应用 开关

12 devices support but apk only support arm-v7a
手机没有打开usb调试 或者没有同意允许调试

13 logcat找不到应用
解决:重新插拔USB线

14 关闭代理模式
1 在Preference->Http proxy中 选择 No proxy
2 在gradle.properties中 将带有SystemProp.http.xx字样的删除即可

logger只打印部分内容
android 的logger单条打印是有上限长度的
大概为1000个字符以下

15 run-as “包名” is unknown
不能在android device explorer看到data/data/包名 或者执行 adb shell run-as 命令
原因:
1 该apk是系统apk 得要root权限才能查看
解决: 先获取root权限 执行"su"命令
16 报错 run-as “包名” is undebuggable
该apk 设置了android:debuggable="false" 不允许debug

17 Error:Project ‘app’ not found in root project ‘ProjectName’
setting.gradle未include ‘app’ 的module


Android常见Error总结

对于一些异常crash 看堆栈 看日志 还是找不到原因 可以基于堆栈、基于日志看下是不是有些特殊异常的操作


1 android.content.res.Resources$NotFoundException
setText只能为String 类型的 而你这里的是int类型


2 Error:(501, 1) 错误: 非法字符: ‘\u0000’
方案1:用Notepad++打开 art+m 或者 点击菜单栏的格式选项 选择 无BOM编码

方案2:在那个文件下把他修改成其他编码然后在修改回UTF-8就应该没问题了 比如我出现在VideoFrament.java 这里 我用的是as 右下角有个修改编码的东西 按照前面说得操作 类似刷新一下编码的意思吧 反正我Build没用 硬是要这样

方案3:如果还是存在 就ctrl+a ctrl+x ctrl+s ctrl+v 这样 让系统再次读下代码


3 Error:null value in entry: outputDirectory=null
删除项目根目录的.gradle文件夹,然后Clean ,Rebulid


4 app:transformClassesWithDexForDebug 错误

1 包重复冲突 检查 build.gradle 以及 lib 或者 external libraries 是否导入了相同的lib库
或者 是 库内存在相同的包

可以查看报错位置 能找的到重复的包就去删掉 找不到可以通过exclude 去声明

2 版本冲突
如support 包 和一些 外置的 包 有版本冲突

如改 support 的版本 27.1.1 为 26.1.0


5 Error:Could not resolve all dependencies for configuration ‘:app:debugAndroidTestRuntimeClasspath’.
Could not determine artifacts for com.android.support.test🏃1.0.1: Skipped due to earlier error
gradle的问题 更换gradle(如不使用google的而是某个镜像,公司内部的gradle)


6 error: :attr>.
Message{kind=ERROR, text=error: :attr>., sources=[C:\Users\maxshwu.gradle\caches\transforms-1\files-1

其中的一种可能是自定义View时

<declare-styleable 

写成了

<style

或者

 <attr name="outerMostArcWidth" format="dimension" />

没有写 format

总之就是你的自定义View的style.xml部分写错


7 无法删除文件
1 解除 classpath引用
2 解除 dependenties (compile)implement引用
3 invalidate cache
4 clean project
5 重启电脑 在文件夹删除(不打开as)


8 classpath引入包或者 dependenties (compile)implement引用库失败
1 可能存在空的文件夹,导致认为该包已经存在 先删掉 删不掉参考第7点


9 SDK location not found. Define location with sdk.dir in the local.properties file or with an ANDROID_HOME environment variable.
1 导入的jar包 未在setting.gradle引用
2 local.properties 的sdk路径未配置正确
3 ANDROID_HOME 配置sdk路径


10 Failed to find Platform SDK with path: platforms;android-23
没有响应的sdk 23版本 去下载对应版本即可


11 androidstudio 更新不了sdk 连不上网
1 检查网络状态
2 检查代理 更换可用的代理 或者镜像
3 手动下载


**12 **
setText 不能是int类型的,虽然编译器没报错 但是去setText的时候是会出错的


**13 **
for (xx:yy)
这里的yy不能为空 一定注意!!! 加判空操作


**14 **
arrayList.get(number) 这里的数值要加判断 if(number <= xxList.size -1) 避免下标越界


15 注意: android studio对于 java python等在环境变量中配置修改 需要重启一下as


16 split注意的点

split()方法 用于根据指定的符号对字符串进行分割 生成 一个数组String[]
1 xx.split() 要记得对xx作非空判断 而他是不会提示的
2 “.”和“|”都是转义字符,必须得加"\\"
3 
String  ips = "12.12.12.12;15.15.15.15;";
	ips = "12.12.12.12;15.15.15.15";
	ips = "12.12.12.12;15.15.15.15;;;";
    	String [] ipList = ips.split(";");
    	System.out.print(ipList.length);
返回的是都是2
	ips = "12.12.12.12;15.15.15.15;;13.13.13.13;";
返回的是4 (即 不是看有几个分号  而是若分号后无数据了 则截断 有数据 中间的分号是空的 则存""(非null的值))
	ips = "12.12.12.12";(即没有匹配 返回的是整个字符串作为数组的第0位)
返回的是1

**17 **

Execution failed for task ':Launcher4SkyWorth:lint'.
 Lint found errors in the project; aborting build.

解决:
1 将相关 的 错误或者警告解决
2 忽略警告

android {
        lintOptions {
            abortOnError false
      }
  }
  

18 Failed to resolve: javax.annotation:javax.annotation-api:1.2
1 若不需要Junit相关的 则删掉 相关compile即可

testCompile 'junit:junit:x.xx'

2 若需要,则

android{
    repositories {
    jcenter()
    maven { url "https://www.jitpack.io" }
    mavenCentral()
}

19 Failed to find Build Tools revision 26.0.2
原因:无法安装 Build Tools26.0.2
解决:
1 点击错误提示处下方的Install进行安装
2 若安装失败,则在SDK Manager中->Android SDK->SDK Tools->右下角勾选 show Package Details->在 Android SDK Build-Tools一栏中选中 26.0.2进行安装
3 可能是代理问题 更换代理即可

Caused by: org.gradle.api.internal.tasks.compile.CompilationFailedException: Compilation failed; see the compiler error output for details.
解决:
点击Build栏左侧的Toggle View 即可查看详细的错误信息

20 无法引用jar包
1 确定jar路径是否正确 项目中是否存在
2 若路径正确 则尝试清除各种缓存 clean project invalidate cache等
3 路径问题 文件夹命名中有/符号(mac系统中发现)
4 重启 as 重启电脑
5 查看各种版本 与能够运行的同学保持一致版本 如gradle jar包 sdk等

21 Caused by: java.util.concurrent.ExecutionException: com.android.tools.aapt2.Aapt2Exception

22 Unresolve Reference:xxx
原因
找不到layout下对应的id
解决
若点击该属性 不能跳转 则检查id是否存在
若能跳转 但是跳转的layout不对 则改个名字 若同名 则关联好相关的layout
1 如可能是使用了kotlin的语法糖 将下面这个改成你的layout
import kotlinx.android.synthetic.main.你的layout.*
2 可能是import导入的"R"错误
检查这个R是否是对应的包下的R文件
3 关闭as 将project的/build app module的/build目录删掉
再打开as clean project rebuild poroject

23 AGPBI: {“kind”:“error”,“text”:“error: expected reference but got (raw string) #000000.”,“sources”:[{“file”:“/Users/xx/project/app/Android/src/app/xx/build/intermediates/packaged_res/debug/values/values.xml”}],“original”:“”,“tool”:“AAPT”}
原因:找不到某个资源
解决: 可能是
1.资源名字写错 找不到这个资源
2.<item name="android:windowBackground">@color/colorBlack</item>
android:windowBackground不能使用#xxxx的方式 而是要用@color的方式

24 NoClassDefFoundError: Failed resolution of: Lkotlin/jvm/internal/Intrinsics
kotlin没有在project的.gradle中添加到classPath 或者 module的build.gradle没有添加

implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk7:$kotlinVersion"

25 java.lang.RuntimeException: Could not read input channel file descriptors from parcel.
在报错的下面可以看到 Too many open files 这个错误
**原因:**单个进程能够打开的最大文件句柄数量(fd)是可以配置的,系统默认是 1024。当单个进程打开的文件句柄数量超过了系统定义的值,
就会出现“Too many files open”的错误提示
解决: 查看代码中有哪些资源没有关闭,如文件,图片,如HandlerThread 如播放器

查看系统允许每个进程持有的fd上限

adb shell  ulimit -a

OR

adb shell /proc/<进程名>/limits

查看该进程持有的fd数

lsof | grep <进程名> | wc -l 

26 import kotlinx.android.synthetic.main.activity_webview.*
原因: kotlin的语法糖发现 unresolve activity_webview
可能是这个文件和activity_webview 不在一个module中 语法糖生成不了
解决: 还是得用回findViewById

27 art虚拟机报的错

Rejecting re-init on previously-failed class java.lang.Class<androidx.core.view.ViewCompat$2>: 
java.lang.NoClassDefFoundError: Failed resolution of: Landroid/view/View$OnUnhandledKeyEventListener

原因:
1 API低于代码的API
2 appcompat版本和android build tool版本不一致
3 有的会报错 但是不影响使用

28 arm64-v8a/android_gradle_build.json (No such file or directory)
1 clean project
2 rebuild project

29 Caused by: java.lang.IllegalStateException: Only fullscreen opaque activities can request orientation
原因: 8.0以上,不允许透明的或者非全屏的Activity设置屏幕方向,屏幕方向应该由全屏的并且非透明的Activity来决定
解决:
1 将这个Activity设置为不透明的
2 不给这个Activity设置屏幕方向
3 针对8.0的系统,style中不设置windowIsTranslucent,而是通过代码反射的形式动态设置

30 aar的包 编译器看正常/不正常 但是编译不正常/正常
原因: 可能换了AAR AS编译器存在缓存没及时替换
解决: invalidate cache and restart

31 java.lang.NoSuchMethodError: No static method xxx
看下那个错误的函数和参数 是否有错 没错的话重新rebuild一下

32 java.lang.StackOverflowError: stack size 8MB
at android.view.ViewGroup.resetResolvedLayoutDirection(ViewGroup.java:6081)

如:自己对自己addView 导致循环引用

33 Build 失败 提示java End of file
原因 java环境没有被AS引用到
open ~/.bash_profile,添加

export JAVA_HOME="xxx/jdk-11.0.16.1.jdk/Contents/Home"
export PATH=$PATH:$JAVA_HOME/bin

然后 source ~/.bash_profile
如果安装了zshrc,需要在zshrc文件里,

source ~/.bash_profile

然后在AS的控制台看java -version是否能正确输出

34 build时 cannot load cache
可以试下rebuild 可能是有一些文件重复了

35 NoClassDefFoundError
明明库在 库里面的文件在 编译器能跳转索引,但是运行时却报错NoClassDefFoundError
解决: 降级库版本

xxx.xml: Error: is not annotated as @Input
解决: 主要就是xml布局写的有问题了

  • 8
    点赞
  • 38
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值