在Java中的For循环中转到下一个迭代


Answers:


357
continue;

continue; 关键字将在调用时开始下一次迭代

例如

for(int i= 0 ; i < 5; i++){
 if(i==2){
  continue;
 }
System.out.print(i);
}

这将打印

0134

看到


2
break会跳过循环:)
Shajeel Afzal

21
相反,“ break”关键字将终止循环。
流氓小伙子

56

试试这个,

1. If you want to skip a particular iteration, use continue.

2. If you want to break out of the immediate loop use break

3 If there are 2 loop, outer and inner.... and you want to break out of both the loop from the inner loop, use break with label.

例如:

继续

for(int i=0 ; i<5 ; i++){

    if (i==2){

      continue;
    }
 }

例如:

打破

for(int i=0 ; i<5 ; i++){

        if (i==2){

          break;
        }
     }

例如:

打破标签

lab1: for(int j=0 ; j<5 ; j++){
     for(int i=0 ; i<5 ; i++){

        if (i==2){

          break lab1;
        }
     }
  }

5
也有继续标签。
Carcamano 2012年

35

如果要跳过当前迭代,请使用continue;

for(int i = 0; i < 5; i++){
    if (i == 2){
        continue;
    }
 }

是否需要打破整个循环?使用break;

for(int i = 0; i < 5; i++){
    if (i == 2){
        break;
    }
}

如果您需要突破一个以上的循环,请使用 break someLabel;

outerLoop:                                           // Label the loop
for(int j = 0; j < 5; j++){
     for(int i = 0; i < 5; i++){
        if (i==2){
          break outerLoop;
        }
     }
  }

*请注意,在这种情况下,您未在代码中标记要跳转的点,而是在标记循环!因此,中断之后,代码将在循环之后继续!

当您需要在嵌套循环中跳过一次迭代时continue someLabel;,可以使用,但也可以将它们全部合并。

outerLoop:
for(int j = 0; j < 10; j++){
     innerLoop:
     for(int i = 0; i < 10; i++){
        if (i + j == 2){
          continue innerLoop;
        }
        if (i + j == 4){
          continue outerLoop;
        }
        if (i + j == 6){
          break innerLoop;
        }
        if (i + j == 8){
          break outerLoop;
        }
     }
  }

9

如所有其他答案中所述,关键字continue将跳至当前迭代的末尾。

另外,您可以标记循环的开始,然后使用continue [labelname];break [labelname];控制嵌套循环中发生的事情:

loop1: for (int i = 1; i < 10; i++) {
    loop2: for (int j = 1; j < 10; j++) {
        if (i + j == 10)
            continue loop1;

        System.out.print(j);
    }
    System.out.println();
}


By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.