Android-71-解决报错: java.lang.ArrayIndexOutOfBoundsException: length=2; index=2

本文解决了在Android应用中使用ListView时遇到的ArrayIndexOutOfBoundsException异常问题。通过调整Adapter中的getViewTypeCount及getItemViewType方法实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前言:时隔两年,从操旧业,从14年底搞java、android,再到中间的iOS。从两年前的windows、eclipse、servlet到如今的Mac、android studio 、ssm框架。确实发生了翻天覆的的变化,将iOS的一些思想与android相融合,更是达到了水乳交融的效果,感谢经历过的所有,不要重复造轮子!


正题:

使用ListView写一个头部固定的ListView, 这个ListView需要返回两种类型的Item, 一种是Section,相当于标题, 一种是具体的item.然后手贱, 不知道出什么问题, 调试出现以下错误

E/AndroidRuntime: FATAL EXCEPTION: main
                  Process: com.ieslab.activity, PID: 10681
                  java.lang.ArrayIndexOutOfBoundsException: length=2; index=2
                      at android.widget.AbsListView$RecycleBin.addScrapView(AbsListView.java:7273)
                      at android.widget.ListView.measureHeightOfChildren(ListView.java:1289)
                      at android.widget.ListView.onMeasure(ListView.java:1186)
                      at android.view.View.measure(View.java:16892)
                      at android.widget.RelativeLayout.measureChild(RelativeLayout.java:794)
                      at android.widget.RelativeLayout.onMeasure(RelativeLayout.java:544)
                      at android.view.View.measure(View.java:16892)
                      at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:5394)
                      at android.widget.FrameLayout.onMeasure(FrameLayout.java:340)

解决办法:

首先, Adapter的 
@Override 
public int getViewTypeCount() { 
return 2; 

需要返回的是2, 接下来的: 
@Override 
public int getItemViewType(int position) { 
return getItem(position).viewType; 

这个才是最重要的, viewType的类型一定要从0开始……否则会出错误, 也就是要定义viewType = 0 和viewType=1, 之前就是因为我viewType=1和viewType=2就出问题了…..

<think>好的,我现在需要解决用户的问题:如何在Scala代码中安全地从args中提取参数以避免ArrayIndexOutOfBoundsException异常。首先,我得回想一下用户提到的相关引用和之前的错误情况。 用户之前遇到了ArrayIndexOutOfBoundsException,可能是因为参数数量不足导致的。比如,当args数组的索引超出范围时,就会抛出这个异常。所以,用户现在希望安全地提取参数,防止这种情况发生。 我需要考虑几种常见的方法。首先,检查参数长度是否足够。比如,在访问args(i)之前,先判断args的长度是否大于i。如果不够,可以给出错误提示或者使用默认值。例如,用户可能使用if语句来检查args.length,或者使用模式匹配来处理不同的参数情况。 另外,用户提到的其他引用中,有关于编码问题导致的类似异常,这可能与参数内容有关,但当前问题更关注参数的提取,所以重点应放在参数数量的检查上。此外,用户提到的依赖版本问题,比如paranamer或spark-core的版本冲突,可能不直接相关,但需要确保代码中没有其他潜在的库冲突。 然后,用户可能希望代码既安全又简洁。Scala提供了多种方式来处理可能为空的或越界的情况,比如使用Option类型或者Try来处理异常。例如,使用lift方法将数组转换为函数,返回Option,这样在访问不存在的索引时返回None而不是抛出异常。 另外,用户可能需要处理多个参数的情况,比如多个选项或标志,这时候可能需要更复杂的解析,使用库如scopt或者Scallop,这些库可以自动处理参数解析,避免手动检查带来的错误。 总结下来,解决方案可能包括: 1. 基本的参数长度检查。 2. 使用Option和模式匹配来安全提取。 3. 使用Try来捕获可能的异常。 4. 使用第三方库进行参数解析。 接下来,我需要将这些方法具体化,给出代码示例,并说明各自的优缺点。同时,提醒用户注意其他可能导致ArrayIndexOutOfBoundsException的情况,比如参数格式错误或编码问题,但主要解决参数数量不足的情况。 最后,生成相关问题,帮助用户深入理解,比如参数解析的最佳实践、处理缺失参数的其他方法,或者推荐的Scala参数解析库。</think>在Scala中从命令行参数(`args: Array[String]`)安全提取参数时,可通过以下方法避免`java.lang.ArrayIndexOutOfBoundsException`异常: --- ### 1. **基础参数长度检查** 直接验证索引是否有效: ```scala if (args.length > index) { val param = args(index) // 正常处理 } else { println(s"参数缺失:需要至少 ${index + 1} 个参数") sys.exit(1) } ``` --- ### 2. **模式匹配提取参数** 通过模式匹配处理不同参数数量: ```scala args match { case Array(param1, param2, _*) => println(s"参数1: $param1, 参数2: $param2") case _ => println("至少需要2个参数") sys.exit(1) } ``` --- ### 3. **使用`Option`包装返回值** 通过`.lift`方法将数组索引转换为`Option`类型: ```scala val param: Option[String] = args.lift(index) param match { case Some(value) => println(s"参数值: $value") case None => println("参数不存在") } ``` --- ### 4. **`Try`异常捕获机制** 显式捕获可能的异常: ```scala import scala.util.Try val param = Try(args(index)).toOption param.getOrElse { println("参数缺失") // 默认值逻辑 } ``` --- ### 5. **参数解析库(推荐)** 使用第三方库如**scopt**或**Scallop**实现安全解析: ```scala // scopt示例 case class Config(input: String = "", output: String = "") val parser = new scopt.OptionParser[Config]("app") { opt[String]('i', "input").required().action((x, c) => c.copy(input = x)) opt[String]('o', "output").required().action((x, c) => c.copy(output = x)) } parser.parse(args, Config()) match { case Some(config) => // 成功解析 case None => sys.exit(1) // 参数缺失或错误 } ``` --- ### **其他注意事项** - 若参数与文件编码相关(如用户提到的GB2312与UTF-8冲突[^1]),需确保参数值的编码与系统环境一致 - 检查依赖版本兼容性,如Spark与JDK版本冲突可能间接导致参数处理异常[^3][^4] ---
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

IOT_Elon

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值