Android Studio升级到3.0后遇到的坑
这几天谷歌推出了as3.0的正式版,相信大家都进行更新了,然后对3.0的新特性也有过一些了解,最后磨刀霍霍开始宰杀,然鹅却一不小心就开始了排坑之路。
第一坑、必须升级gradle到4.0以上
相信这个大坑,一般使用as的人都会解决了,所以就不多说
第二坑、buildtoolsversion升级到26.0.0
其实这个不算坑,一般buildtoolsversion都会升级到最新的版本,直接更新就是了
第三坑、error:resource shrinker cannot be used for libraries.(可能只是个人遇到,这里提下)
第四坑、error:all flavors must now belong to a named flavor dimension. learn more at https://d.android.com/r/tools/flavordimensions-missing-error-message.html
以上两坑在这里一起解决,第三坑的原因是library中使用了混淆,并移除了无用的资源文件,英文的意思是“library中不要使用移除无用的资源文件字段”,所以解决办法就是把该library中的shrinkresources字段移除就可以了
第四坑的原因就是使用了productflavors分包,解决方法就是在build.gradle中的defaultconfig中添加一个flavordimensions "1"就可以了,后面的1一般是跟你的versioncode相同
第五坑、aapt2的坑
error:java.util.concurrent.executionexception: com.android.tools.aapt2.aapt2exception:
aapt2 error: check logs for details
一般跟aapt2相关的问题的解决方法就是:在gradle.properties中关闭appt2 编译,加上下面这行代码就好了:
android.enableaapt2=false
如果项目中没有gradle.properties文件的话,可以新建或者去别的项目中拷贝就可以了
这里讲一个小坑,可能有人的项目路径中包含汉字的文件夹,然后as会提示下图:
此时的解决方法:在gradle.properties文件中加入com.android.build.gradle.overridepathcheck=true即可
第六坑、升级as3.0之后,数据库操作的sql语句中的问号报红,虽然没错但作为处女座的程序员也不能让它报红,报红心里不舒服。
解决方案:把sql语句写在外面用字符串变量代替即可。
今天晚上更新了androidstudio,可是再用这个就发现一个编译问题:
error:java.util.concurrent.executionexception: com.android.tools.aapt2.aapt2exception: aapt2 error: check logs for details error:execution failed for task ':app:mergedebugresources'. > error: java.util.concurrent.executionexception: com.android.tools.aapt2.aapt2exception: aapt2 error: check logs for details
通过google,发现了解决办法:
在项目的gradle.properties中添加
android.enableaapt2=false
目前还没搞懂为什么,先留在这里吧
以上就是最近升级as3.0之后个人所遇到的问题!!
推荐阅读
-
Android Studio升级到3.0后遇到的坑
-
Android Studio 升级到3.0后输入法中文状态下无法选词的终极解决方案
-
详解升级Android Studio3.0时遇到的几个问题
-
Android studio 3.0上进行多渠道打包遇到的问题小结(超简洁版)
-
android studio 3.0 升级 项目遇到的问题及更改思路(问题小结)
-
Android Studio升级到3.0后遇到的坑
-
Android Studio 3.x版本 的输入法遇到的坑及解决方案
-
Android Studio 升级到3.0后输入法中文状态下无法选词的终极解决方案
-
升级到Android Studio3.0遇到的问题及解决方案
-
## @[Android studio通过jdbc连接mysql基本步骤 以及 遇到的坑“The last packet sent successfully to the server was 0 m