C++入门编程----C++运算符(8)
什么是运算符
运算符是让程序执行特定的数学或逻辑操作的符号,用来表示针对数据的特定操作,也称之为操作符。C++运算符分别有算术运算符、关系运算符、逻辑运算符、赋值运算符、位运算符、移位运算符、sizeof运算符、三目运算符、逗号运算符和域解析运算符。
算术运算符
C++中的算术运算符用于进行数学运算,包括加法、减法、乘法、除法和取模等。以下是C++算术运算符的介绍和使用:
- 加法运算符(+) :用于将两个数值相加,或者将一个数值与一个字符串连接起来。例如:
点击查看代码
#include <iostream>
int main() {
int a = 5;
int b = 3;
int sum = a + b; // 8
std::cout << sum;
}
2. 减法运算符(-) :用于从一个数值中减去另一个数值。例如:
点击查看代码
#include <iostream>
int main()
{
int a = 10;
int b = 2;
int d = a - b; // 8
std::cout << d;
}
3. 乘法运算符(*) :用于将两个数组相乘。例如:
点击查看代码
#include <iostream>
int main()
{
int a = 5;
int b = 3;
int product = a * b; // 15
std::cout << product;
}
4. 除法运算符(/):用于将一个数组除以另一个数值。例如:
点击查看代码
#include <iostream>
int main()
{
int a = 10;
int b = 3;
int quotient = a / b; // 3
std::cout << quotient;
}
注意,上述示例,因为计算结果的变量是整型,所以除法运算符会截取整数部分,小数部分会被忽略。如果需要保留小数部分,计算结果的变量可以使用浮点数类型。
5. 取模运算符(%):用于计算两个整数相除的余数。例如:
点击查看代码
#include <iostream>
int main()
{
int a = 10;
int b = 3;
int c = a % b; // 1
std::cout<< c;
}
6. 一元加运算符(+):用于将数值增加1。例如:
点击查看代码
#include <iostream>
int main()
{
int a = 5;
a++; // a的值变为6
std::cout << a << std::endl ;
/*++a; // 7
std::cout << a ;*/
}
7. 一元减运算符(-):用于将数值减少1。例如:
点击查看代码
#include <iostream>
int main()
{
int a = 5;
a--; // 先自减再赋值,a变为4
std::cout << a << std::endl;
/*--a; // 先赋值再自减,a的值变为3
std::cout << a;*/
}
**关系运算符**
C++的关系运算符用于比较两个值之间的关系,如等于、不等于、大于、小于等。以下是C++关系运算符的介绍和使用:
1. 等于运算符(==):用于判断两个值是否相等。例如:
点击查看代码
int main()
{
int a = 5;
int b = 5;
if(a == b)
{
// 如果a等于b,则执行这里的代码
std::cout << "相等";
}
}
2. 不等于运算符(!=) :用于判断两个值是否不相等。例如:
点击查看代码
#include <iostream>
int main()
{
int a = 5;
int b = 3;
if(a != b)
{
// 如果a不等于b,则执行这里的代码
std::cout << "不相等";
}
}
3. 大于运算符(>) :用于判断一个值是否大于另一个值。例如:
点击查看代码
#include <iostream>
int main()
{
int a = 5;
int b = 3;
if(a > b)
{
// 如果a大于b,则执行这里的代码
std::cout << "a大于b";
}
}
4. 小于运算符(<) :用于判断一个值是否小于另一个值。例如:
点击查看代码
#include <iostream>
int main()
{
int a = 3;
int b = 5;
if(a < b)
{
// 如果a小于b,则执行这里的代码
std::cout << "a小于b";
}
}
5. 大于等于运算符(>=) :用于判断一个值是否大于或等于另一个值。例如:
点击查看代码
#include <iostream>
int main()
{
int a = 5;
int b = 3;
if(a >= b)
{
// 如果a大于或等于b,则执行这里的代码
std::cout << "a大于或等于b";
}
}
6. 小于等于运算符(<=):用于判断一个值是否小于或等于另外一个值。例如:
点击查看代码
#include <iostream>
int main()
{
int a = 3;
int b = 5;
if(a < b)
{
// 如果a 小于或等于b,则执行这里的代码
std::cout << "a小于或等于b";
}
}
**逻辑运算符**
C++的逻辑运算符用于对布尔值进行逻辑运算,包括逻辑与(&&)、逻辑或(||)、逻辑非(!)。下面是逻辑运算符的介绍和使用:
1. 逻辑与运算符(&&) :用于判断两个布尔值是否都为真。例如:
点击查看代码
#include <iostream>
int main()
{
bool a = true;
bool b = true;
if(a && b)
{
// 如果a和b都为真,则执行这里的代码
std::cout << "a和b都为真";
}
}
2. 逻辑或运算符(||):用于判断两个布尔值是否有一个为真。例如:
点击查看代码
#include <iostream>
int main()
{
bool a = true;
bool b = false;
if(a || b)
{
// 如果a或b有一个为真,则执行这里的代码
std::cout << "a或b有一个为真";
}
}
3. 逻辑非运算符(!) :用于对一个布尔值进行取反操作。例如:
点击查看代码
#include <iostream>
int main()
{
bool a = false;
if (!a)
{
// 如果a为真,则执行这里的代码
std::cout << "将a取反等于真";
}
}
由于逻辑运算符的优先级低于算术运算符和关系运算符,但高于赋值运算符。因此,在复杂的表达式中,可以使用括号来明确指定运算顺序。
例如:
点击查看代码
#include <iostream>
int main()
{
int a = 5;
int b = 3;
int c = 2;
// 使用括号明确运算顺序,先计算加法再计算关系运算,最后进行逻辑与运算
int sum = (a + b) && (b > c); // 1
if(sum)
{
// 如果sum为真,则执行这里的代码
std:: cout << sum;
}
}
**赋值运算符**
1. 赋值运算符(=) :用于将一个值赋给一个变量。例如:
点击查看代码
#include <iostream>
int main()
{
int a = 5; // 将5赋值给变量a
std::cout << a;
}
2. 加等赋值运算符(+=) :用于将一个值加到一个变量上,并将结果赋值给该变量。例如:
点击查看代码
#include <iostream>
int main()
{
int a = 5;
a += 3; // 将3加到a上,并将结果赋值给a 5 + 3 = 8
std::cout << a;
}
3. 减等赋值运算符(-=):用于从一个变量中减小一个值,并将结果赋值给该变量。例如:
点击查看代码
#include <iostream>
int main()
{
int a = 10;
a -= 3; // 从a中减去3,并将结果7赋值给a;
std::cout << a;
}
4. 乘等赋值运算符(*=) :用于将一个变量的值乘以一个值,并将结果赋值给该变量。例如:
点击查看代码
#include <iostream>
int main()
{
int a = 5;
a *= 3; // 将a的值乘以3,并将结果15赋值给a
std::cout << a;
}
5. 除等赋值运算符(/=):用于将一个变量的值除以一个值,并将结果赋值给该变量。例如:
点击查看代码
#include <iostream>
int main()
{
int a = 10;
a /= 3; // 将a的值除以3,并将结果3赋值给a
std::cout << a;
}
6. 取模等赋值运算符 (%=) :用于计算两个值的余数,并将结果赋值给一个变量。例如:
点击查看代码
#include <iostream>
int main()
{
int a = 10;
a %= 3; // 将a的值除以3的余数1赋值给a
std::cout << a;
}
**位运算符**
C++的位运算符用于对二进制位进行操作。以下是C++位运算符的介绍和使用:
1. 位与运算符(&):用于对两个二进制数进行按位与操作。只有当两个相应的二进制位都为1时,结果的相应位才为1。例如:
点击查看代码
#include <iostream>
int main()
{
int a = 60; // 二进制表示为 0010 1100
int b = 13; // 二进制表示为 0000 1101
int c = a & b; // 结果为0000 1100,即十进制中的12
std::cout << c;
}
2. 位或运算符(|):用于对两个二进制数进行按位或操作。只要两个相应的二进制位中有一个为1,结果的相应位就为1。例如:
点击查看代码
#include <iostream>
int main()
{
int a = 60; // 二进制表示为0010 1100
int b = 13; // 二进制表示为0000 1101
int c = a | b; // 结果为0010 1101,即十进制中的61
std::cout << c;
}
3. 位异或运算符(^) :用于对两个二进制数进行按位异或操作。当两个相应的二进制位不同时,结果的相应位为1。例如:
点击查看代码
#include <iostream>
int main()
{
int a = 60; // 二进制表示为0010 1100
int b = 13; // 二进制表示为0000 1101
int c = a ^ b; // 结果为0010 0001,即十进制中的49
std::cout << c;
}
4. 位非运算符(~):用于对一个二进制数进行按位非操作。当相应的二进制位为1时,结果的相应位为0;当相应的二进制位为0时,结果的相应位为1。例如:
点击查看代码
#include <iostream>
int main()
{
int a = 60; // 二进制表示为0010 1100
int b = ~a; // 二进制表示为1101 0011,即十进制中的-61
std::cout << b;
}
tips:由于位运算符对整数进行低级操作,因此它们经常用于优化性能,特别是在处理网络数据、硬件编程和图形处理等场景。
**移位运算符**
C++中的移位运算符用于对二进制进行左移和右移操作。以下是C++移位运算符的介绍和使用:
1. 左移运算符(<<):用于将一个整数的二进制位向左移动指定的位数。
在左移操作中,左侧的空位将用0来填充。例如:
点击查看代码
#include <iostream>
int main()
{
int a = 5; // 二进制表示为0000 0101
// 向左移动2位
int b = a << 2; // 结果为0001 0100,即十进制中的20
std::cout << b;
}
2. 右移运算符(>>):用于将一个整数的二进制位向右移动指定的位数。
在右移操作中,左侧的空位将根据该数的符合来填充。对于有符合整数,C++采用算术右移,即将最高位(符号位)复制到左侧的空位中。对于无符合整数,左侧的空位将用0来填充。例如:
点击查看代码
#include <iostream>
int main()
{
int a = 20; // 二进制数表示为0010 0100
// 向右移动2位
int b = a >> 2; // 结果为0000 0101 // 即十进制中的5
std::cout << b;
}
tips:使用移位运算符时需要注意数据类型的位数,确保在进行移位操作时不会导致数据溢出或丢失。移位运算符常用于性能敏感的代码中,如低级编程、图形处理、加密等场景。
**sizeof运算符**
sizeof是C++中非常有用的运算符,它用于获取数据类型或对象在内存中所占用的字节数。以下是sizeof运算符的介绍和使用:
基本语法:
sizeof(expression);
使用场景:
1. 获取基本数据类型的大小:例如,sizeof(int) 可以返回int类型在内存中占有的字节数。
2. 获取数组的总大小:例如,sizeof(array)可以返回数组的总字节大小。
3. 获取对象的大小:例如,sizeof(object)可以返回对象在内存中占用的字节数。
应用示例:
点击查看代码
#include <iostream>
int main()
{
int a = 5;
int b[10];
int *p = &a;
std::cout << "Size of int:"<< sizeof(int) <<"bytes\n" ; // 通常是4字节,具体取决于平台
std::cout << "Size of array:"<< sizeof(b) <<"bytes\n" ; // 返回整个数组的大小,通常是40字节。(假设int是4字节)
std::cout << "Size of pointer:"<< sizeof(p) <<"bytes\n" ; // 返回指针的大小,通常是8字节 (假设64位系统)
std::cout << "Size of object:"<< sizeof(a) <<"bytes\n" ; //返回对象的大小, 通常是4字节(假设int是4字节)
}
注意事项:
1. sizeof返回的是size_t类型,这是一种无符号整数类型。
2. sizeof不会计算动态分配的内存。例如,如果你使用new动态地分配了一个数组,那么sizeof将不会计算这部分内存。
3. 对于函数参数,sizeof返回的是参数的类型大小,而不是实际存储在内存中的变量大小。例如,如果函数接受一个指针作为参数,那么sizeof将返回指针的大小,而不是它所指向的数据大小。
**三目运算符**
C++的三目运算符是一种简结的if-else语句,用于根据条件选择两个值中的一个。它的语法如下:
condition ? value_if_true : value_if_false;
语法的condition是一个布尔表达式,如果它的值为true,则放回value_if_true的值;如果它的值为false,则返回value_if_false的值。示例代码如下:
点击查看代码
#include <iostream>
int main()
{
int x = 5;
std::cout << (x > 0 ? "x是正数" : "x不是正数") << std::endl;
}
三目运算符可以用于任何需要选择两个值的情况,不仅仅是if-else语句,还可以使用它来设置变量的值,示例代码如下:
点击查看代码
#include <iostream>
int main()
{
int a = 10;
int b = 12;
int c = (a > b ? a : b);
// 输出结果为12
std::cout<< c;
}
**逗号运算符**
逗号运算符在C++中的特殊的运算符,它允许你在一个语句中执行多个操作,但只返回最后一个操作的结果。逗号运算符的语法如下:
expression1,expression2,...,expressionN;
逗号运算符按照从左到右的顺序依次执行每个表达式,并返回最后一个表达式的值。每个表达式可以是任何合法的C++ 表达式,包括变量赋值、函数调用等,示例代码如下:
点击查看代码
#include <iostream>
int main()
{
// for循环中初始化多个变量
for(int i = 0, j = 0; i < 10; i++,j--)
{
// do something
}
// 执行多个操作
int a = 5;
int b = 10;
int c = (a+=2,b--,a + b); // c的值为16
std::cout << c;
}
**域解析运算符**
C++中的域解析运算符(::) 用于指定类或命名空间的成员。它可以用于访问静态成员、常量成员和非静态成员。
域解析运算符的语法如下:
class_name::member_name;
语法的class_name是类名,member_name是成员名。关于域解析运算符的使用,将会在类或命名空间的内容再作详细讲述。
C++入门编程----C++运算符(8)的更多相关文章
- msp430入门编程05
msp430中C语言的运算符和表达式 msp430中C语言的程序结构06 msp430中C语言的函数及实现07 msp430中C语言操作端口I/O10 msp430中C语言的模块化头文件及实现11 m ...
- Linux学习——shell编程之运算符
shell编程之运算符 一:shell中常见算术运算符号和优先级 二:算术运算符 Shell 变量:是弱类型!不能进行加减乘除!比较麻烦! 例子 :shell变量弱类型 a=11 b=22 echo ...
- Storm实时计算:流操作入门编程实践
转自:http://shiyanjun.cn/archives/977.html Storm实时计算:流操作入门编程实践 Storm是一个分布式是实时计算系统,它设计了一种对流和计算的抽象,概念比 ...
- msp430入门编程50
msp430中项目编程套路 msp430入门编程 msp430入门学习
- msp430入门编程47
msp430中C语言的人机交互--菜单退出 msp430入门编程 msp430入门学习
- msp430入门编程17
msp430中C语言的寄存器操作 msp430入门学习 msp430入门编程
- msp430入门编程27
msp430中C语言开发工具调试程序 msp430入门学习 msp430入门编程
- msp430入门编程26
msp430中C语言开发工具应用 msp430入门学习 msp430入门编程
- msp430入门编程25
msp430中C语言开发环境搭建 msp430入门学习 msp430入门编程
- msp430入门编程24
msp430中C语言的扩展--段的使用 msp430入门学习 msp430入门编程
随机推荐
- Fabric配置块结构解析
本文是区块链浏览器系列的第二篇. 上一篇介绍了交易块中的数据结构,这一篇介绍区块链网络中的配置块数据结构. 这两种区块中数据结构内容的区别主要Payload结构体中的Data域中的内容,接下来将以类图 ...
- .NET Core(C#) PadLeft和PadRight特定格式字符串长度补齐的方法和js中如何填充字符串
.NET Core(C#) 1、PadLeft和PadRight使用说明 两个方法都是对字符串格式化进行补齐填充,PadLeft是左边,而PadRight是右边 '1010'.PadLeft(10,' ...
- PicoPixel贴图查看器
Pico Pixel Pico Pixel是一款纹理查看器,支持查看以下文件格式:TGA,BMP,JPG,DDS,PNG,OpenEXR, KTX, HDR, GIF, TIF. 此外,Pico Pi ...
- 系统Hosts文件原理和应用
Hosts的概念 Hosts是一个没有扩展名的系统文件,可以用记事本等工具打开,其作用就是将一些常用的网址域名与其对应的IP地址建立一个关联"数据库",当用户在浏览器中输入一个需要 ...
- 我手写了一个RPC框架。成功帮助读者斩获字节、阿里等大厂offer。
本着开源精神,本项目README已经同步了英文版本.另外,项目的源代码的注释大部分也修改为了英文. 如访问速度不佳,可放在 Gitee 地址:https://gitee.com/SnailClimb/ ...
- .net5发布到Linux指南
目录 Aspnetcore api 服务发布指南 一. 搭建nginx服务器 下载安装gcc编译库 下载安装pcre正则表达式库 下载安装openssl安全加密库 下载安装zlib解压库 下载解压并编 ...
- 使用Docker部署Tomcat
目录 使用Docker部署Tomcat 1. 获取镜像 2. 第一次启动tomcat 3.带参数启动 4.查看tomcat日志 5.时区问题 使用Docker部署Tomcat 1. 获取镜像 dock ...
- Windows 11 ISO原版镜像文件下载(2024年01月)
Windows 11 (business editions), version 23H2 (x64) - DVD (Chinese-Simplified) 链接:https://pan.baidu.c ...
- SpringBoot 多模块开发 笔记(一)
多模块开发 简易版 dao 层 也可以说是 Mapper 层 web 层 将 controller 放在这一层 还有 统一返回类型 和 自定义异常 也在放在这里 启动类也放在这里 model 层 也就 ...
- Linux(Centos7)升级MySQL 5.7到8.0.31
一.下载MySQL安装包 下载地址:https://downloads.mysql.com/archives/community/ 二.备份 mkdir /home/mysqlback mysqldu ...