Binary XML file line #7: Error inflating class android.support.v7.widget.RecyclerView

前端之家收集整理的这篇文章主要介绍了Binary XML file line #7: Error inflating class android.support.v7.widget.RecyclerView前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

原文地址:http://blog.csdn.net/u010351494/article/details/47022601

@H_502_5@

最近学习RecyclerView,使用eclipse引用RecyclerView,编写完demo后编译没有问题,一运行就挂掉,错误如下:

07-22 23:05:34.553: D/AndroidRuntime(2968): Shutting down VM @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): FATAL EXCEPTION: main @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): Process: com.zh.myrecyclerview,PID: 2968 @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.zh.myrecyclerview/com.zh.myrecyclerview @H_502_5@ .MainActivity}: android.view.InflateException: Binary XML file line #7: Error inflating class android.support.v7.widget.RecyclerView @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2298) @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2360) @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): at android.app.ActivityThread.access$800(ActivityThread.java:144) @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1278) @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): at android.os.Handler.dispatchMessage(Handler.java:102) @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): at android.os.Looper.loop(Looper.java:135) @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): at android.app.ActivityThread.main(ActivityThread.java:5221) @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): at java.lang.reflect.Method.invoke(Native Method) @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): at java.lang.reflect.Method.invoke(Method.java:372) @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899) @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694) @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): Caused by: android.view.InflateException: Binary XML file line #7: Error inflating class android.support.v7.widget.RecyclerView @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): at android.view.LayoutInflater.createView(LayoutInflater.java:633) @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:743) @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): at android.view.LayoutInflater.rInflate(LayoutInflater.java:806) @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): at android.view.LayoutInflater.inflate(LayoutInflater.java:504) @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): at android.view.LayoutInflater.inflate(LayoutInflater.java:414) @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): at android.view.LayoutInflater.inflate(LayoutInflater.java:365) @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:377) @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): at android.app.Activity.setContentView(Activity.java:2144) @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): at com.zh.myrecyclerview.MainActivity.onCreate(MainActivity.java:20) @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): at android.app.Activity.performCreate(Activity.java:5933) @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1105) @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2251) @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): ... 10 more @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): Caused by: java.lang.reflect.InvocationTargetException @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): at java.lang.reflect.Constructor.newInstance(Native Method) @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): at java.lang.reflect.Constructor.newInstance(Constructor.java:288) @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): at android.view.LayoutInflater.createView(LayoutInflater.java:607) @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): ... 21 more @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): Caused by: java.lang.NoClassDefFoundError: Failed resolution of: Landroid/support/v7/recyclerview/R$styleable; @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): at android.support.v7.widget.RecyclerView.<init>(RecyclerView.java:434) @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): at android.support.v7.widget.RecyclerView.<init>(RecyclerView.java:404) @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): ... 24 more @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): Caused by: java.lang.ClassNotFoundException: Didn't find class "android.support.v7.recyclerview.R$styleable" on path: DexPathList[[zip file "/data/app/com.zh.myrecyclerview-1/base.apk"],nativeLibraryDirectories=[/vendor/lib,/system/lib]] @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56) @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): at java.lang.ClassLoader.loadClass(ClassLoader.java:511) @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): at java.lang.ClassLoader.loadClass(ClassLoader.java:469) @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): ... 26 more @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): Suppressed: java.lang.ClassNotFoundException: android.support.v7.recyclerview.R$styleable @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): at java.lang.Class.classForName(Native Method) @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): at java.lang.BootClassLoader.findClass(ClassLoader.java:781) @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): at java.lang.BootClassLoader.loadClass(ClassLoader.java:841) @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): at java.lang.ClassLoader.loadClass(ClassLoader.java:504) @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): ... 27 more @H_502_5@ 07-22 23:05:34.560: E/AndroidRuntime(2968): Caused by: java.lang.NoClassDefFoundError: Class not found using the boot class loader; no stack available @H_502_5@ 07-22 23:05:37.406: I/Process(2968): Sending signal. PID: 2968 SIG: 9 @H_502_5@ @H_502_5@ @H_502_5@ 试了很多方法都不行,整了半天,终于搞定,原来在eclipse中使用RecyclerView只能导入API21.0.0中的包才可以使用。 @H_502_5@ 解决办法:进入sdk\extras\android\m2repository\com\android\support\recyclerview-v7\21.0.0目录,找到recyclerview-v7-21.0.0.aar这个文件。用解压软件解压此文件里面有classes.jar,把这个jar包放到项目中的libs文件下即可。这个jar包就是RecyclerView要使用的,可以给它改个名字例如android-support-v7-recyclerview.jar,便于查看。 @H_502_5@ @H_502_5@ 最近升级了SDK发现sdk\extras\android\m2repository\com\android\support\recyclerview-v7\21.0.0这个目录找不到了,所以把之前的jar包传到了csdn的服务器上,需要的可以到这下载: http://download.csdn.net/detail/u010351494/9232327 注意注意注意:我提供的这个包是15年5.0刚发布的时候保留的包,当时recyclerview这个控件也是刚刚推出,功能很强大,但是也有许多不完善的地方,在后期的sdk更新中官方可能更新了recyclerview的api,使其更加完善。但这也导致大家在用我的包并在21以上的sdk编译时有些方法不支持,比如 addOnScrollListener和android.support.v7.widget.helper.ItemTouchHelper。 如果你没有用到这些方法又必须使用eclipse可以继续使用我的包,如果必须用这些方法,建议大家放弃使用eclipse,换成使用as开发。

猜你在找的XML相关文章