C++重新入门-C++运算符

目录

1. 算术运算符

2. 关系运算符

3.逻辑运算符

4.位运算符

5.赋值运算符

6.杂项运算符

7.C++ 中的运算符优先级


运算符是一种告诉编译器执行特定的数学或逻辑操作的符号。C++ 内置了丰富的运算符,并提供了以下类型的运算符:

  • 算术运算符
  • 关系运算符
  • 逻辑运算符
  • 位运算符
  • 赋值运算符
  • 杂项运算符

本章将逐一介绍算术运算符、关系运算符、逻辑运算符、位运算符、赋值运算符和其他运算符。

1. 算术运算符

下表显示了 C++ 支持的算术运算符。

假设变量 A 的值为 10,变量 B 的值为 20,则:

实例

请看下面的实例,了解 C++ 中可用的算术运算符。

复制并粘贴下面的 C++ 程序到 test.cpp 文件中,编译并运行程序。

#include <iostream>
using namespace std;int main()
{int a = 21;int b = 10;int c;c = a + b;cout << "Line 1 - c 的值是 " << c << endl ;c = a - b;cout << "Line 2 - c 的值是 " << c << endl ;c = a * b;cout << "Line 3 - c 的值是 " << c << endl ;c = a / b;cout << "Line 4 - c 的值是 " << c << endl ;c = a % b;cout << "Line 5 - c 的值是 " << c << endl ;int d = 10;   //  测试自增、自减c = d++;cout << "Line 6 - c 的值是 " << c << endl ;d = 10;    // 重新赋值c = d--;cout << "Line 7 - c 的值是 " << c << endl ;return 0;
}

 当上面的代码被编译和执行时,它会产生以下结果:

Line 1 - c 的值是 31
Line 2 - c 的值是 11
Line 3 - c 的值是 210
Line 4 - c 的值是 2
Line 5 - c 的值是 1
Line 6 - c 的值是 10
Line 7 - c 的值是 10

2. 关系运算符

C++中的关系运算符用于比较两个值之间的关系,并返回一个布尔值(true或false)表示比较的结果。下面是C++中常用的关系运算符及其含义:

  1. ==(等于):用于检查两个值是否相等。如果两个值相等,则返回true;否则返回false。

  2. !=(不等于):用于检查两个值是否不相等。如果两个值不相等,则返回true;否则返回false。

  3. <(小于):用于检查左操作数是否小于右操作数。如果左操作数小于右操作数,则返回true;否则返回false。

  4. >(大于):用于检查左操作数是否大于右操作数。如果左操作数大于右操作数,则返回true;否则返回false。

  5. <=(小于等于):用于检查左操作数是否小于或等于右操作数。如果左操作数小于或等于右操作数,则返回true;否则返回false。

  6. >=(大于等于):用于检查左操作数是否大于或等于右操作数。如果左操作数大于或等于右操作数,则返回true;否则返回false。

 

#include <iostream>
using namespace std;int main() {int A = 5;int B = 10;// 等于cout << "A == B: " << (A == B) << endl; // 输出 0(false)// 不等于cout << "A != B: " << (A != B) << endl; // 输出 1(true)// 小于cout << "A < B: " << (A < B) << endl;   // 输出 1(true)// 大于cout << "A > B: " << (A > B) << endl;   // 输出 0(false)// 小于等于cout << "A <= B: " << (A <= B) << endl; // 输出 1(true)// 大于等于cout << "A >= B: " << (A >= B) << endl; // 输出 0(false)return 0;
}

在这个例子中,变量A的值为5,变量B的值为10。通过使用不同的关系运算符,我们可以比较这两个变量的值,并输出比较结果。

3.逻辑运算符

逻辑运算符用于在布尔表达式中组合和操作布尔值。C++中常用的逻辑运算符有以下几种:

  1. &&(逻辑与):如果两个操作数都为true,则结果为true;否则为false。

  2. ||(逻辑或):如果两个操作数中至少有一个为true,则结果为true;否则为false。

  3. !(逻辑非):用于取反操作,如果操作数为true,则结果为false;如果操作数为false,则结果为true。

#include <iostream>
using namespace std;int main() {bool A = true;bool B = false;// 逻辑与cout << "A && B: " << (A && B) << endl; // 输出 0(false)// 逻辑或cout << "A || B: " << (A || B) << endl; // 输出 1(true)// 逻辑非cout << "!A: " << (!A) << endl;         // 输出 0(false)cout << "!B: " << (!B) << endl;         // 输出 1(true)return 0;
}

 在这个例子中,我们定义了两个布尔变量A和B,分别赋值为true和false。然后我们使用逻辑运算符来组合和操作这两个布尔值,并输出结果。

4.位运算符

位运算符用于对整数的二进制表示进行位操作。C++中常用的位运算符有以下几种:

  1. &(按位与):对两个操作数的每一位执行逻辑与操作,只有当两个操作数的对应位都为1时,结果的对应位才为1,否则为0。

  2. |(按位或):对两个操作数的每一位执行逻辑或操作,只要两个操作数的对应位中至少有一个为1,结果的对应位就为1,否则为0。

  3. ^(按位异或):对两个操作数的每一位执行异或操作,只有当两个操作数的对应位不相同时,结果的对应位才为1,否则为0。

  4. ~(按位取反):对操作数的每一位执行取反操作,将1变为0,将0变为1。

  5. <<(左移):将操作数的所有位向左移动指定的位数,低位补0。

  6. >>(右移):将操作数的所有位向右移动指定的位数,高位根据移位运算符的类型(算术右移或逻辑右移)补0或保持符号位不变。

#include <iostream>
using namespace std;int main() {int A = 5; // 二进制表示为 101int B = 3; // 二进制表示为 011// 按位与cout << "A & B: " << (A & B) << endl; // 输出 1(二进制 001)// 按位或cout << "A | B: " << (A | B) << endl; // 输出 7(二进制 111)// 按位异或cout << "A ^ B: " << (A ^ B) << endl; // 输出 6(二进制 110)// 按位取反cout << "~A: " << (~A) << endl;       // 输出 -6// 左移cout << "A << 1: " << (A << 1) << endl; // 输出 10(二进制 1010)// 右移cout << "B >> 1: " << (B >> 1) << endl; // 输出 1(二进制 001)return 0;
}

 在这个例子中,我们定义了两个整数变量A和B,分别赋值为5和3,其二进制表示分别为101和011。然后我们使用位运算符对这两个整数进行位操作,并输出结果。

5.赋值运算符

赋值运算符用于将右侧的值赋给左侧的操作数。在C++中,常见的赋值运算符是=。除了简单的赋值运算符之外,还有一些复合赋值运算符,它们将算术运算符与赋值操作结合起来,如+=-=*=/=等。

以下是一些常见的赋值运算符及其示例:

#include <iostream>
using namespace std;int main()
{int a = 21;int c ;c =  a;cout << "Line 1 - =  运算符实例,c 的值 = : " <<c<< endl ;c +=  a;cout << "Line 2 - += 运算符实例,c 的值 = : " <<c<< endl ;c -=  a;cout << "Line 3 - -= 运算符实例,c 的值 = : " <<c<< endl ;c *=  a;cout << "Line 4 - *= 运算符实例,c 的值 = : " <<c<< endl ;c /=  a;cout << "Line 5 - /= 运算符实例,c 的值 = : " <<c<< endl ;c  = 200;c %=  a;cout << "Line 6 - %= 运算符实例,c 的值 = : " <<c<< endl ;c <<=  2;cout << "Line 7 - <<= 运算符实例,c 的值 = : " <<c<< endl ;c >>=  2;cout << "Line 8 - >>= 运算符实例,c 的值 = : " <<c<< endl ;c &=  2;cout << "Line 9 - &= 运算符实例,c 的值 = : " <<c<< endl ;c ^=  2;cout << "Line 10 - ^= 运算符实例,c 的值 = : " <<c<< endl ;c |=  2;cout << "Line 11 - |= 运算符实例,c 的值 = : " <<c<< endl ;return 0;
}

6.杂项运算符

杂项运算符包括了一些在C++中不容易归类到其他类别的运算符。

  1. sizeof:用于获取变量或类型的大小(以字节为单位)。

  2. ?:(条件运算符):也称为三元运算符,用于根据条件选择两个表达式之一的值。

  3. ,(逗号运算符):用于在一个语句中顺序执行多个表达式,并返回最后一个表达式的值。

  4. .->(成员访问运算符):用于访问结构体或类的成员。

  5. typeid:用于返回表达式的运行时类型信息。

  6. static_cast, dynamic_cast, const_cast, reinterpret_cast:用于类型转换。

  7. newdelete:用于动态内存分配和释放。

  8. ::(作用域解析运算符):用于标识命名空间成员或全局作用域中的变量或函数。

  9. sizeof...(参数包长度运算符):用于获取参数包的长度。

  10. #(预处理运算符):用于在预处理阶段操作字符串。

这些运算符在不同的情境下有不同的用途,它们为C++提供了更大的灵活性和功能。在实际编程中,它们经常被使用到。

 

#include <iostream>
using namespace std;int main() {int array[5];cout << "Size of array: " << sizeof(array) << " bytes" << endl; // 输出数组的大小(以字节为单位)cout << "Size of int: " << sizeof(int) << " bytes" << endl;       // 输出整型变量的大小(以字节为单位)return 0;
}#include <iostream>
using namespace std;int main() {int a = 10;int b = 5;int max = (a > b) ? a : b; // 如果a大于b,返回a的值;否则返回b的值cout << "Max value: " << max << endl; // 输出10return 0;
}#include <iostream>
using namespace std;int main() {int a = 5, b = 10, c = 15;// 使用逗号运算符初始化多个变量int sum = (a += 2, b += 3, c += 4); // 逗号运算符按顺序执行表达式,并返回最后一个表达式的值cout << "Sum: " << sum << endl;     // 输出最后一个表达式的值,即 c += 4 的结果// 输出修改后的变量值cout << "a: " << a << endl; // 输出 7cout << "b: " << b << endl; // 输出 13cout << "c: " << c << endl; // 输出 19return 0;
}#include <iostream>
using namespace std;struct Point {int x;int y;
};int main() {Point p1;p1.x = 10;p1.y = 20;cout << "Point p1: (" << p1.x << ", " << p1.y << ")" << endl; // 输出p1的坐标值return 0;
}#include <iostream>
using namespace std;#define PI 3.14159int main() {cout << "Value of PI: " << PI << endl; // 输出宏定义PI的值return 0;
}

 

7.C++ 中的运算符优先级

算符的优先级确定表达式中项的组合。这会影响到一个表达式如何计算。某些运算符比其他运算符有更高的优先级,例如,乘除运算符具有比加减运算符更高的优先级。

例如 x = 7 + 3 * 2,在这里,x 被赋值为 13,而不是 20,因为运算符 * 具有比 + 更高的优先级,所以首先计算乘法 3*2,然后再加上 7。

下表将按运算符优先级从高到低列出各个运算符,具有较高优先级的运算符出现在表格的上面,具有较低优先级的运算符出现在表格的下面。在表达式中,较高优先级的运算符会优先被计算。

 

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/2779548.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

高仿原神官网UI 纯html源码

高仿原神官网UI源码介绍 如果您希望打造一个与原神官方网站相似的外观和用户体验&#xff0c;但又不想使用复杂的框架或模板&#xff0c;那么我们的高仿原神官网UI源码将是一个完美的选择。它采用纯HTML5构建&#xff0c;无需任何额外的CSS或JavaScript库支持&#xff0c;即可…

C#,巴都万数列(Padonve Number)的算法与源代码

1 巴都万数列&#xff08;Padovan Sequence&#xff09; 巴都万数列&#xff08;Padovan Sequence&#xff09;是一个整数数列。 首数个值为1, 1, 1, 2, 2, 3, 4, 5, 7, 9, 12, 16, 21, 28, 37 ... 此数列以建筑师理察巴都万命名&#xff0c;他的论文Dom&#xff08;1994年&a…

3D高斯溅射:面向三维场景的实时渲染技术

1. 前言 高斯溅射技术【1】一经推出&#xff0c;立刻引起学术界和工业界的广泛关注。相比传统的隐式神经散射场渲染技术&#xff0c;高斯溅射依托椭球空间&#xff0c;显性地表示多目图像的三维空间关系&#xff0c;其计算效率和综合性能均有较大的提升&#xff0c;且更容易理…

反应式编程

反应式编程 前言1 反应式编程概览2 初识 Reactor2.1 绘制反应式流图2.2 添加 Reactor 依赖 3.使用常见的反应式操作3.1 创建反应式类型3.2 组合反应式类型3.3 转换和过滤反应式流3.4 在反应式类型上执行逻辑操作 总结 前言 你有过订阅报纸或者杂志的经历吗?互联网的确从传统的…

EasyExcel动态列导出

测试代码地址&#xff1a;https://gitee.com/wangtianwen1996/cento-practice/tree/master/src/test/java/com/xiaobai/easyexcel/dynamiccolumn 官方文档&#xff1a;https://easyexcel.opensource.alibaba.com/docs/2.x/quickstart/write 一、实现方式 1、根据需要导出的列…

C/C++模板初阶

目录 1. 泛型编程 2. 函数模板 2.1 函数模板概念 2.1 函数模板格式 2.3 函数模板的原理 2.4 函数模板的实例化 2.5 模板参数的匹配原则 3. 类模板 3.1 类模板的定义格式 3.2 类模板的实例化 1. 泛型编程 如何实现一个通用的交换函数呢&#xff1f; void Swap(int&…

Github 2024-02-11 开源项目日报Top10

根据Github Trendings的统计&#xff0c;今日(2024-02-11统计)共有10个项目上榜。根据开发语言中项目的数量&#xff0c;汇总情况如下&#xff1a; 开发语言项目数量Python项目4非开发语言项目2C项目1C项目1Solidity项目1JavaScript项目1Rust项目1HTML项目1 免费服务列表 | f…

树状菜单(利用映射-bootstrap+jQuery实现折叠功能)

效果&#xff08;默认全部展开&#xff09;&#xff1a; <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8" /><meta name"viewport" content"widthdevice-width, initial-scale1.0" /><…

【大厂AI课学习笔记】【1.6 人工智能基础知识】(3)神经网络

深度学习是机器学习中一种基于对数据进行表征学习的算法。观测值(例如一幅草莓照片)可以使用 多种方式来表示&#xff0c;如每个像素强度值的向量&#xff0c;或者更抽象地表示成一系列边、特定形状的区域等。 深度学习的最主要特征是使用神经网络作为计算模型。神经网络模型 …

《Python 网络爬虫简易速速上手小册》第10章:未来展望与新兴技术(2024 最新版)

文章目录 10.1 机器学习在爬虫中的应用10.1.1 重点基础知识讲解10.1.2 重点案例&#xff1a;使用机器学习进行自动化内容抽取10.1.3 拓展案例 1&#xff1a;利用深度学习识别复杂的网页结构10.1.4 拓展案例 2&#xff1a;机器学习辅助的动态反反爬虫策略 10.2 处理 JavaScript …

Python操作MySQL基础

除了使用图形化工具以外&#xff0c;我们也可以使用编程语言来执行SQL从而操作数据库。在Python中&#xff0c;使用第三方库: pymysql来完成对MySQL数据库的操作。 安装第三方库pymysql 使用命令行,进入cmd&#xff0c;输入命令pip install pymysql. 创建到MySQL的数据库连接…

企业飞书应用机器人,使用python发送图文信息到群

企业飞书应用的自动化&#xff0c;需要创建企业应用&#xff0c;应用开通机器人能力&#xff0c;并获取机器人所需的app_id与app_secret&#xff08;这一部分大家可以在飞书的控制台获取&#xff1a;https://open.feishu.cn/api-explorer/&#xff09; 文章目录 步骤1&#xff…

【开源】基于JAVA+Vue+SpringBoot的公司货物订单管理系统

目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 客户管理模块2.2 商品维护模块2.3 供应商管理模块2.4 订单管理模块 三、系统展示四、核心代码4.1 查询供应商信息4.2 新增商品信息4.3 查询客户信息4.4 新增订单信息4.5 添加跟进子订单 五、免责说明 一、摘要 1.1 项目…

提高效率!企业短信通道账单拆分一键处理,干货分享

**提高效率!企业短信通道账单拆分一键处理,干货分享! 昨天从硬盘里看到2019年写的 账单拆分案列,这里分享给大家 文章目录 **提高效率!企业短信通道账单拆分一键处理,干货分享!背景企业短信通道账单展示干货来了用python拆分短信账号最后短信通道账单拆分后的处理。最后…

微信小程序上传代码教程

文章目录 概要整体架构流程技术名词解释技术细节小结 概要 小程序上传代码到gogs上面来 整体架构流程 小程序也要远程连接仓库&#xff0c;实现代码上传 技术名词解释 微信开发者工具gogs 技术细节 连接gogs仓库地址 微信小程序需要head将本地代码和gogs代码同步 小结 …

hexo 博客搭建以及踩雷总结

搭建时的坑 文章置顶 安装一下这个依赖 npm install hexo-generator-topindex --save然后再文章的上面设置 top: number&#xff0c;数字越大&#xff0c;权重越大&#xff0c;也就是越靠顶部 hexo 每次推送 nginx 都访问不到 宝塔自带的 nginx 的 config 里默认的角色是 …

LayUI中表格树折叠 --

1、先将插件源码进行下载&#xff0c;新建 tableTree.js 文件&#xff0c;将源码放进去 2、将 tableTree.js 文件 配置之后&#xff0c;在需要使用的页面进行引入&#xff1a; layui.define(["tableTree"],function (exports) {var tableTree layui.tableTree;// …

RabbitMQ之五种消息模型

1、 环境准备 创建Virtual Hosts 虚拟主机&#xff1a;类似于mysql中的database。他们都是以“/”开头 设置权限 2. 五种消息模型 RabbitMQ提供了6种消息模型&#xff0c;但是第6种其实是RPC&#xff0c;并不是MQ&#xff0c;因此不予学习。那么也就剩下5种。 但是其实3、4…

python执行js代码

1. Python执行JavaScript代码 假如在爬虫逆向分析时&#xff0c;发现某个js加密算法比较繁琐&#xff0c;用Python还原同样的算法比较费劲。此时&#xff0c;可以不必使用Python还原&#xff0c;而是利用Python去直接调用JavaScript中定义的功能。 想实现Python调用JavaScrip…

svg基础(八)滤镜-feTurbulence(湍流)

feTurbulence&#xff1a;湍流滤镜 湍流滤镜&#xff0c;不稳定气流&#xff0c;能够实现半透明的烟熏或波状图像。 通常用于实现一些特殊的纹理。滤镜利用 Perlin 噪声函数创建了一个图像。噪声在模拟云雾效果时非常有用&#xff0c;能产生非常复杂的质感&#xff0c;利用它可…