C++之break / continue陈述九州地址QA98嚸CC语言

break陈述

关键字 break 用于跳出 switch 陈述或跳出回圈。

以下程式示范switch陈述中使用break

复制代码
#include <iostream>
  
int main() {
    int data = 0;
    
    switch (data) {
        case 0:
            std::cout << "0" << std::endl;
            
        case 1: case 2:
            std::cout << "12" << std::endl;
            break;
            
        case 5:
            std::cout << "5" << std::endl;
    }
    
    return 0;
}

编译后执行,结果如下

复制代码
$ g++ u0507_1.cpp
$./a.out 复制代码
0
12
$

此例在case 1、case 2之后使用break陈述

复制代码
case 1: case 2:
    std::cout << "12" << std::endl;
    break;

由于0就符合选项,使得执行完case 0的部份后,由于这里没有break陈述,因此程式会继续执行底下所有的陈述,直到遇上break或到右大括弧为止。

以下程式示范在回圈中使用break

复制代码
#include <iostream>
  
int main() {
    int i;
    for (i = 0; i < 10; i++) {
        if (i == 5) {
            break;
        }
        
        std::cout << i << std::endl;
    }
    
    return 0;
}

编译后执行,结果如下

复制代码
$ g++ u0507_2.cpp
$./a.out 复制代码
0
1
2
3
4
$

这里利用if判断控制变数i是否等于整数5,若是等于5就用break跳出for回圈,因此输出只有印到4为止。

continue陈述

关键字 continue可于回圈中暂停执行一次,然后进行下一轮。回圈碰到continue就像直接跳到回圈最后右大括弧的地方,接着重新进行回圈的结束条件测试,如果测试结果为真,那么回圈继续进行。

举例如下

复制代码
#include <iostream>
  
int main() {
    int i;
    for (i = 0; i < 10; i++) {
        if (i == 5) {
            continue;
        }
        
        std::cout << i << std::endl;
    }
    
    return 0;
}

编译后执行,结果如下

复制代码
示例代码:
$./a.out 复制代码
0
1
2
3
4
6
7
8
9
$

此例在for回圈中测试控制变数i是否等于5,如果等于5就执行continue,因此印出结果中没有数字5。

使用continue需要留意控制变数的调整,我们将上例改用while回圈如下

复制代码
#include <iostream>
  
int main() {
    int i = 0;
    while (i < 10) {
        if (i == 5) {
            continue;
        }
        
        std::cout << i << std::endl;
        
        i++;
    }
    
    return 0;
}

由于控制变数i等于5的时候就会执行continue,但是continue之前没有调整控制变数值,结果造成i永远等于5,回圈结束条件永远为真

复制代码
$ g++ u0508_2.cpp
$./a.out 复制代码
0
1
2
3
4
_

这造成一个无穷回圈(infinite loop) ,如同程式当掉不会结束执行,因此要利用按Ctrl + c或其他方式强制结束程式执行。

相关推荐
郝学胜_神的一滴27 分钟前
CMake 27:缓存变量的特性、语法、类型与实操全解
c++·cmake
kisshyshy34 分钟前
从递归到迭代,一文吃透二叉树的核心知识与 JavaScript 实现
javascript·算法·代码规范
To_OC11 小时前
LC 49 字母异位词分组:想到哈希表很简单,选对 key 才是精髓
javascript·算法·leetcode
用户9385156350717 小时前
从 O(n²) 到 O(nlogn):一文读懂快速排序的“快”与“妙”
javascript·算法
To_OC18 小时前
手写快排次次翻车?别死背快排模板了,这才是面试官想听的底层逻辑
javascript·算法·排序算法
饼干哥哥18 小时前
Reddit VOC调研太慢?搭一个AI专家团队半小时洞察任何品类|以猫用饮水机为例
人工智能·算法·ai编程
地平线开发者19 小时前
Transformer模型部署之性能优化指南
算法
地平线开发者20 小时前
人在途中:从“编译失败”到“模型可落地”——CUDA 自定义算子
算法·自动驾驶
半个落月1 天前
从递归到快速排序:用 JavaScript 把分治思想讲明白
javascript·算法·面试
小月土星1 天前
JavaScript 快速排序:从 pivot、双指针到分治思想
javascript·算法·面试