publicstaticvoidmain(String[]args){Integer[]qq={1,2,3,4,5,6,7,8,9,10};Listl=newArrayList();Collections.addAll(l,qq);//1l=l.stream().map(e->{returne+1;}).collect(Collectors.toList());//2l.forEach(integer->integer++);}
2 回答
慕盖茨4494581
TA贡献1850条经验 获得超11个赞
api的设计是通过语义的不同,让开发者做出更符合自己业务的代码。例如题目中map和forEach的区别:map是变形操作,即:[0,1,2,3]=>[false,true,true,true],如果要完成这个事情,map就是最佳选择,符合语义设计,代码如下:publicstaticvoidmain(String[]args){Listnums=Arrays.asList(0,1,2,3); Listbools=nums.stream().map(num->num!=0).collect(Collectors.toList()); System.out.println(bools);}forEach是副作用,如果你只是想针对每一个值做额外的操作,如下,打印一下:publicstaticvoidmain(String[]args){Listnums=Arrays.asList(0,1,2,3); nums.forEach(num->{System.out.println(num);});}那就应该用forEach,也更符合他的语义。这是语义化的好处,在程序执行层面没什么特别的对错或者好坏
红糖糍粑
TA贡献1815条经验 获得超6个赞
你确定能在foreach里面改变integer的值?你写的例子里两个执行效果都不一样,没法比。效果一样的前提下,如果不是CPU密集型的功能,一般哪个可读性更好久用哪个l.stream().map(e->{returne+1;}).collect(Collectors.toList());这个会创建一个新的list,里面的值是l的对应位置元素值+1;而l.forEach(i->i++)相当于l.forEach(i->{i++;return;})执行完什么都没变
添加回答
举报
0/150
提交
取消