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 导致循环引用