什么是运算符
运算符是让程序执行特定的数学或逻辑操作的符号,用来表示针对数据的特定操作,也称之为操作符。C++运算符分别有算术运算符、关系运算符、逻辑运算符、赋值运算符、位运算符、移位运算符、sizeof运算符、三目运算符、逗号运算符和域解析运算符。
算术运算符
C++中的算术运算符用于进行数学运算,包括加法、减法、乘法、除法和取模等。以下是C++算术运算符的介绍和使用:
- 加法运算符(+) :用于将两个数值相加,或者将一个数值与一个字符串连接起来。例如:
点击查看代码
#include
int main() {
int a = 5;
int b = 3;
int sum = a + b; // 8
std::cout
2. 减法运算符(-) :用于从一个数值中减去另一个数值。例如:
点击查看代码
#include
int main()
{
int a = 10;
int b = 2;
int d = a - b; // 8
std::cout
3. 乘法运算符(*) :用于将两个数组相乘。例如:
点击查看代码
#include
int main()
{
int a = 5;
int b = 3;
int product = a * b; // 15
std::cout
4. 除法运算符(/):用于将一个数组除以另一个数值。例如:
点击查看代码
#include
int main()
{
int a = 10;
int b = 3;
int quotient = a / b; // 3
std::cout
注意,上述示例,因为计算结果的变量是整型,所以除法运算符会截取整数部分,小数部分会被忽略。如果需要保留小数部分,计算结果的变量可以使用浮点数类型。
5. 取模运算符(%):用于计算两个整数相除的余数。例如:
点击查看代码
#include
int main()
{
int a = 10;
int b = 3;
int c = a % b; // 1
std::cout
6. 一元加运算符(+):用于将数值增加1。例如:
点击查看代码
#include
int main()
{
int a = 5;
a++; // a的值变为6
std::cout
7. 一元减运算符(-):用于将数值减少1。例如:
点击查看代码
#include
int main()
{
int a = 5;
a--; // 先自减再赋值,a变为4
std::cout
**关系运算符**
C++的关系运算符用于比较两个值之间的关系,如等于、不等于、大于、小于等。以下是C++关系运算符的介绍和使用:
1. 等于运算符(==):用于判断两个值是否相等。例如:
点击查看代码
int main()
{
int a = 5;
int b = 5;
if(a == b)
{
// 如果a等于b,则执行这里的代码
std::cout
2. 不等于运算符(!=) :用于判断两个值是否不相等。例如:
点击查看代码
#include
int main()
{
int a = 5;
int b = 3;
if(a != b)
{
// 如果a不等于b,则执行这里的代码
std::cout
3. 大于运算符(>) :用于判断一个值是否大于另一个值。例如:
点击查看代码
#include
int main()
{
int a = 5;
int b = 3;
if(a > b)
{
// 如果a大于b,则执行这里的代码
std::cout
4. 小于运算符(
#include
int main()
{
int a = 3;
int b = 5;
if(a
5. 大于等于运算符(>=) :用于判断一个值是否大于或等于另一个值。例如:
点击查看代码
#include
int main()
{
int a = 5;
int b = 3;
if(a >= b)
{
// 如果a大于或等于b,则执行这里的代码
std::cout
6. 小于等于运算符(
#include
int main()
{
int a = 3;
int b = 5;
if(a
**逻辑运算符**
C++的逻辑运算符用于对布尔值进行逻辑运算,包括逻辑与(&&)、逻辑或(||)、逻辑非(!)。下面是逻辑运算符的介绍和使用:
1. 逻辑与运算符(&&) :用于判断两个布尔值是否都为真。例如:
点击查看代码
#include
int main()
{
bool a = true;
bool b = true;
if(a && b)
{
// 如果a和b都为真,则执行这里的代码
std::cout
2. 逻辑或运算符(||):用于判断两个布尔值是否有一个为真。例如:
点击查看代码
#include
int main()
{
bool a = true;
bool b = false;
if(a || b)
{
// 如果a或b有一个为真,则执行这里的代码
st服务器托管网d::cout
3. 逻辑非运算符(!) :用于对一个布尔值进行取反操作。例如:
点击查看代码
#include
int main()
{
bool a = false;
if (!a)
{
// 如果a为真,则执行这里的代码
std::cout
由于逻辑运算符的优先级低于算术运算符和关系运算符,但高于赋值运算符。因此,在复杂的表达式中,可以使用括号来明确指定运算顺序。
例如:
点击查看代码
#include
int main()
{
int a = 5;
int b = 3;
int c = 2;
// 使用括号明确运算顺序,先计算加法再计算关系运算,最后进行逻辑与运算
int sum = (a + b) && (b > c); // 1
if(sum)
{
// 如果sum为真,则执行这里的代码
std:: cout
**赋值运算符**
1. 赋值运算符(=) :用于将一个值赋给一个变量。例如:
点击查看代码
#include
int main()
{
int a = 5; // 将5赋值给变量a
std::cout
2. 加等赋值运算符(+=) :用于将一个值加到一个变量上,并将结果赋值给该变量。例如:
点击查看代码
#include
int main()
{
int a = 5;
a += 3; // 将3加到a上,并将结果赋值给a 5 + 3 = 8
std::cout
3. 减等赋值运算符(-=):用于从一个变量中减小一个值,并将结果赋值给该变量。例如:
点击查看代码
#include
int main()
{
int a = 10;
a -= 3; // 从a中减去3,并将结果7赋值给a;
std::cout
4. 乘等赋值运算符(*=) :用于将一个变量的值乘以一个值,并将结果赋值给该变量。例如:
点击查看代码
#include
int main()
{
int a = 5;
a *= 3; // 将a的值乘以3,并将结果15赋值给a
std::cout
5. 除等赋值运算符(/=):用于将一个变量的值除以一个值,并将结果赋值给该变量。例如:
点击查看代码
#include
int main()
{
int a = 10;
a /= 3; // 将a的值除以3,并将结果3赋值给a
std::cout
6. 取模等赋值运算符 (%=) :用于计算两个值的余数,并将结果赋值给一个变量。例如:
点击查看代码
#include
int main()
{
int a = 10;
a %= 3; // 将a的值除以3的余数1赋值给a
std::cout
**位运算符**
C++的位运算符用于对二进制位进行操作。以下是C++位运算符的介绍和使用:
1. 位与运算符(&):用于对两个二进制数进行按位与操作。只有当两个相应的二进制位都为1时,结果的相应位才为1。例如:
点击查看代码
#include
int main()
{
int a = 60; // 二进制表示为 0010 1100
int b = 13; // 二进制表示为 0000 1101
int c = a & b; // 结果为0000 1100,即十进制中的12
std::cout
2. 位或运算符(|):用于对两个二进制数进行按位或操作。只要两个相应的二进制位中有一个为1,结果的相应位就为1。例如:
点击查看代码
#include
int main()
{
int a = 60; // 二进制表示为0010 1100
int b = 13; // 二进制表示为0000 1101
int c = a | b; // 结果为0010 1101,即十进制中的61
std::cout
3. 位异或运算符(^) :用于对两个二进制数进行按位异或操作。当两个相应的二进制位不同时,结果的相应位为1。例如:
点击查看代码
#include
int main()
{
int a = 60; // 二进制表示为0010 1100
int b = 13; // 二进制表示为0000 1101
int c = a ^ b; // 结果为0010 0001,即十进制中的49
std::cout
4. 位非运算符(~):用于对一个二进制数进行按位非操作。当相应的二进制位为1时,结果的相应位为0;当相应的二进制位为0时,结果的相应位为1。例如:
点击查看代码
#include
int main()
{
int a = 60; // 二进制表示为0010 1100
int b = ~a; // 二进制表示为1101 0011,即十进制中的-61
std::cout
tips:由于位运算符对整数进行低级操作,因此它们经常用于优化性能,特别是在处理网络数据、硬件编程和图形处理等场景。
**移位运算符**
C++中的移位运算符用于对二进制进行左移和右移操作。以下是C++移位运算符的介绍和使用:
1. 左移运算符(
#include
int main()
{
int a = 5; // 二进制表示为0000 0101
// 向左移动2位
int b = a
2. 右移运算符(>>):用于将一个整数的二进制位向右移动指定的位数。
在右移操作中,左侧的空位将根据该数的符合来填充。对于有符合整数,C++采用算术右移,即将最高位(符号位)复制到左侧的空位中。对于无符合整数,左侧的空位将用0来填充。例如:
点击查看代码
#include
int main()
{
int a = 20; // 二进制数表示为0010 0100
// 向右移动2位
int b = a >> 2; // 结果为0000 0101 // 即十进制中的5
std::cout
tips:使用移位运算符时需要注意数据类型的位数,确保在进行移位操作时不会导致数据溢出或丢失。移位运算符常用于性能敏感的代码中,如低级编程、图形处理、加密等场景。
**sizeof运算符**
sizeof是C++中非常有用的运算符,它用于获取数据类型或对象在内存中所占用的字节数。以下是sizeof运算符的介绍和使用:
基本语法:
sizeof(expression);
使用场景:
1. 获取基本数据类型的大小:例如,sizeof(int) 可以返回int类型在内存中占有的字节数。
2. 获取数组的总大小:例如,sizeof(array)可以返回数组的总字节大小。
3. 获取对象的大小:例如,sizeof(object)可以返回对象在内存中占用的字节数。
应用示例:
点击查看代码
#include
int main()
{
int a = 5;
int b[10];
int *p = &a;
std::cout
注意事项:
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
int main()
{
int x = 5;
std::cout 0 ? "x是正数" : "x不是正数")
三目运算符可以用于任何需要选择两个值的情况,不仅仅是if-else语句,还可以使用它来设置变量的值,示例代码如下:
点击查看代码
#include
int main()
{
int a = 10;
int b = 12;
int c = (a > b ? a : b);
// 输出结果为12
std::cout
**逗号运算符**
逗号运算符在C++中的特殊的运算符,它允许你在一个语句中执行多个操作,但只返回最后一个操作的结果。逗号运算符的语法如下:
expression1,expression2,…,expressionN;
逗号运算符按照从左到右的顺序依次执行每个表达式,并返回最后一个表达式的值。每个表达式可以是任何合法的C++ 表达式,包括变量赋值、函数调用等,示例代码如下:
点击查看代码
#include
int main()
{
// for循环中初始化多个变量
for(int i = 0, j = 0; i
**域解析运算符**
C++中的域解析运算符(::) 用于指定类或命名空间的成员。它可以用于访问静态成员、常量成员和非静态成员。
域解析运算符的语法如下:
class_name::member_name;
语法的class_服务器托管网name是类名,member_name是成员名。关于域解析运算符的使用,将会在类或命名空间的内容再作详细讲述。服务器托管,北京服务器托管,服务器租用 http://www.fwqtg.net
机房租用,北京机房租用,IDC机房托管, http://www.fwqtg.net
步骤: 打开蓝牙 配对连接 手机与电脑: 手机主动连接不上。电脑却可以连接手机。 连接上了,手机却不能向电脑传输文件,电脑可以向手机传输文件。 手机不能发送文件,很奇怪。但是电脑却可以向手机发送文件。 而且新老电脑之间能连接,但是传输服务器托管网不了文件。只有…