记录下遇到的一个比较坑爹的问题
2015-12-04 15:25
435 查看
今天在添加一个新需求中遇到一个纠结了好久的问题,不是报源码里面的错误,而是报以下这个错误(仅贴出部分log):
12-04 11:10:33.843: E/AndroidRuntime(4158): FATAL EXCEPTION: main
12-04 11:10:33.843: E/AndroidRuntime(4158): java.lang.ClassCastException: android.widget.LinearLayout$LayoutParams cannot be cast to android.widget.AbsListView$LayoutParams
12-04 11:10:33.843: E/AndroidRuntime(4158): at android.widget.ListView.setupChild(ListView.java:1889)
12-04 11:10:33.843: E/AndroidRuntime(4158): at android.widget.ListView.makeAndAddView(ListView.java:1858)
12-04 11:10:33.843: E/AndroidRuntime(4158): at android.widget.ListView.fillDown(ListView.java:678)
12-04 11:10:33.843: E/AndroidRuntime(4158): at android.widget.ListView.fillSpecific(ListView.java:1348)
12-04 11:10:33.843: E/AndroidRuntime(4158): at android.widget.ListView.layoutChildren(ListView.java:1648)
12-04 11:10:33.843: E/AndroidRuntime(4158): at android.widget.AbsListView.onLayout(AbsListView.java:2141)
12-04 11:10:33.843: E/AndroidRuntime(4158): at android.view.View.layout(View.java:14317)
各种Google,都说是Android:LayoutParameter不匹配的问题。然后让我一顿好找啊。最后我只好把最新加入的代码先删除了,结果发现问题解决了,然后去看看我删掉的代码,只是删除了一个gridview。去看看那个gridview的布局:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >
<GridView
android:id="@+id/gvCategory_2"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@color/bg_main_white"
android:paddingLeft="10dp"
android:paddingBottom="10dp"
android:verticalSpacing="10dp"
android:numColumns="3" />
</LinearLayout>
看到了没,LinearLayout里面嵌套了一个GridView。先贴上一张图(图片地址:http://blog.csdn.net/zqiang_55/article/details/7051282):
看到了没,GridView继承AbListView,这就是为什么程序会报出上面的那个错误,由于不同Layout,对应不同Layoutparameter,那么被嵌套的布局或者view,要尊用父布局的Layoutparameter类。因此GridView会去使用LinearLayout的LayoutParameter,而没有使用其父类的LayoutParameter,所以程序报错。
解决办法:去掉该布局的LinearLayout,该布局只包含一个GridView
但是我有一点不明白的是想,在Android5.0上,却是运行正常的。
12-04 11:10:33.843: E/AndroidRuntime(4158): FATAL EXCEPTION: main
12-04 11:10:33.843: E/AndroidRuntime(4158): java.lang.ClassCastException: android.widget.LinearLayout$LayoutParams cannot be cast to android.widget.AbsListView$LayoutParams
12-04 11:10:33.843: E/AndroidRuntime(4158): at android.widget.ListView.setupChild(ListView.java:1889)
12-04 11:10:33.843: E/AndroidRuntime(4158): at android.widget.ListView.makeAndAddView(ListView.java:1858)
12-04 11:10:33.843: E/AndroidRuntime(4158): at android.widget.ListView.fillDown(ListView.java:678)
12-04 11:10:33.843: E/AndroidRuntime(4158): at android.widget.ListView.fillSpecific(ListView.java:1348)
12-04 11:10:33.843: E/AndroidRuntime(4158): at android.widget.ListView.layoutChildren(ListView.java:1648)
12-04 11:10:33.843: E/AndroidRuntime(4158): at android.widget.AbsListView.onLayout(AbsListView.java:2141)
12-04 11:10:33.843: E/AndroidRuntime(4158): at android.view.View.layout(View.java:14317)
各种Google,都说是Android:LayoutParameter不匹配的问题。然后让我一顿好找啊。最后我只好把最新加入的代码先删除了,结果发现问题解决了,然后去看看我删掉的代码,只是删除了一个gridview。去看看那个gridview的布局:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >
<GridView
android:id="@+id/gvCategory_2"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@color/bg_main_white"
android:paddingLeft="10dp"
android:paddingBottom="10dp"
android:verticalSpacing="10dp"
android:numColumns="3" />
</LinearLayout>
看到了没,LinearLayout里面嵌套了一个GridView。先贴上一张图(图片地址:http://blog.csdn.net/zqiang_55/article/details/7051282):
看到了没,GridView继承AbListView,这就是为什么程序会报出上面的那个错误,由于不同Layout,对应不同Layoutparameter,那么被嵌套的布局或者view,要尊用父布局的Layoutparameter类。因此GridView会去使用LinearLayout的LayoutParameter,而没有使用其父类的LayoutParameter,所以程序报错。
解决办法:去掉该布局的LinearLayout,该布局只包含一个GridView
但是我有一点不明白的是想,在Android5.0上,却是运行正常的。
相关文章推荐
- linux中send函数MSG_NOSIGNAL异常消息
- 配置Ubuntu Server高速apt-get源
- 安装php7及安装memcache扩展出现的新旧php版本兼容扩展的问题
- 时序图
- String类intern()方法解析
- 关于Win10系统下VIA HD AUDIO威盛声卡没声音问题 - 有效解决办法
- eclipse创建web项目和配置tomcat
- 搜索题【入门】
- iOS将控制台Log日志转为输出为文本文件
- Oracle创建删除用户、角色、表空间、导入导出、...命令总结
- UIWindow & UIWindowLevel笔记
- Android学习-----Button点击事件几种写法
- hdu 4902 Nice boat 线段树
- 三大重磅福利!曲面电视现史上最佳买点
- IOS Iphone震动 和 提示音
- 验证docker的Redis镜像也存在未授权访问漏洞
- iOS--深浅拷贝深析
- Linux查找、安装&卸载命令学习
- LINUX下开启apache时出现Address already in use: make_sock: could not bind to address [::]:80
- Exception in thread "main" java.lang.UnsatisfiedLinkError: org.apache.hadoop.io.nativeio.NativeIO$Wi