java 迭代器 for循环_[DanoR][Java代码][逻辑精简::for循环遍历Iterator迭代器]

博主分享了一种利用逻辑代数精简Java中for循环遍历Iterator的方法,通过在for循环的判断表达式中结合hasNext()和next(),实现了既简洁又安全的代码。文章详细解析了迭代器的遍历逻辑,并通过实例展示了如何通过赋值表达式实现这一目标,同时强调了Java的短路表达式在防止异常方面的作用。
摘要由CSDN通过智能技术生成

博主有较强的强迫倾向!

今天强迫症犯了,就想把代码都精简了!

结果发现一个关于for循环遍历Iterator迭代器的精简的写法,利用逻辑代数实现。

定义:

HashMap map = new HashMap();

map.put("1","a");

map.put("2","b");

map.put("3","c");

map.put("4","d");

```java

Iterator it = map.values().iterator();//迭代器

- 一般的写法:

```java

for (; it.hasNext(); )

System.out.println(it.next());

可惜的是, Iterator不支持这样的写法,

最喜欢这种写法了,不用考虑结束条件,又有循环变量s可以直接使用,不用担心多次调用next()产生错误。

for(String s:it)//这样是错的,不支持。

System.out.println(s);

所以作为一个有强迫倾向的人, 希望找到一种接近上述特性的写法。

天无绝人之路,

Java语言有一个我很喜欢的特性————允许在表达式中赋值!

流的IO读写操作就是一个十分典型的应用。

经验告诉我,只要利用这个特性就能实现我的目的:

首先,明确Iterator一般是怎么遍历的。

Iterator是通过两个函数——hasNext()和next()函数互相配合遍历的。

hasNext()判断是否存在下个对象。

next()则返回下个对象并移动游标到下下个对象。

根据上述特性归纳一下,上述逻辑等价于:

每次循环

----hasNext()判断

--------如果true则next()执行一次,

--------如果false就跳出循环。

接着,想一想for(初始化语句; 判断表达式; 每次循环后语句)的特性:

一般for的初始化语句用定义一个下标变量来表示循环到哪里?

而一般的Iterator遍历,因为有next()函数所以不用着for的初始化语句。

所以,

初始化语句可以定义下标变量,那么也当然可以用来定义一个循环变量!

另外,

Java允许赋值,那么上文提到的遍历Iterator的逻辑就也可以归纳for的判断表达式中!

最后,确定for的判断表达式:

设表达式为A。

明显地,A = hasNext(),才能正确地跳出循环。

并且,要在表达式A中完成一次赋值s=next()。

运用代数逻辑,演算如下:

A = A

A = A && true

true = 包含一次赋值的表达式

一般情况,当hasNext()为true时。next()不可能抛出异常或返回null

所以,next()!=null必为true。有:

true = (s = next()) != null

结果如下:

it.hasNext() && (s=(String) it.next()) != null

等价于 A = A && true,等价于 hasxNext(),完成了一次赋值

最终完整代码:

HashMap map = new HashMap();

map.put("1","a");

map.put("2","b");

map.put("3","c");

map.put("4","d");

Iterator it = map.values().iterator();

for (String s = null; it.hasNext() && (s=it.next()) != null; )

System.out.println(s);

这样就既可以直接使用循环变量s, 又可以一行写完for语句, 实在符合我的强迫倾向的审美。

同时Java的表达式是短路表达式,一旦hasNext()返回是false,后续的(s = next()) != null操作就不会继续执行,防止遍历到最后next()到空值而产生异常。

后记

当然,这不是什么很厉害的代码,也写得很啰嗦,估计没人能静下心,一路看到这里。

但是对于我来说是一次很好的逻辑整理,想出这表达只用了几分钟,但写出这对文字却用了我几个小时(语言能力太差了)。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值