三邦车视为什么不能看呢

经典文章子分类收藏,626 浏览
问题对人有帮助,内容完整,我也想知道答案
问题没有实际价值,缺少关键内容,没有改进余地
求一个明确的解答,通俗易懂的哈
答案对人有帮助,有参考价值
答案没帮助,是错误的答案,答非所问
具体语言实现不同,这里是一些语言无关的点
如果你在遍历时往数组增加数据,会导致遍历不完整(因为增加了新成员长度变了),或者死循环(因为总是有新的进去)
如果在遍历时删除数据,则会导致数组访问越界(因为长度缩短了,指针指向了一个已经标示为空的区域)
的答案,如果你只是在遍历时修改这个节点本身的数据,一般来说是安全的(当然需要看具体场景)
答案对人有帮助,有参考价值
答案没帮助,是错误的答案,答非所问
你的问题描述得不太准确,标签是java和lisp,只写过一点 racket 代码就不谈论 lisp 了,以下默认修改为 list 的 add/remove 操作
首先, java 里面有很多种 list :
  java.util.ArrayL
  java.util.LinkedL
  java.util.S
  java.util.V
  java.util.concurrent.CopyOnWriteArrayL
其中 CopyOnWriteArrayList在遍历的时候修改是不会出错的,实现方法是读写分离,参考维基
其次, java 里面有好几种遍历方式:
for,在 for 循环中修改并没有问题,除非你把要访问的对象删除,数组越界,或者一直add生成无穷序列
iterator,你用 iterator.remove() 是不会有问题的,因为 iterator.remove() 会设置
this.expectedModCount = ArrayList.this.modC//(1)
这样之后遍历执行 iterator.next() 就不会抛异常
public E next() {
this.checkForComodification();
final void checkForComodification() {
if(ArrayList.this.modCount != this.expectedModCount) {
throw new ConcurrentModificationException();
foreach,本质上是隐式的 iterator (可以用 javap -c 比较字节码),由于没有重新设置 expectedModCount ,当你使用 list.remove()
后遍历执行 iterator.next() 时就会报ConcurrentModificationException
最后,这里面有一个特别的地方,就如果删除的是 list 里倒数第二个值,这样触发 hasNext() 的时候结果正好为 false 退出循环不继续执行 next() 也就不会报错
public boolean hasNext() {
return this.cursor != ArrayList.this.
PS:使用的JDK是java-8-openjdk-amd64
答案对人有帮助,有参考价值
答案没帮助,是错误的答案,答非所问
可以修改呀,下面的程序会打印3个aaaaa
List&String& list = new ArrayList&String&();
list.add("hello");
list.add("world");
list.add("!");
for (int i = 0; i & list.size(); i++) {
list.set(i, "aaaaa");
for (int i = 0; i & list.size(); i++) {
System.out.println(list.get(i));
你是用什么方法遍历的,请贴出代码来,好帮你分析
答案对人有帮助,有参考价值
答案没帮助,是错误的答案,答非所问
从java的角度回答这个问题, Iterator模式是用于遍历集合类的标准访问方法。它可以把访问逻辑从不同类型的集合类中抽象出来,从而避免向客户端暴露集合的内部结构。
例如,如果没有使用Iterator,遍历一个数组的方法是使用索引:
for(int i=0; i&array.size(); i++) { ... get(i) ... }
客户端都必须事先知道集合的内部结构,访问代码和集合本身是紧耦合,无法将访问逻辑从集合类和客户端代码中分离出来,每一种集合对应一种遍历方法,客户端代码无法复用。
更恐怖的是,如果以后需要把ArrayList更换为LinkedList,则原来的客户端代码必须全部重写。为解决以上问题,Iterator模式总是用同一种逻辑来遍历集合:
for(Iterator it = c.iterater(); it.hasNext(); ) { ... }
 - 奥秘在于客户端自身不维护遍历集合的"指针",所有的内部状态(如当前元素位置,是否有下一个元素)都由Iterator来维护,而这个Iterator由集合类通过工厂方法生成,因此,它知道如何遍历整个集合。客户端从不直接和集合类打交道,它总是控制Iterator,向它发送"向前","向后","取当前元素"的命令,就可以间接遍历整个集合。
当使用Iterator对集合元素进行迭代的时候,collection并不是把集合元素本身传给了迭代变量,而是把集合元素的值传给了迭代变量。所以修改迭代变量的值对集合元素本身的值没有任何改变。迭代器Iterator不保存对象,它依附于Collection对象,仅用于遍历集合。迭代器Iterator采用的是快速-失败(fail-fast)机制,一旦在迭代的过程中检测到该集合已经被修改,程序立即引发java.util.ConcurrentModificationException,而不是显示修改后的结果。这样可以避免共享资源而引发的潜在问题。
public class TestCollections {
public static void main(String[] args) {
List&String& list = new ArrayList&String&();
for (int i = 0; i & 10; i++) {
list.add("hello_" + i);
Iterator&String& iterator = list.iterator();
while (iterator.hasNext()) {
String str = iterator.next();
System.out.println(str);
if (str.equals("hello_5")) {
iterator.remove();
list.remove(str);
str = "hehe";
System.out.println(list);
执行 { str = "hello" } 语句,对外部的元素没有任何影响,执行 iterator.remove()会删除当前的迭代对象.
执行list.remove(str) ,会报java.util.ConcurrentModificationException ,因为他检测到集合的元素被修改了.
同步到新浪微博
分享到微博?
与我们一起探索更多的未知
专业的开发者技术社区,为用户提供多样化的线上知识交流,丰富的线下活动及给力的工作机会
加入只需一步
关闭理由:
删除理由:
忽略理由:
推广(招聘、广告、SEO 等)方面的内容
与已有问题重复(请编辑该提问指向已有相同问题)
答非所问,不符合答题要求
宜作评论而非答案
带有人身攻击、辱骂、仇恨等违反条款的内容
无法获得确切结果的问题
非开发直接相关的问题
非技术提问的讨论型问题
其他原因(请补充说明)
我要举报该,理由是:
扫扫下载 App
SegmentFault
一起探索更多未知→ 请问烧伤后口渴,但是为什么不能喝水呢?
请问烧伤后口渴,但是为什么不能喝水呢?
健康咨询描述:
我的一个同学,因为家里着火,他为了抢救自己家的财产,冲进火海去救火了,结果很不幸的被烧伤了,在医院医生特别的交代,千万不能喝白开水,我们都觉得很奇怪
想得到怎样的帮助:请问烧伤后为什么不能喝白开水呢?
其他类似问题
3个回答2个回答5个回答1个回答9个回答
医生回复区
帮助网友:26978称赞:35
&&&&&&你好!但按照医学要求,对烧伤病人是不能给白开水喝的。因为人在烧伤后,随着体液外渗的同时,钠盐也随之丧失,如果单纯给他白开水喝,可导致血液内氯化钠浓度进一步下降,引起细胞内水肿,出现脑水肿或肺水肿,这就是所谓的“水中毒”,可危及烧伤者的生命。
您可能关注的推广
其他类似问题
7个回答2个回答2个回答2个回答1个回答
参考价格:38
参考价格:23
参考价格:0
您可能关注的问题
用药指导/吃什么药好
本品适用于放射治疗引发的继发性红斑。I度,II度...
参考价格:¥220
清热解毒,止痛,生肌。本品用于各种烧﹑烫﹑灼伤。...
参考价格:¥15

我要回帖

更多关于 洗澡为什么不能先洗头 的文章

 

随机推荐