gpt4 book ai didi

java - Android 5.x ClassNotFoundException 在 6.0+ 上运行良好

转载 作者:IT老高 更新时间:2023-10-28 21:09:06 26 4
gpt4 key购买 nike

我已将项目的 minSdkVersion 从 19 更新到 21。这导致我无法运行应用程序的 5.0/5.1 设备出现问题。我在我的 Application 类上不断收到 ClassNotFoundException。完整的日志、应用程序类和 gradle 文件如下。如果我将我的项目恢复到 minSdkVersion 19,那么应用程序将在 4.4+ 上运行而没有问题。

我的尝试

  • 清理/重建

  • 更新和降级构建工具版本

  • 跨项目的所有支持库都具有相同的版本号

  • 将我的所有 list 类设为相对然后绝对

  • 更新了所有 SDK 和构建工具

日志

04-27 14:37:07.152 6278-6278/? E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.package.testapp, PID: 6278
java.lang.RuntimeException: Unable to instantiate application com.package.TestApplication: java.lang.ClassNotFoundException: Didn't find class "com.package.Application" on path: DexPathList[[zip file "/data/app/com.package.testapp-1/base.apk"],nativeLibraryDirectories=[/data/app/com.package.testapp-1/lib/x86_64, /vendor/lib64, /system/lib64]]
at android.app.LoadedApk.makeApplication(LoadedApk.java:563)
at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4526)
at android.app.ActivityThread.access$1500(ActivityThread.java:151)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1364)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:135)
at android.app.ActivityThread.main(ActivityThread.java:5254)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698)
Caused by: java.lang.ClassNotFoundException: Didn't find class "com.package.TestApplication" on path: DexPathList[[zip file "/data/app/com.package.testapp-1/base.apk"],nativeLibraryDirectories=[/data/app/com.package.testapp-1/lib/x86_64, /vendor/lib64, /system/lib64]]
at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56)
at java.lang.ClassLoader.loadClass(ClassLoader.java:511)
at java.lang.ClassLoader.loadClass(ClassLoader.java:469)
at android.app.Instrumentation.newApplication(Instrumentation.java:980)
at android.app.LoadedApk.makeApplication(LoadedApk.java:558)
at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4526) 
at android.app.ActivityThread.access$1500(ActivityThread.java:151) 
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1364) 
at android.os.Handler.dispatchMessage(Handler.java:102) 
at android.os.Looper.loop(Looper.java:135) 
at android.app.ActivityThread.main(ActivityThread.java:5254) 
at java.lang.reflect.Method.invoke(Native Method) 
at java.lang.reflect.Method.invoke(Method.java:372) 
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903) 
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698) 
Suppressed: java.lang.ClassNotFoundException: com.package.testapp.welcome.TestClaimApplication
at java.lang.Class.classForName(Native Method)
at java.lang.BootClassLoader.findClass(ClassLoader.java:781)
at java.lang.BootClassLoader.loadClass(ClassLoader.java:841)
at java.lang.ClassLoader.loadClass(ClassLoader.java:504)
... 13 more
Caused by: java.lang.NoClassDefFoundError: Class not found using the boot class loader; no stack available

Gradle

    buildscript {
repositories {
maven { url 'https://maven.fabric.io/public' }
}

dependencies {
classpath 'io.fabric.tools:gradle:1.+'
}
}

apply plugin: 'com.android.application'
apply plugin: 'io.fabric'

repositories {
maven { url 'https://maven.fabric.io/public' }
}

android {

compileSdkVersion 25
buildToolsVersion '25.0.3'

defaultConfig {
applicationId "com.package.testapp"
minSdkVersion 21
multiDexEnabled = true
targetSdkVersion 25
versionCode 2
versionName "0.7"
renderscriptTargetApi 18 // support mode not supported 21+
renderscriptSupportModeEnabled true
testInstrumentationRunner
"android.support.test.runner.AndroidJUnitRunner"
}
dexOptions {
javaMaxHeapSize "4g"
}
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
}
lintOptions {
checkReleaseBuilds false
abortOnError false
}

productFlavors {
companylocal
companymaven
}
}

dependencies {


def ext = rootProject.ext;

compile fileTree(include: ['*.jar'], dir: 'libs')
compile "com.android.support:appcompat-v7:${ext.supportLibraryVersion}"
compile "com.android.support:design:${ext.supportLibraryVersion}"
compile 'com.romandanylyk:pageindicatorview:0.0.9'
compile "com.jakewharton:butterknife:${ext.butterknifeLibraryVersion}"
annotationProcessor "com.jakewharton:butterknife-compiler:${ext.butterknifeLibraryVersion}"
compile "uk.co.chrisjenx:calligraphy:2.2.0"
compile 'com.android.support:multidex:1.0.1'
// Crashlytics Kit - for crash handling
compile('com.crashlytics.sdk.android:crashlytics:2.5.2@aar') {
transitive = true
}
androidTestCompile('com.android.support.test.espresso:espresso-core:2.2.2', {
exclude group: 'com.android.support', module: 'support-annotations'
})

testCompile 'junit:junit:4.12'
testCompile 'org.robolectric:robolectric:3.0'
testCompile "com.squareup.okhttp3:mockwebserver:${ext.okHttp3LibraryVersion}"
testCompile('com.squareup.assertj:assertj-android:1.1.1') {
exclude module: 'support-annotations'
}
}

应用程序

public class TestApplication extends Application {

Engine engine;

@Override
public void onCreate() {
super.onCreate();

String privateServerUrlLocal = getString(R.string.server_url);
ProfileLauncher profileLauncher = getProfileLauncher();
LoginLauncher loginLauncher = getLoginLauncher();

// Set up Crash Analytics
final CrashlyticsCore crashlyticsCore = new CrashlyticsCore.Builder().disabled(DEBUG).build();
Fabric.with(this, new Crashlytics.Builder().core(crashlyticsCore).build());

Intent intent = new Intent(this, LogoutService.class);
startService(intent);

CertificatePinner certificatePinner = new CertificatePinner.Builder()
.add("")
.add("")
.build();

engine = new Engine.Builder(privateServerUrlLocal, getString(R.string.other_server_url))
.setCertificatePinner(certificatePinner)
.setSDKPartnerSetupManager(getSdkPartnerManager())
.setLogoutActionHandler(getLogoutActionHandler())
.setVLocationManager(new VLocationManagerImp())
.setDebug(DEBUG)
.addDeepLinkHandler(new ClaimDeepLinkHandler(loginLauncher, profileLauncher))
.addDeepLinkHandler(new LinkGiftCodeDeeplinkHandler(loginLauncher, profileLauncher))
.addDeepLinkHandler(new OpenLinkDeepLinkHandler())
.addDeepLinkHandler(new DetailsDeepLinkHandler())
.addClaimConfig(new ClaimConfig(false, false, false, false, true))
.build();
engine.startup(this);
}



@Override
protected void attachBaseContext(Context base) {
super.attachBaseContext(base);
MultiDex.install(base);
}

}

list

<manifest xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
package="com.package.testapp">

<uses-feature
android:name="android.hardware.camera"
android:required="true" />
<uses-feature
android:name="android.hardware.camera.autofocus"
android:required="false" />
<uses-feature
android:name="android.hardware.camera.flash"
android:required="false" />

<!-- Required for g+ login -->
<uses-permission android:name="android.permission.CAMERA" />

<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />

<application
android:name=".TestApplication"
android:allowBackup="false"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:roundIcon="@mipmap/ic_launcher"
android:supportsRtl="true"
android:theme="@style/AppTheme">

<service
android:name="com.package.companycommon.ui.LogoutService"
android:stopWithTask="true" />

<activity
android:name=".LaunchActivity"
android:screenOrientation="portrait"
android:theme="@style/AppTheme.NoActionBar">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>

<activity
android:name=".welcome.WelcomeActivity"
android:screenOrientation="portrait"
android:theme="@style/AppTheme.NoActionBar.ClearStatus" />
<activity
android:name=".RegisterActivity"
android:screenOrientation="portrait"
android:theme="@style/AppTheme.NoActionBar.ClearStatus"
android:windowSoftInputMode="adjustResize" />
<activity
android:name=".LoginActivity"
android:screenOrientation="portrait"
android:theme="@style/AppTheme.NoActionBar.ClearStatus"
android:windowSoftInputMode="adjustResize" />
<activity
android:name=".ActivationActivity"
android:screenOrientation="portrait"
android:theme="@style/AppTheme.NoActionBar.ClearStatus"
android:windowSoftInputMode="adjustResize" />
<activity
android:name=".AddPhoneNumberActivity"
android:screenOrientation="portrait"
android:theme="@style/AppTheme.NoActionBar.ClearStatus"
android:windowSoftInputMode="adjustResize" />
<activity
android:name=".ForgotPasswordActivity"
android:screenOrientation="portrait"
android:theme="@style/AppTheme.NoActionBar.ClearStatus"
android:windowSoftInputMode="adjustResize" />
<activity
android:name=".GiftHistoryActivity"
android:screenOrientation="portrait"
android:theme="@style/AppTheme.NoActionBar.ClearStatus" />
<activity
android:name="com.package.PartnerLoginHiddenActivity"
android:screenOrientation="portrait"
android:theme="@style/AppTheme.NoActionBar.ClearStatus" />
<activity
android:name=".tutorial.TutorialActivity"
android:screenOrientation="portrait"
android:theme="@style/AppTheme.NoActionBar.ClearStatus" />
<activity
android:name=".CreateNewPasswordActivity"
android:screenOrientation="portrait"
android:theme="@style/AppTheme.NoActionBar.ClearStatus" />
<activity
android:name=".settings.SettingsActivity"
android:screenOrientation="portrait">
<meta-data
android:name="android.support.PARENT_ACTIVITY"
android:value=".GiftHistoryActivity" />
</activity>
<activity
android:name=".settings.ExtraSettingsActivity"
android:label="@string/settings"
android:screenOrientation="portrait">
<meta-data
android:name="android.support.PARENT_ACTIVITY"
android:value=".settings.SettingsActivity" />
</activity>
<activity
android:name="companyapp.company.NewsActivity"
android:label="@string/notifications"
android:screenOrientation="portrait"
android:theme="@style/AppTheme" />
<activity
android:name=".termsandconditions.CompanyTermsAndConditionsActivity"
android:screenOrientation="portrait"
android:theme="@style/AppTheme" />

<activity
android:name="com.package.companycommon.ui.PhotoViewerActivity"
android:screenOrientation="portrait"
android:theme="@style/AppTheme" />

<activity
android:name="com.package.company.details.CompanyDetailActivity"
android:screenOrientation="portrait"
android:theme="@style/AppTheme" />
<activity
android:name="com.package.company.details.CompanyDetailActivityLocation"
android:screenOrientation="portrait"
android:theme="@style/AppTheme">
<meta-data
android:name="android.support.PARENT_ACTIVITY"
android:value="com.package.company.details.CompanyDetailActivity" />
</activity>
<activity
android:name="com.package.company.ClaimActivity"
android:theme="@style/AppTheme.NoActionBar"
tools:replace="android:theme" />
</application>

</manifest>

最佳答案

当面向 api 21 时,编译器将读取 100 个 dex 文件的限制。因此,我发现一个简单的解决方案是将其添加到 gradle 文件中的 dexOptions 中。这会将您的所有 dex 文件合并到尽可能低的数量。

在您的 build.gradle 文件中添加以下内容

android {
...
dexOptions {
preDexLibraries = false
}
}

关于java - Android 5.x ClassNotFoundException 在 6.0+ 上运行良好,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43666425/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com