指挥棒:C++ 与运算符

参考

项目描述
微软C++ 语言文档
搜索引擎BingGoogle
AI 大模型文心一言通义千问讯飞星火认知大模型ChatGPT
C++ Primer Plus (第六版)中文版史蒂芬·普拉达 / 张海龙,袁国忠 译
精通C++(第九版)ISBN:9787302503163
黑马程序员C++
CPlusPlusReference

描述

项目描述
操作系统Windows 10 专业版
编辑器VSCode
编译器g++.exe (x86_64-win32-seh-rev1, Built by MinGW-Builds project) 13.1.0

算术运算符

C++ 作为编程语言提供了各种运算符,这其中包含了算术运算符。算术运算符在编程语言中 用于执行各种数学运算操作。在 C++ 中有如下常用的算术运算符:

项目描述
+正号、加法运算符
-负号、减法运算符
*乘法运算符
/除法运算符
%取模(取余)运算符
++自增运算符
-\-自减运算符

除法运算

C++ 中使用除法运算符进行除法运算时,除法运算符的行为将因操作数(参与运算的数据)的不同而不同,具体如下:

  1. 若两个操作数 均为整数,则除法运算的结果将为 整数
  2. 若两个操作数中 存在浮点数,则除法运算的结果将为 浮点数

举个栗子

#include <iostream>
using namespace std;


int main() {
    cout << 5 / 3 << endl;
    cout << 5.0 / 3 << endl;
    cout << 5.0 / 3.0 << endl;
    
    system("pause");
    return 0;
}

执行结果

1
1.66667
1.66667
请按任意键继续. . .

注:

  1. 除法操作符作用的两个操作数若为整数时,除法运算的结果将为整数。该 整数并不是由实际计算结果四舍五入后得来的,而是直接去除小数点及小数部分 后所剩余的部分 。

  2. 在表达式中,除数不能为零。否则,C++ 将为此抛出异常。

取模运算

取模运算与除法运算的区别在于,除法运算的结果值为 两数相除的结果,而取模运算的结果值为 两数相除所得到的余数

举个栗子

#include <iostream>
using namespace std;


int main() {
    cout << 5 % 3 << endl;
    cout << 0 % 9 << endl;
    cout << 36 % 6 << endl;
    
    system("pause");
    return 0;
}

执行结果

2
0
0
请按任意键继续. . .

注:

  1. 取模运算符的操作数不可为浮点数,仅能为整数。否则,C++ 将为此抛出异常。

  2. 取模运算符的操作数中若存在负数,则结果值的正负性满足如下规则:
    A % B 而言,取模运算的结果值的正负性与操作数 A 相同。

举个栗子

#include <iostream>
using namespace std;


int main() {
    cout << -5 % 3 << endl;
    cout << 8 % -20 << endl;
    cout << -3 % -3 << endl;
    cout << -2 % -3 << endl;
    
    system("pause");
    return 0;
}

执行结果

对于 C++ 来说,-00 是相同的。故 -3 % -3 的输出结果为 0

-2
8
0
-2
请按任意键继续. . .

复合赋值运算符

在 C++ 中,+=-= 等运算符被称为复合赋值运算符(Compound Assignment Operators)。复合赋值运算符 结合了算术运算符与赋值运算符的功能,可以用来简化对变量值的修改操作。

C++ 所支持的常用复合赋值运算符

赋值运算符功能示例等效于
+=加法赋值运算符,将右侧的值加到左侧的变量上a += b;a = a + b;
-=减法赋值运算符,从左侧的变量中减去右侧的值a -= b;a = a - b;
*=乘法赋值运算符,将左侧的变量与右侧的值相乘a *= b;a = a * b;
/=除法赋值运算符,将左侧的变量除以右侧的值a /= b;a = a / b;
%=取模赋值运算符,将左侧的变量取模右侧的值a %= b;a = a % b;

举个栗子

#include <iostream>
using namespace std;


int main() {
    int a = 97, b = 98, c = 99;
    a += 9;
    b %= 7;
    c /= 33;
    
    cout << "97 + 9 = " << a << endl;
    cout << "98 % 7 = " << b << endl;
    cout << "99 / 33 = " << c << endl;
    
    system("pause");
    return 0;
}

执行效果

97 + 9 = 106
98 % 7 = 0
99 / 33 = 3
请按任意键继续. . .

自增运算符

使用自增运算符可以将类似 a = a + 1 的语句简化为 a++++a。其中,a++ 中的 ++ 被称为后置自增运算符;++a 中的 ++ 被称为前置自增运算符。
前置自增与后置自增的区别在于,两者所作用的操作数自增的时机不同。前置自增运算过程中操作数的自增时机 在包含自增语句的表达式执行完毕前完成自增,而后置自增运算过程总操作数的自增时机则 在包含自增语句的表达式执行完毕后完成自增。对此,请参考如下示例:

举个栗子

#include <iostream>
using namespace std;


int main() {
    int num = 3;
    // 3 * 6 + 3 * 6 = 36
    cout << 3 * 6 + num++ * 6 << endl;

    num = 3;
    
    // 3 * 6 + 4 * 6 = 42
    cout << 3 * 6 + ++num * 6 << endl;

    system("pause");
    return 0;
}

执行结果

36
42
请按任意键继续. . .

自减运算符

自减运算符与自增运算符的类似,只是自增运算符最终将实现操作数的 自增,而自减运算符最终将实现操作数的 自减

比较运算符

比较运算符作用于两个操作数,运算结果为布尔值。C++ 支持如下比较运算符:

项目描述
==判断两个操作数是否相等,若两者相等则运算结果为 true,否则为 false
!=判断两个操作数是否不相等,若两者不相等则运算结果为 true,否则为 false
>判断左操作数是否大于右操作数,若是则运算结果为 true,否则为 false
<判断左操作数是否小于右操作数,若是则运算结果为 true,否则为 false
>=判断左操作数是否大于或等于右操作数,若是则运算结果为 true,否则为 false
<=判断左操作数是否小于或等于右操作数,若是则运算结果为 true,否则为 false

举个栗子

#include <iostream>
using namespace std;


int main() {
    cout << (3 > 6) << endl;
    cout << (6 >= 6) << endl;
    cout << ('3' == 3) << endl;
    system("pause");
}

执行结果

0
1
0
请按任意键继续. . .

逻辑运算符

概念

C++ 中的逻辑运算符是用于执行逻辑运算的特殊运算符,逻辑运算符操作 布尔值(true 或 false)布尔表达式(能够产生布尔值的表达式,含有逻辑运算符的表达式也是布尔表达式)以产生布尔结果。逻辑运算符主要用于 控制流程条件测试

C++ 中存在三种逻辑运算符,具体如下:

逻辑运算符描述称呼别称
!操作数将被隐式转换为 Bool 类型。 如果转换结果为 false,则运算结果为 true;反之,结果为 false逻辑非
&&操作数将被隐式转换为 Bool 类型。如果两个操作数的转换结果均为 true,则运算结果为 true,否则为 false逻辑与短路与
||操作数将被隐式转换为 Bool 类型。如果两个操作数的转换结果中存在 true,则运算结果为 true,否则为 false逻辑或短路或

举个栗子

由于运算符之间存在 优先级关系,没有考虑到不同运算符之间的优先级可能会导致异常的产生。由于 << 运算符的优先级高于大部分逻辑运算符,故在下述示例中需要 使用括号将逻辑运算表达式括起以提高被包裹表达式的优先级,使得程序能够正常运行。

#include <iostream>
using namespace std;


int main() {
    cout << !true << endl;
    cout << (true && false) << endl;
    cout << (true && true) << endl;
    cout << (666 || 0) << endl;
    
    system("pause");
    return 0;
}

执行结果

0
0
1
1
请按任意键继续. . .

注:

在 C++ 中,所有的非零值转换为布尔值的结果均为 true;零转换为布尔值的结果为 false

短路

逻辑与运算符仅当前一个操作数的转换结果为 true 时,才会计算后一个个操作数。
逻辑或运算符仅当前一个操作数的转换结果为 false 时,才会计算后一个操作数。

逻辑与运算符的第前一个操作数的转换结果为 false 以及逻辑或运算符的前一个操作数为 true 时,都将发生 短路,即后一个操作数不会被计算。

举个栗子

#include <iostream>
using namespace std;


int main() {
    int num = 1;
    cout << (true || num++) << endl;
    cout << num << endl;
    cout << (false && num++) << endl;
    cout << num << endl;
    
    system("pause");
    return 0;
}

执行结果

在上述代码执行过程中,变量 num 被初始化为 1 后保存的值未曾发生过改变。原因是逻辑运算过程中发生了短路,num++ 均未被执行。

1
1
0
1
请按任意键继续. . .
为什么需要短路机制?

短路机制 有助于提高程序的效率,在某些情况下可以防止出现不必要的计算,尤其是当条件表达式包含了复杂的计算或者函数调用时。但要注意,短路机制可能导致部分表达式 永远不被执行,这 可能会脱离程序的设计初衷。因此,在设计逻辑运算的过程中,需要 仔细考虑条件表达式的逻辑和代码执行的顺序,以确保程序按照开发者的意愿运行。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

BinaryMoon

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值