Groovy Tip 2 each方法和break
2008-04-16 19:44
399 查看
Groovy Tip 2 each方法和break
在Groovy这样的动态语言中,闭包是其中的一个重要武器。而这些语言的开发者自然不会放弃使用这些武器,我们可以看到在Groovy语言的集合类中,广泛的使用了闭包。其中,each方法就是这样一个使用闭包的方法。
我们知道,在Java中,我们使用下面的语句对集合类对象进行遍历:
for(int i=0;i<list.size();i++)
{
System.out.println(list.get(i))
}
而在Groovy语言中,我们使用each方法对集合类对象进行遍历:
list.each{
it ->
println it
}
已经比起传统的for循环语句来说简单得多,但仍然可以更简单:
list.each{
println it
}
这是因为在默认情况下,each方法的输入参数为it。
如果我们想通过each方法获取集合类对象中的元素位置时,应该这样使用:
list.eachWithIndex{
i,it ->
println"port: $i value: $it"
}
下面,我们定义一个List对象:
def list = [1,5,6,2,6,7]
现在,我想要判断上面的集合对象中是否大于5的元素:
def have = false
list.each{
if(it>5)
{
have = true
break;
}
}
println have
结果却发现该break语言编译不过去。怎么办?
def have = false
for(it in list){
if(it>5)
{
have = true
break;
}
}
println have
不错,有时侯这些旧的语法还有是用途的。
在Groovy这样的动态语言中,闭包是其中的一个重要武器。而这些语言的开发者自然不会放弃使用这些武器,我们可以看到在Groovy语言的集合类中,广泛的使用了闭包。其中,each方法就是这样一个使用闭包的方法。
我们知道,在Java中,我们使用下面的语句对集合类对象进行遍历:
for(int i=0;i<list.size();i++)
{
System.out.println(list.get(i))
}
而在Groovy语言中,我们使用each方法对集合类对象进行遍历:
list.each{
it ->
println it
}
已经比起传统的for循环语句来说简单得多,但仍然可以更简单:
list.each{
println it
}
这是因为在默认情况下,each方法的输入参数为it。
如果我们想通过each方法获取集合类对象中的元素位置时,应该这样使用:
list.eachWithIndex{
i,it ->
println"port: $i value: $it"
}
下面,我们定义一个List对象:
def list = [1,5,6,2,6,7]
现在,我想要判断上面的集合对象中是否大于5的元素:
def have = false
list.each{
if(it>5)
{
have = true
break;
}
}
println have
结果却发现该break语言编译不过去。怎么办?
def have = false
for(it in list){
if(it>5)
{
have = true
break;
}
}
println have
不错,有时侯这些旧的语法还有是用途的。
相关文章推荐
- Groovy Tip 11 GDK的Object扩展方法
- groovy中each迭代get方法获取值未空,原因探究。GStringImpl
- Groovy Tip 33 方法的参数 二
- Groovy Tip 32 方法的参数 一
- each函数不能使用break和continue关键字,替代方法
- jQuery的each方法中实现continue和break的流控制
- HashMap 的遍历 for:each 和EntrySet两种方法
- 【Groovy】List对象的transpose和inject方法的使用
- [js] 如何 在 jQuery 中的 $.each 循环中使用 break 和 continue
- 为原生js Array增加each方法
- Jquery的each里面用return false代替break; return ture 代替continue
- PHP跳出循环的方法及continue、break、exit的区别
- Jquery中find与each方法使用详解
- 在Groovy中调用ViewImpl与ViewRowImpl的方法
- PHP跳出循环的方法及continue、break、exit的区别
- Populating Next Right Pointers in Each Node II [leetcode] 空间O(1)的基于循环和基于递归的两种方法
- for_each使用方法
- LeetCode 140 Word Break II (DFS 分词方法 推荐)
- shapely and geos break在distance方法
- 多层循环方法状态的返回tip