美文网首页Android ClassAndroid进阶Android开发
Android Studio 3.0项目迁移所遇到的坑

Android Studio 3.0项目迁移所遇到的坑

作者: ThinkNuo | 来源:发表于2017-11-01 14:43 被阅读3881次

    最近 Android Studio 3.0 版本正式推出,趁着项目刚发完版本,赶紧更新试试水,结果发现项目完全跑不起来,折腾了几个小时才搞好。记录一下填坑过程,希望能帮助其他同学。

    1. gradle 和 buildToolsVersion 版本

    Android Studio 3.0 要求 gradle 版本为 4.1 ,对应的 buildToolsVersion 为 26.0.2 ,然后记得在项目最外层的 build.gradle 添加 google() ,如果不添加将会导致某些官方依赖下载不了。

    buildscript {
        repositories {
            ...
            google()
        }
    }
    

    2. module 依赖方式变更

    原先依赖 module 使用的是 compile ,现在需要替换为 apiimplementation
    api : module 编译时可用,module 的使用者编译和运行时可用,这个和过时的 compile 一样的。
    implementation : module 编译时可用,module 的使用者运行时可用,对于大量使用 library 的项目,可以显著提高编译时间,因为它可以减少构建系统重新编译一些 module 。
    那么什么时候用 api ,什么时候用 implementation 呢?由于公司项目采用的是组件化开发,有个 common module 需要被各个组件依赖,一开始采用的是 implementation ,结果发现会导致别的组件无法引用 common 中的库( common -> A module ,A module 无法引用 common 依赖的库 )。
    试验过后得出结论,当这个 module 会被多次引用应该使用 api,不会被别的 module 引用使用 implementation
    发一下我现在使用的方式

    dependencies {
        api fileTree(include: ['*.jar'], dir: 'libs')
        api 'com.squareup.okhttp3:okhttp:3.4.2'
        ...
        debugApi 'com.squareup.leakcanary:leakcanary-android:1.5.1'
        releaseApi 'com.squareup.leakcanary:leakcanary-android-no-op:1.5.1'
    }
    

    compileOnly 替换了 providedruntimeOnly 替换了 apk

    3. apt 插件更换

    apt 插件已被废弃,需更换为 annotationProcessor

    //apply plugin: 'android-apt'
    
    dependencies {
        ...
        annotationProcessor 'com.jakewharton:butterknife-compiler:8.5.1'
    }
    

    4.第三方库不兼容问题

    · retrolambda
    Android Studio 3.0 已经支持 Java 8 了,不需要第三方库来支持,因此需要去掉 retrolambda
    项目最外层的 build.gradle

    buildscript {
        ...
        dependencies {
            ...
            //classpath 'me.tatarka:gradle-retrolambda:3.2.5'
        }
    }
    

    module 中的 build.gradle

    //apply plugin: 'me.tatarka.retrolambda'
    
    android {
        ...
        compileOptions {
            sourceCompatibility JavaVersion.VERSION_1_8
            targetCompatibility JavaVersion.VERSION_1_8
        }
    }
    
    dependencies {
        ...
        //retrolambdaConfig 'net.orfjackal.retrolambda:retrolambda:2.3.0'
    }
    

    · butterknife
    butterknife 最新版本为 8.8.0,与 Android Studio 3.0 不兼容,会提示

    Caused by: java.lang.NoSuchMethodError: com.android.build.gradle.tasks.ProcessAndroidResources.getPackageForR()Ljava/lang/String;

    官方 issue 已经有人提过这个问题,貌似是 gradle 的问题。解决办法:版本降级到 8.5.1 即可解决
    · 项目中同一个第三库有多个版本导致编译失败
    不知道是不是 Android Studio 3.0 编译现在比以前严格了,以前有的库没有统一过版本,现在直接编译不过了。解决办法:统一第三方库的版本
    在 Terminal 中输入 gradle app:dependencies (gradle环境配置可以百度)

    ...
    +--- com.meituan.android.walle:library:1.1.5
    |    +--- com.android.support:support-annotations:24.1.1 -> 25.2.0
    |    \--- com.meituan.android.walle:payload_reader:1.1.5
    ...
    

    如果出现了 com.android.support:support-annotations:24.1.1 -> 25.2.0 代表该库中有自己依赖的库被升级了,需要去除这个依赖。

    dependencies {
        ...
        api('com.meituan.android.walle:library:1.1.5') {
            exclude(group: 'com.android.support', module: 'support-annotations')
        }
    }
    

    group: 前面的包名,: 后面的是 module 名字。
    如果依赖的是 jar 包,写法为 exclude(module: 'libs/xxx.jar')
    exclude(group: 'com.android.support') 是忽略所有 com.android.support 的module。

    另外 apk 的输出目录变了,多了一层目录结构 debug 。
    app/build/outputs/apk 变为 app/build/outputs/apk/debug,如果是用 Jenkins 打包项目拷贝文件的脚本需要修改下。

    相关文章

      网友评论

      • 童话镇里蜿蜒的河:厉害了,我的软
      • 冰冰的冻结:以前的项目无法预览CoordinatorLayout 布局,所有的material design 都不能预览,是不是必须升级最新的library 才可以呢
        ThinkNuo:@冰冰的冻结 studio是3.0,gradle是4.1
        冰冰的冻结:@ThinkNuo 你的gradle 版本是3.0 的吗,我昨天升级了gradle 及library的版本才可以预览,否则就不可以
        ThinkNuo:@冰冰的冻结 不应该啊,我自定义view都可以预览,你build一次就能预览了
      • 兰亦辛:请问有碰到 dagger 相关的异常么 类似无法生成 daggercomponent 之类的
        兰亦辛:@ThinkNuo 换了
        ThinkNuo:@兰亦辛 你注解apt换了没
        兰亦辛:* What went wrong:
        Execution failed for task ':order:compileDebugJavaWithJavac'.
        > java.lang.NoClassDefFoundError: dagger/Provides
      • Flipped199:老铁遇到过这个问题吗http://www.jianshu.com/p/77f61990c071
        ThinkNuo:@牛掰啊牛掰 之前是自适应的吗
        Flipped199: @ThinkNuo 普通的
        ThinkNuo:@牛掰啊牛掰 你这图片是.9还是普通的图片
      • 到了我的周末:我的在运行自己的项目的时候,出现
        Error:Execution failed for task ':app:compileDebugJavaWithJavac'。
        没有找到解决的办法。
        建立的新的项目没有这个问题。
        ThinkNuo:@到了我的周末 你点开 Gradle Console ,那里有详细的报错信息。你贴那个报错无法定位是什么错误
        到了我的周末:@ThinkNuo 这个就是报错的信息。:sob: 就这么点。在运行的时候提示。
        ThinkNuo:能贴下完整报错信息吗

      本文标题:Android Studio 3.0项目迁移所遇到的坑

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