java - 为什么我仍然收到 java.lang.NoClassDefFoundError : android. support.v7.appcompat.R$attr?

标签 java android gradle

所以我正在开发一个俗气的应用程序,在我从事公司的实际应用程序项目之前发布帖子来训练自己使用 android。我遇到了一个让我非常困难的错误。

我得到了一个我要使用的库依赖项列表,并设置了我的 build.gradle 文件来加载它们。它可以很好地同步,所以我认为据我所知它是正确的:

dependencies {
    compile fileTree(dir: 'libs', include: ['*.jar'])
    compile 'com.android.support:appcompat-v7:22.1.1'
    compile 'com.google.android.gms:play-services:7.3.0'
    compile 'com.squareup.okhttp:okhttp:2.3.0'
    compile 'com.squareup.retrofit:retrofit:1.7.0'
    compile 'com.google.code.gson:gson:2.3'
    compile 'com.squareup.dagger:dagger:1.2.2'
    compile 'com.squareup.dagger:dagger-compiler:1.2.2'
    compile 'com.squareup.picasso:picasso:2.5.2'
    compile 'com.android.support:recyclerview-v7:22.1.1'
    compile 'com.squareup:otto:1.3.7'
    compile 'com.path:android-priority-jobqueue:1.1.2'
    compile 'io.realm:realm-android:0.80.1'
    compile 'com.jakewharton:butterknife:6.1.0'
    compile 'com.android.support:multidex:1.0.0'
    compile 'com.android.support:appcompat-v7:22.1.1'
}

我实际上已经安装了 android 支持库和存储库: SDK Manager Proof I've installed what I need

但我仍然尝试启动应用程序并获得以下堆栈跟踪:

java.lang.NoClassDefFoundError: android.support.v7.appcompat.R$attr
        at android.support.v7.app.AppCompatDelegateImplV7.ensureSubDecor(AppCompatDelegateImplV7.java:286)
        at android.support.v7.app.AppCompatDelegateImplV7.setContentView(AppCompatDelegateImplV7.java:246)
        at android.support.v7.app.AppCompatActivity.setContentView(AppCompatActivity.java:106)
        at com.anglersatalas.twitstagram.MainActivity.onCreate(MainActivity.java:23)
        at android.app.Activity.performCreate(Activity.java:5451)
        at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1093)
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2298)
        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2392)
        at android.app.ActivityThread.access$900(ActivityThread.java:169)
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1280)
        at android.os.Handler.dispatchMessage(Handler.java:102)
        at android.os.Looper.loop(Looper.java:146)
        at android.app.ActivityThread.main(ActivityThread.java:5487)
        at java.lang.reflect.Method.invokeNative(Native Method)
        at java.lang.reflect.Method.invoke(Method.java:515)
        at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1283)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1099)
        at dalvik.system.NativeStart.main(Native Method)

我在 Stack Overflow 上看到的其他任何地方都有添加 appcompat v7 库的解决方案,正如他们在 android 网站上所说的那样,我已经在上面证明了这一点。我一生都无法弄清楚为什么这仍然会发生。查看堆栈跟踪,它在 setContentView() 方法中中断了我的 MainActivity:

package com.anglersatalas.twitstagram;

import android.os.Bundle;
import com.anglersatalas.twitstagram.R;
import android.support.v7.app.AppCompatActivity;
import android.view.Menu;
import android.view.MenuItem;
import android.widget.TextView;

import com.anglersatalas.twitstagram.api.PostService;
import com.anglersatalas.twitstagram.models.Post;

import java.util.List;

import retrofit.RestAdapter;


public class MainActivity extends AppCompatActivity{

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(com.anglersatalas.twitstagram.R.layout.activity_main);

        TextView tv =  (TextView)findViewById(com.anglersatalas.twitstagram.R.id.textView);

        RestAdapter adapter = new RestAdapter.Builder()
                .setEndpoint("10.0.0.248/testserver/backend/web")
                .build();

        PostService service = adapter.create(PostService.class);
        List<Post> list = service.getPosts();
        String str = "";
        for(Post p : list){
            str += String.format("%s\n", p);
        }
        tv.setText(str);

    }

    ...

}

点击到调用抛出异常方法的类文件,显示找不到'android.support.v7.appcompat.R;':

enter image description here

我和我的同事都不知所措。有关如何解决此问题的任何建议?

最佳答案

我刚刚花了几个小时来解决同样的问题,我能够解决它......

事实证明我超过了 dex 限制,我的 build.gradle 文件中的 defaultConfig 确实有 multiDexEnabled true,但对于 5.0 之前的设备,我似乎遗漏了其他一些东西..

defaultConfig { 
...
        multiDexEnabled true 
... }

我首先检查了我的方法计数:https://github.com/mihaip/dex-method-counts

我在 67952 方法...

然后我更新了我的 build.gradle 以添加多索引支持

dependencies {
...
compile 'com.android.support:multidex:1.0.0'
... }

然后我更新了我的应用程序(我们已经有自己的)以从 MultiDexApplication 扩展

package com.me.myapp
...
public class Application extends MultiDexApplication {}

这是我用来正确实现 multidex 的文档中的两个链接: https://developer.android.com/tools/building/multidex.html https://developer.android.com/reference/android/support/multidex/MultiDexApplication.html

确保 list 中的应用程序指向您的自定义 multidex 应用程序

<application
...
android:name="com.me.myapp.Application" />

关于java - 为什么我仍然收到 java.lang.NoClassDefFoundError : android. support.v7.appcompat.R$attr?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30224899/

相关文章:

Android Studio 无法构建新项目,等待从属 aapt 进程时超时

gradle - 无法从Gradle Exec任务执行sh文件

gradle - 如何使用格拉德脚本在 war 构建中添加WEB-INF/lib jar

java - 扩展对象并继承所有变量

java - Android 音轨播放时带有噪音

java - 如何使用 gradle-launch4j 插件将 gradle 项目编译为 exe

android - Delphi TListview - 搜索项目并自动滚动到该项目

java - 通过 WCF 客户端调用 Java SOAP 1.1 服务

安卓。 Espresso 。如何单击带有文本的 Spinner 项目?

java - Badass 运行时 suggestModules NPE 问题