C 语言零基础入门教程(七)

news/2025/3/20 7:37:08/

C 运算符

运算符是一种告诉编译器执行特定的数学或逻辑操作的符号。C 语言内置了丰富的运算符,并提供了以下类型的运算符:
算术运算符
关系运算符
逻辑运算符
位运算符
赋值运算符
杂项运算符
本章将逐一介绍算术运算符、关系运算符、逻辑运算符、位运算符、赋值运算符和其他运算符。

算术运算符

下表显示了 C 语言支持的所有算术运算符。假设变量 A 的值为 10,变量 B 的值为 20,则:
在这里插入图片描述
实例
请看下面的实例,了解 C 语言中所有可用的算术运算符:

#include <stdio.h>int main()
{int a = 21;int b = 10;int c ;c = a + b;printf("Line 1 - c 的值是 %d\n", c );c = a - b;printf("Line 2 - c 的值是 %d\n", c );c = a * b;printf("Line 3 - c 的值是 %d\n", c );c = a / b;printf("Line 4 - c 的值是 %d\n", c );c = a % b;printf("Line 5 - c 的值是 %d\n", c );c = a++;  // 赋值后再加 1 ,c 为 21,a 为 22printf("Line 6 - c 的值是 %d\n", c );c = a--;  // 赋值后再减 1 ,c 为 22 ,a 为 21printf("Line 7 - c 的值是 %d\n", c );}

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

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

以下实例演示了 a++ 与 ++a 的区别:
实例

#include <stdio.h>int main()
{int c;int a = 10;c = a++; printf("先赋值后运算:\n");printf("Line 1 - c 的值是 %d\n", c );printf("Line 2 - a 的值是 %d\n", a );a = 10;c = a--; printf("Line 3 - c 的值是 %d\n", c );printf("Line 4 - a 的值是 %d\n", a );printf("先运算后赋值:\n");a = 10;c = ++a; printf("Line 5 - c 的值是 %d\n", c );printf("Line 6 - a 的值是 %d\n", a );a = 10;c = --a; printf("Line 7 - c 的值是 %d\n", c );printf("Line 8 - a 的值是 %d\n", a );}

以上程序执行输出结果为:

先赋值后运算:
Line 1 - c 的值是 10
Line 2 - a 的值是 11
Line 3 - c 的值是 10
Line 4 - a 的值是 9
先运算后赋值:
Line 5 - c 的值是 11
Line 6 - a 的值是 11
Line 7 - c 的值是 9
Line 8 - a 的值是 9

关系运算符

下表显示了 C 语言支持的所有关系运算符。假设变量 A 的值为 10,变量 B 的值为 20,则:
在这里插入图片描述
实例
请看下面的实例,了解 C 语言中所有可用的关系运算符:

#include <stdio.h>int main()
{int a = 21;int b = 10;int c ;if( a == b ){printf("Line 1 - a 等于 b\n" );}else{printf("Line 1 - a 不等于 b\n" );}if ( a < b ){printf("Line 2 - a 小于 b\n" );}else{printf("Line 2 - a 不小于 b\n" );}if ( a > b ){printf("Line 3 - a 大于 b\n" );}else{printf("Line 3 - a 不大于 b\n" );}/* 改变 a 和 b 的值 */a = 5;b = 20;if ( a <= b ){printf("Line 4 - a 小于或等于 b\n" );}if ( b >= a ){printf("Line 5 - b 大于或等于 a\n" );}
}

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

Line 1 - a 不等于 b
Line 2 - a 不小于 b
Line 3 - a 大于 b
Line 4 - a 小于或等于 b
Line 5 - b 大于或等于 a

逻辑运算符

下表显示了 C 语言支持的所有关系逻辑运算符。假设变量 A 的值为 1,变量 B 的值为 0,则:
在这里插入图片描述
实例
请看下面的实例,了解 C 语言中所有可用的逻辑运算符:

#include <stdio.h>int main()
{int a = 5;int b = 20;int c ;if ( a && b ){printf("Line 1 - 条件为真\n" );}if ( a || b ){printf("Line 2 - 条件为真\n" );}/* 改变 a 和 b 的值 */a = 0;b = 10;if ( a && b ){printf("Line 3 - 条件为真\n" );}else{printf("Line 3 - 条件为假\n" );}if ( !(a && b) ){printf("Line 4 - 条件为真\n" );}
}

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

Line 1 - 条件为真
Line 2 - 条件为真
Line 3 - 条件为假
Line 4 - 条件为真

位运算符

位运算符作用于位,并逐位执行操作。&、 | 和 ^ 的真值表如下所示:
在这里插入图片描述
假设如果 A = 60,且 B = 13,现在以二进制格式表示,它们如下所示:

A = 0011 1100
B = 0000 1101
-----------------
A&B = 0000 1100
A|B = 0011 1101
A^B = 0011 0001
~A  = 1100 0011

下表显示了 C 语言支持的位运算符。假设变量 A 的值为 60,变量 B 的值为 13,则:
在这里插入图片描述
实例
请看下面的实例,了解 C 语言中所有可用的位运算符:

#include <stdio.h>int main()
{unsigned int a = 60;    /* 60 = 0011 1100 */  unsigned int b = 13;    /* 13 = 0000 1101 */int c = 0;           c = a & b;       /* 12 = 0000 1100 */ printf("Line 1 - c 的值是 %d\n", c );c = a | b;       /* 61 = 0011 1101 */printf("Line 2 - c 的值是 %d\n", c );c = a ^ b;       /* 49 = 0011 0001 */printf("Line 3 - c 的值是 %d\n", c );c = ~a;          /*-61 = 1100 0011 */printf("Line 4 - c 的值是 %d\n", c );c = a << 2;     /* 240 = 1111 0000 */printf("Line 5 - c 的值是 %d\n", c );c = a >> 2;     /* 15 = 0000 1111 */printf("Line 6 - c 的值是 %d\n", c );
}

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

Line 1 - c 的值是 12
Line 2 - c 的值是 61
Line 3 - c 的值是 49
Line 4 - c 的值是 -61
Line 5 - c 的值是 240
Line 6 - c 的值是 15

赋值运算符

下表列出了 C 语言支持的赋值运算符:
在这里插入图片描述
实例
请看下面的实例,了解 C 语言中所有可用的赋值运算符:

#include <stdio.h>int main()
{int a = 21;int c ;c =  a;printf("Line 1 - =  运算符实例,c 的值 = %d\n", c );c +=  a;printf("Line 2 - += 运算符实例,c 的值 = %d\n", c );c -=  a;printf("Line 3 - -= 运算符实例,c 的值 = %d\n", c );c *=  a;printf("Line 4 - *= 运算符实例,c 的值 = %d\n", c );c /=  a;printf("Line 5 - /= 运算符实例,c 的值 = %d\n", c );c  = 200;c %=  a;printf("Line 6 - %%= 运算符实例,c 的值 = %d\n", c );c <<=  2;printf("Line 7 - <<= 运算符实例,c 的值 = %d\n", c );c >>=  2;printf("Line 8 - >>= 运算符实例,c 的值 = %d\n", c );c &=  2;printf("Line 9 - &= 运算符实例,c 的值 = %d\n", c );c ^=  2;printf("Line 10 - ^= 运算符实例,c 的值 = %d\n", c );c |=  2;printf("Line 11 - |= 运算符实例,c 的值 = %d\n", c );}

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

Line 1 - =  运算符实例,c 的值 = 21
Line 2 - += 运算符实例,c 的值 = 42
Line 3 - -= 运算符实例,c 的值 = 21
Line 4 - *= 运算符实例,c 的值 = 441
Line 5 - /= 运算符实例,c 的值 = 21
Line 6 - %= 运算符实例,c 的值 = 11
Line 7 - <<= 运算符实例,c 的值 = 44
Line 8 - >>= 运算符实例,c 的值 = 11
Line 9 - &= 运算符实例,c 的值 = 2
Line 10 - ^= 运算符实例,c 的值 = 0
Line 11 - |= 运算符实例,c 的值 = 2

杂项运算符 ↦ sizeof & 三元

下表列出了 C 语言支持的其他一些重要的运算符,包括 sizeof 和 ? :。
在这里插入图片描述
实例
请看下面的实例,了解 C 语言中所有可用的杂项运算符:

#include <stdio.h>int main()
{int a = 4;short b;double c;int* ptr;/* sizeof 运算符实例 */printf("Line 1 - 变量 a 的大小 = %lu\n", sizeof(a) );printf("Line 2 - 变量 b 的大小 = %lu\n", sizeof(b) );printf("Line 3 - 变量 c 的大小 = %lu\n", sizeof(c) );/* & 和 * 运算符实例 */ptr = &a;    /* 'ptr' 现在包含 'a' 的地址 */printf("a 的值是 %d\n", a);printf("*ptr 是 %d\n", *ptr);/* 三元运算符实例 */a = 10;b = (a == 1) ? 20: 30;printf( "b 的值是 %d\n", b );b = (a == 10) ? 20: 30;printf( "b 的值是 %d\n", b );
}

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

Line 1 - 变量 a 的大小 = 4
Line 2 - 变量 b 的大小 = 2
Line 3 - 变量 c 的大小 = 8
a 的值是 4
*ptr 是 4
b 的值是 30
b 的值是 20

C 中的运算符优先级

运算符的优先级确定表达式中项的组合。这会影响到一个表达式如何计算。某些运算符比其他运算符有更高的优先级,例如,乘除运算符具有比加减运算符更高的优先级。
例如 x = 7 + 3 * 2,在这里,x 被赋值为 13,而不是 20,因为运算符 * 具有比 + 更高的优先级,所以首先计算乘法 3*2,然后再加上 7。
下表将按运算符优先级从高到低列出各个运算符,具有较高优先级的运算符出现在表格的上面,具有较低优先级的运算符出现在表格的下面。在表达式中,较高优先级的运算符会优先被计算。
在这里插入图片描述
实例
请看下面的实例,了解 C 语言中运算符的优先级:

#include <stdio.h>main()
{int a = 20;int b = 10;int c = 15;int d = 5;int e;e = (a + b) * c / d;      // ( 30 * 15 ) / 5printf("(a + b) * c / d 的值是 %d\n",  e );e = ((a + b) * c) / d;    // (30 * 15 ) / 5printf("((a + b) * c) / d 的值是 %d\n" ,  e );e = (a + b) * (c / d);   // (30) * (15/5)printf("(a + b) * (c / d) 的值是 %d\n",  e );e = a + (b * c) / d;     //  20 + (150/5)printf("a + (b * c) / d 的值是 %d\n" ,  e );return 0;
}

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

(a + b) * c / d 的值是 90
((a + b) * c) / d 的值是 90
(a + b) * (c / d) 的值是 90
a + (b * c) / d 的值是 50

http://www.ppmy.cn/news/195687.html

相关文章

C语言——数组(详解)

C语言数组详解 文章目录 C语言数组详解1.一维数组的创建与初始化1.1.什么是数组?1.2一维数组的创建1.2.数组的初始化 2.一维数组的使用2.1一维数组的使用2.2.字符串与字符数组的区别 3.一维数组在内存中的存储4.二维数组的创建以及初始化4.1二维数组的创建4.2二维数组的初始化…

C语言——数组【详解】

文章目录 1. 一维数组的创建和初始化1.1 数组的创建1.2 数组的初始化1.3 一维数组的使用1.4 一维数组在内存中的存储 2. 二维数组的创建和初始化2.1 二维数组的创建2.2 二维数组的初始化2.3 二维数组的使用2.4 二维数组在内存中的存储 3. 数组越界4. 数组作为函数参数4.1 冒泡排…

Android怎么插手机卡,魅蓝E手机卡怎么装 魅蓝E手机SIM卡安装图文教程

昨天下午&#xff0c;魅族发布了全新系列魅蓝手机——魅蓝E&#xff0c;定位魅蓝高端产品线&#xff0c;售价1299元&#xff0c;李楠号称魅蓝E采用三四千元的旗舰机工艺&#xff0c;外观/屏幕/拍照提升明显。此外&#xff0c;魅蓝E依旧支持全网通双卡双待。那么魅蓝E怎么插卡/装…

【C语言入门】--- 数组详解

文章目录 一维数组一、一维数组的创建二、一维数组的初始化三、一维数组的使用四、一维数组在内存中的存储 二维数组一、二维数组的创建二、二维数组的初始化三、二维数组的使用四、数组越界五、冒泡排序六、数组名6.1一维数组的数组名6.2二维数组的数组名 一维数组 一、一维数…

android平板怎么插卡,魅蓝X如何插卡 魅蓝X插卡方法【图文教程】

对于刚入手使用新机的小伙伴&#xff0c;有的对于魅蓝X怎么使用就不是很清楚。比如说魅蓝x怎幺插卡&#xff1f;下面&#xff0c;小编给大家带来魅蓝X插卡图文教程&#xff0c;感兴趣的朋友一起来看看吧。 魅蓝X 魅蓝X怎幺插卡须知&#xff1a; 以下是魅蓝X网络制式详情。 魅蓝…

C 语言零基础入门教程(六)

C 存储类 存储类定义 C 程序中变量/函数的范围&#xff08;可见性&#xff09;和生命周期。这些说明符放置在它们所修饰的类型之前。下面列出 C 程序中可用的存储类&#xff1a; auto register static extern auto 存储类 auto 存储类是所有局部变量默认的存储类。 {int mo…

魅蓝NOTE6怎么ROOT,一招最简单实用的方法

魅蓝note6如何完全ROOT?很多魅蓝NOTE6用户都想ROOT自己的手机&#xff0c;但是通过使用KINGROOT,ROOT大师&#xff0c;ROOT精灵之类的ROOT软件&#xff0c;发现并没有效果。以为魅蓝note6 不能root了&#xff0c;其实魅蓝NOte6可以获取完美root&#xff0c; 下面说说教程步骤 …

魅蓝metal刷android 6,魅族魅蓝Metal刷机包 Flyme 6.0.2.0Y公开稳定版 Flyme 6稳定版系统发布 全新体验...

rom更新记录 功能调整 每个功能从创造到落地都花费了巨大心血,只为给魅友带来更多惊喜。由于新功能在各个机型上的适配会存在一定时间差,未找到新功能的魅友请耐心等候。 系统 全面提升系统稳定性,同时优化了待机功耗,让使用更顺心 提高第三方应用的兼容性,避免因闪退影…