最近幾天完成了對公司項目從Eclipse到Studio的遷移,兩者的對比相信都用過的人會懂。簡單地列舉幾點:
- Studio看源碼更加方便,無論是Android的還是Moudel的;
- Studio下載插件更加方便,相信用過Eclipse的"Install New Software"的人都懂;
- Studio支持gradle、ant、maven更加徹底,而Eclipse還要去下載gradle插件;
- 官方支持Studio的發(fā)展,我剛開始準備移植的時候用的Studio還是1.5.1正式版,現(xiàn)在都出到2.2 Preview1了(順便吐槽下hotpatch確實快但是不夠穩(wěn)定啊);【手動笑哭】
- 便于解決65536問題,便于及時清除重復的、不需要的依賴和permission;
……
開始正題,我秉著“先解決最難的,簡單的就是小菜一碟”的原則,移植的是公司用到最多第三方組件的用戶端(使用maven編譯),共涉及百度地圖搜索定位模塊、支付寶支付、微信支付、銀聯(lián)支付、jpush、async-http、ksoap、leancloud的聊天組件(順便引入了一系列組件)、ormlite、universal-image-loader等。
大致實踐步驟:
- 新建項目
- 獲取到公司倉庫里的包并嘗試獲取Model
- 獲取其他jar包
- 調(diào)用數(shù)據(jù)獲取接口嘗試獲取數(shù)據(jù)
- 將項目代碼導入
- 將Moudel導入,我這里導入了leanchatlib
花式出錯:
1.UNEXPECTED TOP-LEVEL EXCEPTION:
com.Android.dx.cf.iface.ParseException: bad class file magic (cafebabe) or version
解決辦法
2.app:transformResourcesWithMergeJavaResForDebug
出現(xiàn)原因:主app和moudel中引用了相同的包 且兩個包中也包含相同的包
Error:Execution failed for task ':app:transformResourcesWithMergeJavaResForDebug'.
> com.android.build.api.transform.TransformException: com.android.builder.packaging.DuplicateFileException: Duplicate files copied in APK META-INF/maven/包名/proxy/pom.xml
File1: C:\Users\Kerchin\.gradle\caches\modules-2\files-2.1\包名\proxy\0.0.1-SNAPSHOT\b6ace00dfdbae1d6d37314fbf51efe562eaae301\proxy-0.0.1-SNAPSHOT.jar
File2: C:\Users\Kerchin\.gradle\caches\modules-2\files-2.1\包名\proxy\0.0.1-SNAPSHOT\b6ace00dfdbae1d6d37314fbf51efe562eaae301\proxy-0.0.1-SNAPSHOT.jar
最佳解決辦法:刪除主app中的compile,保留moudel中的,并兩邊的build.gradle中都添加如下代碼
packagingOptions {
exclude 'META-INF/maven/包名/proxy/pom.xml'
exclude 'META-INF/maven/包名/proxy/pom.properties'
exclude 'META-INF/maven/包名/util/pom.xml'
exclude 'META-INF/maven/包名/util/pom.properties'
exclude 'META-INF/DEPENDENCIES.txt'
exclude 'META-INF/LICENSE.txt'
exclude 'META-INF/NOTICE.txt'
exclude 'META-INF/NOTICE'
exclude 'META-INF/LICENSE'
exclude 'META-INF/DEPENDENCIES'
exclude 'META-INF/notice.txt'
exclude 'META-INF/license.txt'
exclude 'META-INF/dependencies.txt'
exclude 'META-INF/LGPL2.1'
}
3.Android Studio中的.so文件導入方法
- 一開始使用的是
在app/libs下放入所有需要的文件再在app/build.gradle的android{}中添加如下代碼
task nativeLibsToJar(type: Zip, description: "create a jar archive of the native libs") {
destinationDir file("$projectDir/libs")
baseName "Native_Libs2"
extension "jar"
from fileTree(dir: "libs", include: "**/*.so")
into "lib"
}
tasks.withType(JavaCompile) {
compileTask -> compileTask.dependsOn(nativeLibsToJar)
}
原理是將libs中的.so文件打包在Native_Libs2.jar中再一同放進app中
- 后來發(fā)現(xiàn)一種更直接的方式
在````app/src/main中新建名為jniLibs```的文件夾并放入即可
jniLibs目錄位置
4.com.android.dex.DexException: Multiple dex files define Landroid/support/annotation/AnimRes
leancloud的聊天模塊的verifyError
這個bug很奇怪,在Eclipse并不會出現(xiàn)
java.lang.NoClassDefFoundError: com.avos.avoscloud.PostHttpResponseHandler
W/System.err: at com.avos.avoscloud.PaasClient.createPostHandler(PaasClient.java:288)
W/System.err: at com.avos.avoscloud.PaasClient.postBatchSave(PaasClient.java:533)
W/System.err: at com.avos.avoscloud.AVObject.saveObjectToAVOSCloud(AVObject.java:1916)
W/System.err: at com.avos.avoscloud.AVObject._saveObject(AVObject.java:1875)
W/System.err: at com.avos.avoscloud.AVObject.saveObject(AVObject.java:1812)
W/System.err: at com.avos.avoscloud.AVObject.saveInBackground(AVObject.java:2266)
W/System.err: at com.avos.avoscloud.AVObject.saveInBackground(AVObject.java:2234)
W/System.err: at com.avos.avoscloud.PushService.onStartCommand(PushService.java:140)
W/System.err: at android.app.ActivityThread.handleServiceArgs(ActivityThread.java:2897)
W/System.err: at android.app.ActivityThread.access$2400(ActivityThread.java:139)
W/System.err: at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1378)
5.之前以apklib的形式導入的leanchatlib,studio不再支持
在 leanchatlib的build.gradle中將apply plugin: 'com.android.application'改成apply plugin: 'com.android.library'在app的build.gradle中將apk project(':leanchatlib')改為compile project(':leanchatlib')
6.Error:Execution failed for task ':app:processDebugManifest'
7.Android libpng error: Not a PNG file錯誤解決
8.Error:Execution failed for task ':ProjectName:mergeDebugResources'. > Crunching Cruncher some file failed, see logs
6..so的導入
尚未解決的一個問題
Error:warning: Ignoring InnerClasses attribute for an anonymous inner class
Error:(com.baidu.mapapi.map.m) that doesn't come with an
Error:associated EnclosingMethod attribute. This class was probably produced by a
Error:compiler that did not target the modern .class file format. The recommended
Error:solution is to recompile the class from source, using an up-to-date compiler
Error:and without specifying any "-target" type options. The consequence of ignoring
Error:this warning is that reflective operations on this class will incorrectly
Error:indicate that it is *not* an inner class.
共261個類似錯誤,涵蓋baidumap、unionpay、alipay、tencent的資源
而且由于是編譯時錯誤,導致編譯很卡,每次3分鐘以上T.T
