C++系列六:一文打尽C++运算符

news2024/11/16 6:47:39

C++运算符

    • 1. 算术运算符
    • 2. 关系运算符
    • 3. 逻辑运算符
    • 4. 按位运算符
    • 5. 取地址运算符
    • 6. 取内容运算符
    • 7. 成员选择符
    • 8. 作用域运算符
    • 9. 总结

1. 算术运算符

算术运算符用于执行基本数学运算,例如加减乘除和取模等操作。下表列出了C++中支持的算术运算符:

运算符描述示例
+ + +加法a + + +b
− - 减法a-b
∗ * 乘法a ∗ * b
/ / /除法a / / /b
% 取模a % b

其中,a和b代表要进行计算的两个变量或值。

(1)加法运算符

加法运算符(+)用于将两个值相加。如果两个操作数都是数字,则它们将被相加。如果其中一个操作数是字符串,则它们将被连接起来。

e.g.

int a = 5;
int b = 3;
int c = a + b; // c的值为8
std::string str1 = "Hello, ";
std::string str2 = "world!";
std::string str3 = str1 + str2; // str3的值为"Hello, world!"

(2)减法运算符

减法运算符(-)用于将第一个操作数减去第二个操作数。

e.g.

int a = 5;
int b = 3;
int c = a - b; // c的值为2

(3)乘法运算符

乘法运算符(*)用于将两个数相乘。

e.g.

int a = 5;
int b = 3;
int c = a * b; // c的值为15

(4)除法运算符

除法运算符(/)用于将第一个操作数除以第二个操作数。

e.g.

int a = 6;
int b = 3;
int c = a / b; // c的值为2

注意,C++中整数除法返回整数结果,即舍去小数部分。

(5)取模运算符

取模运算符(%)返回除法的余数。

e.g.

int a = 7;
int b = 3;
int c = a % b; // c的值为1

2. 关系运算符

关系运算符用于比较两个值并返回布尔值(true或false)。下表列出了C++中支持的关系运算符:

运算符描述示例
==相等a == b
!=不相等a != b
>大于a > b
<小于a < b
>=大于等于a >= b
<=小于等于a <= b

其中,a和b代表要进行比较的两个变量或值。

(1)相等和不相等运算符

相等运算符(==)用于比较两个值是否相等。如果它们相等,则返回true,否则返回false。

e.g.

int a = 5;
int b = 3;
bool c = (a == b); // c的值为false

不相等运算符(!=)用于比较两个值是否不相等。如果它们不相等,则返回true,否则返回false。

e.g.

int a = 5;
int b = 3;
bool c = (a != b); // c的值为true

(2)大于和小于运算符

大于运算符(>)用于比较第一个操作数是否大于第二个操作数。如果是,则返回true,否则返回false。

e.g.

int a = 5;
int b = 3;
bool c = (a > b); // c的值为true

小于运算符(<)用于比较第一个操作数是否小于第二个操作数。如果是,则返回true,否则返回false。

e.g.

int a = 5;
int b = 3;
bool c = (a < b); // c的值为false

(3)大于等于和小于等于运算符

大于等于运算符(>=)用于比较第一个操作数是否大于或等于第二个操作数。如果是,则返回true,否则返回false。

e.g.

int a = 5;
int b = 3;
bool c = (a >= b); // c的值为true

小于等于运算符(<=)用于比较第一个操作数是否小于或等于第二个操作数。如果是,则返回true,否则返回false。

e.g.

int a = 5;
int b = 3;
bool c = (a <= b); // c的值为false

3. 逻辑运算符

逻辑运算符用于执行布尔逻辑操作。下表列出了C++中支持的逻辑运算符:

运算符描述示例
&&逻辑与a && b
||逻辑或a
!逻辑非!a

其中,a和b代表要进行逻辑运算的两个布尔值。

(1)逻辑与运算符

逻辑与运算符(&&)用于检查两个条件是否都为真。只有当两个条件都为真时,才会返回true,否则返回false。

e.g.

bool a = true;
bool b = false;
bool c = (a && b); // c的值为false

(2)逻辑或运算符

逻辑或运算符(||)用于检查两个条件是否至少有一个为真。只有当两个条件都为假时,才会返回false,否则返回true。

e.g.

bool a = true;
bool b = false;
bool c = (a \|\| b); // c的值为true

(3)逻辑非运算符

逻辑非运算符(!)用于翻转一个布尔值。如果输入为true,则返回false,否则返回true。

e.g.

bool a = true;
bool b = !a; // b的值为false

4. 按位运算符

按位运算符用于操作二进制数据。下表列出了C++中支持的按位运算符:

运算符描述示例
&按位与a & b
|按位或a
^按位异或a ^ b
~取反~a
<<左移a << b
>>右移a >> b

其中,a和b代表要进行按位运算的两个整数。

(1)按位与运算符

按位与运算符(&)将两个二进制数的每一位进行比较,并且如果两位都为1,则该位输出1,否则输出0。

e.g.

int a = 5; // 二进制表示为101
int b = 3; // 二进制表示为011
int c = a & b; // c的值为1,二进制表示为001

(2)按位或运算符

按位或运算符(|)将两个二进制数的每一位进行比较,并且如果任意一位为1,则该位输出1,否则输出0。

e.g.

int a = 5; // 二进制表示为101
int b = 3; // 二进制表示为011
int c = a \| b; // c的值为7,二进制表示为111

(3)按位异或运算符

按位异或运算符将两个整数的二进制表示进行“异或”操作,并返回一个新的整数。当两个比特位相同时,该比特位结果为 0,否则为 1。

e.g.

int a = 5; // 二进制 101
int b = 3; // 二进制 011
int c = a ^ b; // 二进制 110 (即十进制 6)

(4)按位取反运算符

按位取反运算符对整数的二进制表示进行取反操作,并返回一个新的整数。当一个比特位为 0 时,结果为 1,否则为 0。

e.g.

int a = 5; // 二进制 101
int b = ~a; // 二进制 010 (即十进制 2)

(5)左移位运算符

左移位运算符将一个整数的二进制表示向左移动指定的位数,并返回一个新的整数。左移 n 位相当于将这个数乘以 2 的 n 次方。

e.g.

int a = 5; // 二进制 101
int b = a << 1; // 二进制 1010 (即十进制 10)

(6)右移位运算符

右移位运算符将一个整数的二进制表示向右移动指定的位数,并返回一个新的整数。右移 n 位相当于将这个数除以 2 的 n 次方。

e.g.

int a = 5; // 二进制 101
int b = a >> 1; // 二进制 10 (即十进制 2)

5. 取地址运算符

C++中,取地址运算符用于获取变量或对象的内存地址,表示为&,并且可以应用于任何变量、指针或对象。使用取地址运算符可以在程序中有效地管理内存和数据结构。

取地址运算符的一般语法如下:

&variable // 获取变量的地址

&object // 获取对象的地址

&type // 获取类型的地址

其中,“variable”表示要获取地址的变量,“object”表示要获取地址的对象,“type”表示要获取地址的类型。

e.g.

int a = 10;
int* ptr = &a; // 使用取地址运算符获取变量a的地址,并将其存储在指针ptr中

cout << "The value of a is: " << a << endl;
cout << "The address of a is: " << &a << endl;
cout << "The value of ptr is: " << ptr << endl;
cout << "The value pointed to by ptr is: " << *ptr << endl;

上述代码首先定义一个整数变量“a”,然后使用取地址运算符&获取它的地址,并将其存储在指针“ptr”中。接下来打印出变量“a”的值和地址、指针“ptr”的值以及指针所指向的值。

输出结果应该与以下内容类似:

The value of a is: 10
The address of a is: 0x7fff5fbff7dc
The value of ptr is: 0x7fff5fbff7dc
The value pointed to by ptr is: 10

从输出结果可以看出,变量“a”的地址与指针“ptr”的值相同,并且指针所指向的值与变量“a”的值相同。

6. 取内容运算符

在C++中,取内容运算符用于获取指针所指向的值,表示为*,并且可以应用于任何指针变量。

取内容运算符的一般语法如下:

*pointer // 获取指针所指向的值

其中,“pointer”表示要获取值的指针变量。

e.g.

int a = 10;
int* ptr = &a; // 使用取地址运算符获取变量a的地址,并将其存储在指针ptr中

cout << "The value of a is: " << a << endl;
cout << "The value pointed to by ptr is: " << *ptr << endl;

上述代码首先定义一个整数变量“a”,然后使用取地址运算符&获取它的地址,并将其存储在指针“ptr”中。接下来打印出变量“a”的值和指针“ptr”所指向的值。

输出:

The value of a is: 10
The value pointed to by ptr is: 10

从输出结果可以看出,指针“ptr”所指向的值与变量“a”的值相同。

7. 成员选择符

在C++中,成员选择符用于访问类的成员变量和成员函数。它表示为.(点号),并且可以应用于任何已定义的对象。使用成员选择符可以操作和修改对象的成员,从而实现面向对象编程。

成员选择符的一般语法如下:

object.member // 访问成员变量或成员函数

其中,“object”表示要访问成员的对象,“member”表示要访问的成员变量或成员函数。

e.g.

class MyClass {
public:
  int myVar;
  void myFunc() {
    cout << "Hello, world!" << endl;
  }
};

MyClass obj; // 创建MyClass对象

obj.myVar = 42; // 使用成员选择符访问myVar成员变量
cout << "The value of myVar is: " << obj.myVar << endl;

obj.myFunc(); // 使用成员选择符调用myFunc成员函数

上述代码首先定义了一个名为“MyClass”的类,该类包含一个整数类型的成员变量“myVar”和一个无参数无返回值的成员函数“myFunc”。接下来创建了一个名为“obj”的MyClass对象,并使用成员选择符访问其成员变量和成员函数。

输出:

The value of myVar is: 42
Hello, world!

从输出结果可以看出,我们成功地使用成员选择符访问了MyClass对象的成员变量和成员函数。

成员选择符 -> 用于访问结构体和类指针所指向的成员。它通常与动态内存分配函数 new 结合使用,来创建对象并进行操作。

e.g.

struct Person {
    std::string name;
    int age;
};

int main() {
    // 创建Person结构体指针p
    Person *p = new Person();

    // 通过成员选择符->访问p所指向的name成员变量
    p->name = "John";

    // 通过成员选择符->访问p所指向的age成员变量
    p->age = 30;

    delete p;
    return 0;
}

上述代码在动态内存中分配了一个新的Person结构体,并将其作为指针p进行访问。然后使用成员选择符 -> 访问指针p所指向的name和age成员。

需要注意的是,当使用普通对象(即不是指针)时,必须使用句点 . 而不是 -> 来访问成员。

8. 作用域运算符

C++的作用域运算符 :: 用于访问类、命名空间、结构体或枚举类型中的成员,以及访问全局变量和函数。

C++可以使用作用域运算符来区分同名的成员或变量,并指定需要访问的特定成员或变量。例如,当一个类的成员与它的父类具有相同的名称时,我们可以使用作用域运算符来访问这个类所定义的成员,而不是其父类中的成员。此外,在多个源文件中实现相同的函数时,可以使用作用域运算符来分隔全局命名空间和局部命名空间。

e.g. 访问类的成员

class A {
public:
    int x;
};

class B : public A {
public:
    int x;
};

int main() {
    B b;
    b.A::x = 5; // 访问A类中的x成员
    b.x = 10;   // 访问B类中的x成员

    return 0;
}

e.g. 访问命名空间中的变量或函数:

namespace MyNamespace {
    int x = 5;

    void printX() {
        std::cout << "x = " << x << std::endl;
    }
}

int main() {
    MyNamespace::printX(); // 访问MyNamespace中的printX函数
    std::cout << "MyNamespace::x = " << MyNamespace::x << std::endl; // 访问MyNamespace中的x变量

    return 0;
}

e.g. 访问全局变量:

int x = 10;

int main() {
    int x = 5;
    std::cout << "局部变量x = " << x << std::endl;

    std::cout << "全局变量x = " << ::x << std::endl; // 访问全局命名
}

9. 总结

20年前学习C++语言的幼稚记录

在这里插入图片描述

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

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

相关文章

Oracle 19C 单机环境升级RU(19.3升级至19.12)

&#x1f4e2;&#x1f4e2;&#x1f4e2;&#x1f4e3;&#x1f4e3;&#x1f4e3; 哈喽&#xff01;大家好&#xff0c;我是【IT邦德】&#xff0c;江湖人称jeames007&#xff0c;10余年DBA及大数据工作经验 一位上进心十足的【大数据领域博主】&#xff01;&#x1f61c;&am…

鸿蒙Hi3861学习五-Huawei LiteOS-M(任务管理)

一、任务简介 关于任务的相关介绍&#xff0c;之前文章有比较详细的介绍&#xff0c;这里不做过多解释&#xff0c;可以参考如下文章&#xff1a;FreeRTOS学习二&#xff08;任务&#xff09;_t_guest的博客-CSDN博客 而LiteOS的主要特性可以总结为如下几点&#xff1a; LiteO…

〖数据挖掘〗weka3.8.6的安装与使用

目录 背景 一、安装 二、使用explorer 1. 介绍 2.打开自带的数据集(Preprocess) 1.打开步骤 2.查看属性和数据编辑 3.classify 4.Cluster 5.Associate 6.Select attributes 7.Visualize 待补充 背景 Weka的全名是怀卡托智能分析环境&#xff08;Waikato Environme…

低代码平台解读—如何不写代码创建表单和维护表单

工作表新建与修改——敲敲云 新建工作表的流程包含 新建工作表/编辑公祖表为工作表添加字段&#xff0c;例如“员工档案”表中有姓名、性别、年龄等字段为字段设置属性工作表布局工作表预览、保存、关闭 1、新建工作表/修改工作表 新建工作表 修改工作表 2、为工作表添加字段 …

c#笔记-定义类

声明类 类可以使用帮助你管理一组相互依赖的数据&#xff0c;来完成某些职责。 类使用class关键字定义&#xff0c;并且必须在所有顶级语句之下。 类的成员只能有声明语句&#xff0c;不能有执行语句。 class Player1 {int Hp;int MaxHp;int Atk;int Def;int Overflow(){if (…

算法记录 | Day55 动态规划

392.判断子序列 思路&#xff1a; 1.确定dp数组&#xff08;dp table&#xff09;以及下标的含义: dp[i][j] 表示以下标i-1为结尾的字符串s&#xff0c;和以下标j-1为结尾的字符串t&#xff0c;相同子序列的长度为dp[i][j]。 2.确定递推公式&#xff1a; if (s[i - 1] t[…

线程同步、生产者消费模型和POSIX信号量

gitee仓库&#xff1a; 1.阻塞队列代码&#xff1a;https://gitee.com/WangZihao64/linux/tree/master/BlockQueue 2.环形队列代码&#xff1a;https://gitee.com/WangZihao64/linux/tree/master/ringqueue 条件变量 概念 概念&#xff1a; 利用线程间共享的全局变量进行同…

单片机c51中断 — 开关状态监测

项目文件 文件 关于项目的内容知识点可以见专栏单片机原理及应用 的第五章&#xff0c;中断 图中 P2.0引脚处接有一个发光二极管 D1&#xff0c;P3.2引脚处接有一个按键。要求分别采用一般方式和中断方式编程实现按键压下一次&#xff0c;D1 的发光状态反转一次的功能。 查询…

从C语言到C++⑦(第二章_类和对象_下篇)初始化列表+explicit+static成员+友元+内部类+匿名对象

目录 1. 构造函数的初始化列表 1.1 初始化列表概念 1.2 初始化列表注意事项 2. 构造函数的explicit关键字 2.1 C语言的隐式类型转换 2.2 explicit 关键字使用 3. static成员 3.1 static的概念 3.2 static成员特性 3.3 static成员使用场景 4. 友元&#xff08;frien…

【Java 基础】类和对象 方法重载详解

《Java 零基础入门到精通》专栏持续更新中。通过本专栏你将学习到 Java 从入门到进阶再到实战的全套完整内容,所有内容均将集中于此专栏。无论是初学者还是有经验的开发人员,都可从本专栏获益。 订阅专栏后添加我微信或者进交流群,进群可找我领取 前端/Java/大数据/Python/低…

Linux 常用命令(1)

文章目录 Linux 常用命令格式 clear 清屏清屏获取当前目录的路径 pwd目录切换命令 cd进入上一级目录进入当前目录的文件夹 ta中(假设这里有一个文件夹ta)进入主目录进入根目录 显示目录内容 ls显示详细信息&#xff0c;包含文件属性显示全部内容&#xff0c;包含隐藏文件&#…

tiechui_lesson07_中断级和自旋锁

一、中断级IRQL 高级别可以打断低级别的调用&#xff0c;同级别不能打断同级别的调用。 中断级在软件层面分为三级&#xff0c;再高的级别是硬件发送的中断。 - 0 pass_level- 1 apc_level- 2 dpc_level 只有硬件中断能打断 1.获取中断级 DbgPrint("当前执行中断级为 %…

无法防范的网络攻击-DDOS

DDoS攻击&#xff08;Distributed Denial of Service Attack&#xff09;是一种网络攻击方式&#xff0c;攻击者通过利用大量的计算机或者网络设备向目标服务器发送大量的请求&#xff0c;使得目标服务器无法正常响应合法用户的请求&#xff0c;从而导致服务不可用或者服务质量…

M302H-YS-Hi3798MV300H/MV310-当贝纯净桌面卡刷固件包

M302H-YS-Hi3798MV300H&#xff0f;MV310-当贝纯净桌面卡刷固件包-内有教程及短接点提示 特点&#xff1a; 1、适用于对应型号的电视盒子刷机&#xff1b; 2、开放原厂固件屏蔽的市场安装和u盘安装apk&#xff1b; 3、修改dns&#xff0c;三网通用&#xff1b; 4、大量精简…

LicheePi4A尝鲜开箱笔记

开发板介绍 LicheePi4A是以 TH1520 主控核心&#xff0c;搭载 4TOPSint8 AI 算力的 NPU&#xff0c;支持双屏 4K 显示输出&#xff0c;支持 4K 摄像头接入&#xff0c;双千兆 POE 网口和多个 USB 接口&#xff0c;音频由 C906 核心处理。 LicheePi4A详细介绍可以在https://wi…

SpringCloud 微服务系列——Spring Cloud Alibaba 微服务工具集

✅作者简介&#xff1a;2022年博客新星 第八。热爱国学的Java后端开发者&#xff0c;修心和技术同步精进。 &#x1f34e;个人主页&#xff1a;Java Fans的博客 &#x1f34a;个人信条&#xff1a;不迁怒&#xff0c;不贰过。小知识&#xff0c;大智慧。 &#x1f49e;当前专栏…

FreeRTOS内核:详解Task各状态(GPT4帮写)

FreeRTOS内核&#xff1a;详解Task各状态&#xff08;GPT4帮写&#xff09; 1. 背景2. Task顶层状态区分3. 运行状态&#xff08;Running&#xff09;4. 非运行状态4.1 阻塞态&#xff08;Blocked&#xff09;&#xff1a;4.2 挂起态&#xff08;Suspended&#xff09;4.3 就绪…

K8s基础8——svc基础使用、应用暴露、iptables代理、ipvs代理

文章目录 一、Service基本了解二、Service定义与创建2.1 相关命令2.2 yaml文件参数大全2.3 创建svc2.3.1 两种创建方式类比2.3.2 验证集群内A应用访问B应用2.3.3 将集群外服务定义为K8s的svc2.3.4 分配多个端口 2.4 常用三种类型2.4.1 ClusterIP&#xff08;集群内部访问&#…

如何解决Redis的双写一致性

目录 1.更新策略2.问题场景3.解决方案 1.更新策略 Redis和MySQL的默认的更新策略是旁路缓存策略&#xff0c;旁路缓存策略又有写策略和读策略 写策略&#xff1a;更新时&#xff0c;先更新数据库&#xff0c;再更新缓存 读策略&#xff1a;读取数据时&#xff0c;如果命中缓…

自动驾驶——Smooth Local Planning

7.1参数曲线 在本模块中&#xff0c;我们将讨论分层运动规划器的最低级别&#xff0c;即局部规划器。作为提醒&#xff0c;局部规划器是分层规划器的一部分&#xff0c;它以无碰撞、高效和舒适的方式执行行为规划器所要求的机动。这导致轨迹&#xff0c;即在给定时间空间中的一…