本教程是针对JDK 8编写的。本页面描述的示例和实践不利用后续版本中引入的改进,并可能使用不再可用的技术。
请查看Java语言变更,了解Java SE 9及后续版本中更新的语言功能摘要。
请查看JDK发布说明,获取有关所有JDK版本的新功能、增强功能以及已删除或不推荐使用的选项的信息。
break语句有两种形式:带标签和不带标签。你在之前对switch语句的讨论中看到了不带标签的形式。你也可以使用不带标签的break语句来终止for、while或do-while循环,如下面的BreakDemo程序所示:
class BreakDemo { public static void main(String[] args) { int[] arrayOfInts = { 32, 87, 3, 589, 12, 1076, 2000, 8, 622, 127 }; int searchfor = 12; int i; boolean foundIt = false; for (i = 0; i < arrayOfInts.length; i++) { if (arrayOfInts[i] == searchfor) { foundIt = true; break; } } if (foundIt) { System.out.println("找到了 " + searchfor + " 在索引 " + i); } else { System.out.println(searchfor + " 不在数组中"); } } }
这个程序在数组中搜索数字12。加粗显示的break语句在找到该值时终止for循环。控制流然后转移到for循环后的语句。该程序的输出是:
找到了 12 在索引 4
不带标签的break语句终止最内层的switch、for、while或do-while语句,但带标签的break语句终止外部语句。下面的程序BreakWithLabelDemo与之前的程序类似,但使用嵌套的for循环在二维数组中搜索一个值。当找到该值时,带标签的break语句终止外部的for循环(标签为"search"):
class BreakWithLabelDemo { public static void main(String[] args) { int[][] arrayOfInts = { { 32, 87, 3, 589 }, { 12, 1076, 2000, 8 }, { 622, 127, 77, 955 } }; int searchfor = 12; int i; int j = 0; boolean foundIt = false; search: for (i = 0; i < arrayOfInts.length; i++) { for (j = 0; j < arrayOfInts[i].length; j++) { if (arrayOfInts[i][j] == searchfor) { foundIt = true; break search; } } } if (foundIt) { System.out.println("找到了 " + searchfor + " 在 " + i + ", " + j); } else { System.out.println(searchfor + " 不在数组中"); } } }
这是程序的输出。
在 1, 0 处找到 12
break
语句终止带标签的语句; 它不会将控制流转移到标签处。控制流转移到标记(已终止)语句后面的语句。
continue
语句continue
语句跳过当前的 for
、while
或 do-while
循环的迭代。未标记的形式跳到最内层循环体的末尾,并评估控制循环的 boolean
表达式。下面的程序 ContinueDemo
,遍历一个字符串,计算字母“p”的出现次数。如果当前字符不是“p”,则 continue
语句跳过循环的其余部分,继续下一个字符。如果是“p”,程序会增加字母计数。
class ContinueDemo { public static void main(String[] args) { String searchMe = "peter piper picked a " + "peck of pickled peppers"; int max = searchMe.length(); int numPs = 0; for (int i = 0; i < max; i++) { // 只关注 p if (searchMe.charAt(i) != 'p') continue; // 处理 p numPs++; } System.out.println("在字符串中找到了 " + numPs + " 个 p。"); } }
这个程序的输出如下:
在字符串中找到了 9 个 p。
为了更清楚地看到这个效果,尝试删除 continue
语句并重新编译。当你再次运行程序时,计数将是错误的,显示找到了 35 个 p,而不是 9 个。
带标签的 continue
语句跳过具有给定标签的外部循环的当前迭代。下面的示例程序 ContinueWithLabelDemo
使用嵌套循环在另一个字符串中搜索子字符串。需要两个嵌套循环:一个用于迭代子字符串,一个用于迭代被搜索的字符串。下面的程序 ContinueWithLabelDemo
使用带标签的形式的 continue 来跳过外部循环的迭代。
class ContinueWithLabelDemo { public static void main(String[] args) { String searchMe = "Look for a substring in me"; String substring = "sub"; boolean foundIt = false; int max = searchMe.length() - substring.length(); test: for (int i = 0; i <= max; i++) { int n = substring.length(); int j = i; int k = 0; while (n-- != 0) { if (searchMe.charAt(j++) != substring.charAt(k++)) { continue test; } } foundIt = true; break test; } System.out.println(foundIt ? "找到了" : "没有找到"); } }
这是程序的输出结果。
找到了
return
语句分支语句的最后一个是return
语句。return
语句退出当前方法,并且控制流返回到调用该方法的位置。return
语句有两种形式:一种返回一个值,一种不返回值。要返回一个值,只需在return
关键字之后放置该值(或计算该值的表达式)。
return ++count;
返回值的数据类型必须与方法声明的返回值类型相匹配。当方法声明为void
时,使用不返回值的return
形式。
return;
类和对象教程将涵盖关于编写方法的所有知识。