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

时间:2015-05-13 20:47:41

标签: 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);

    }

    ...

}

单击调用抛出异常的方法的类文件,表明它无法找到&#39; android.support.v7.appcompat.R;&#39;:

enter image description here

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

2 个答案:

答案 0 :(得分:50)

我只是花了好几个小时处理同样的问题,我能够解决它......

事实证明我超过了dex限制,我在defaultConfig下的build.gradle文件中确实有multiDexEnabled为true,但看起来我缺少了5.0之前的其他设备..

defaultConfig { 
...
        multiDexEnabled true 
... }

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

我在67952方法......

然后我更新了我的build.gradle以添加multidex支持

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

确保清单中的应用程序指向您的自定义多索引应用程序

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

答案 1 :(得分:3)

我只花了几个小时,现在已经解决了。

某些Android应用程序的约束是底层编译的.dex文件可以支持的方法总数。它受16位或65,536个值的限制。

当您在应用程序中包含第三方库时,您将在.dex文件中包含所有方法。较大的API(例如Google Play服务中包含的API)将很快开始进入限制。

更多详情:Google Play services and DEX method limits

就我而言,我在我的应用中使用Google Play服务进行Google / Youtube身份验证。

  

compile&#39; com.google.android.gms:play-services:7.3.0&#39;

所以我把它改成了

  

compile&#39; com.google.android.gms:play-services-identity:7.3.0&#39;

因为我只需要身份/身份验证。 所以你可以根据你的要求选择个人图书馆。

例如,如果你想要使用的只是地图,那么你会改为:

  

compile&#39; com.google.android.gms:play-services-maps:7.3.0&#39;

同样适用于位置

  

compile&#39; com.google.android.gms:play-services-location:7.3.0&#39;

我希望它会对你有所帮助!