news 2026/6/26 10:45:39

自增自减运算符,赋值运算符,关系运算符,四种逻辑运算符

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
自增自减运算符,赋值运算符,关系运算符,四种逻辑运算符

一、自增自减运算符

1. 基本用法

c

int a = 5; int b; b = a++; // 先赋值后自增:b=5, a=6 b = ++a; // 先自增后赋值:a先变成7, b=7

2. 指针与自增自减

c

int arr[] = {1, 2, 3}; int *p = arr; printf("%d\n", *p++); // 输出1,p指向arr[1] printf("%d\n", (*p)++); // 输出2,arr[1]变成3 printf("%d\n", *++p); // p先指向arr[2],输出3

3. 注意事项

  • 副作用:自增自减会改变操作数的值

  • 优先级:后缀++/--> 前缀++/--> 解引用*

  • 求值顺序:避免在同一个表达式中对同一变量多次自增自减


二、赋值运算符

1. 基本赋值

c

int a = 10; // 简单赋值 a += 5; // 等价于 a = a + 5 a *= 2; // 等价于 a = a * 2

2. 复合赋值运算符

运算符等价形式说明
+=a = a + b加赋值
-=a = a - b减赋值
*=a = a * b乘赋值
/=a = a / b除赋值
%=a = a % b模赋值

3. 多重赋值

c

int a, b, c; a = b = c = 10; // 从右向左赋值

三、关系运算符

1. 六种关系运算符

c

> // 大于 < // 小于 >= // 大于等于 <= // 小于等于 == // 等于 != // 不等于

2. 运算结果

  • 结果为1(真)或0(假)

c

int result = (5 > 3); // result = 1 result = (5 == 3); // result = 0

3. 注意事项

  • 不要与赋值混淆=是赋值,==是比较

  • 浮点数比较:避免直接用==比较浮点数,应使用误差范围

c

double x = 0.1 + 0.2; if (fabs(x - 0.3) < 1e-6) // 正确比较

四、逻辑运算符

1. 四种逻辑运算符

运算符名称说明示例
&&逻辑与两个都为真时结果为真(a>0 && b>0)
``逻辑或至少一个为真时结果为真`(a>0b>0)`
!逻辑非取反操作!(a>0)
按位逻辑位运算按位操作`&,, ^, ~`

2. 逻辑与&&和逻辑或||

c

int a = 5, b = 0; if (a > 0 && b > 0) // b>0为假,整体为假(短路特性) if (a > 0 || b > 0) // a>0为真,整体为真(短路特性)

3. 短路特性

c

int a = 0; int b = 5; if (a != 0 && b / a > 2) // a!=0为假,后面不会执行,避免除零错误 if (a == 0 || b / a > 2) // a==0为真,后面不会执行

4. 位逻辑运算符(按位操作)

c

unsigned int a = 5; // 0101 unsigned int b = 3; // 0011 a & b; // 0001 = 1 (按位与) a | b; // 0111 = 7 (按位或) a ^ b; // 0110 = 6 (按位异或) ~a; // 1010 = ... (按位取反)

5. 运算符优先级总结

从高到低:

  1. ()括号

  2. ++ --后缀

  3. ++ --前缀、!~+(正)、-(负)

  4. */%

  5. +-

  6. <<=>>=

  7. ==!=

  8. &(位与)

  9. ^(位异或)

  10. |(位或)

  11. &&

  12. ||

  13. =+=-=等赋值运算符


五、综合示例

c

#include <stdio.h> int main() { int a = 5, b = 3, c = 0; // 自增与关系运算 printf("a++ > b: %d\n", a++ > b); // 5>3为真,输出1,a变成6 // 逻辑运算 printf("a>0 && b>0: %d\n", a>0 && b>0); // 1 // 赋值与运算 c = a += 2; // a先加2变成8,再赋值给c printf("a=%d, c=%d\n", a, c); // a=8, c=8 return 0; }

六、常见易错点

  1. 混淆===

    c

    if (a = 5) // 总是真,因为赋值表达式值为5 if (a == 5) // 正确比较
  2. 自增自减的顺序问题

    c

    int a = 5; int b = a++ + ++a; // 结果依赖编译器,避免这样写
  3. 短路特性的利用

    • 用于条件判断中的函数调用保护

    c

    if (p != NULL && p->data > 0) // 避免空指针访问
  4. 位运算与逻辑运算的区别

    c

    int a = 1, b = 2; a & b; // 位运算:0 a && b; // 逻辑运算:1(非零为真)

总结:掌握这些运算符的优先级、结合性和特殊行为,是编写正确、高效C程序的基础。特别要注意自增自减的副作用和逻辑运算符的短路特性。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/26 7:13:23

14.2 全流程拆解:每个环节的关键任务与交付物

14.2 全流程拆解:每个环节的关键任务与交付物 在上一节中,我们介绍了AIGC产品的标准设计流程。今天,我们将对这个流程进行详细拆解,深入分析每个环节的关键任务和预期交付物,帮助大家更好地理解和执行AIGC产品开发项目。 需求分析与机会识别阶段 这个阶段是整个产品开发…

作者头像 李华
网站建设 2026/6/25 19:47:48

仅限内部流传的优化技巧:Open-AutoGLM缩放手势识别三大禁忌与破解

第一章&#xff1a;Open-AutoGLM缩放手势识别优化概述Open-AutoGLM 是一种基于自回归语言模型与视觉编码协同的多模态交互框架&#xff0c;其在移动设备端的手势识别任务中展现出卓越的实时性与准确性。针对缩放手势&#xff08;Pinch-to-Zoom&#xff09;这一高频交互行为&…

作者头像 李华
网站建设 2026/6/25 3:24:00

你还在静态设置超时?Open-AutoGLM智能等待时间调整已成行业标配!

第一章&#xff1a;Open-AutoGLM操作等待时间动态调整的演进与意义在大规模语言模型服务部署中&#xff0c;操作等待时间的稳定性直接影响用户体验与系统吞吐。Open-AutoGLM作为开源自适应推理框架&#xff0c;其核心机制之一便是对请求处理过程中的等待时间进行动态调整。这一…

作者头像 李华
网站建设 2026/6/26 6:24:51

Excalidraw与Figma对比:谁更适合做技术草图设计?

Excalidraw与Figma对比&#xff1a;谁更适合做技术草图设计&#xff1f; 在一次深夜的技术评审会上&#xff0c;团队正为新系统的架构争执不下。有人坚持用事件驱动&#xff0c;有人主张同步调用&#xff0c;但口头描述始终模糊不清。直到一位工程师打开浏览器&#xff0c;输入…

作者头像 李华
网站建设 2026/6/25 21:58:10

Open-AutoGLM智能重试引擎揭秘:基于响应延迟与错误率的动态调整模型

第一章&#xff1a;Open-AutoGLM 重试次数智能设置在构建高可用的自动化推理系统时&#xff0c;网络波动、服务限流或临时性故障时常导致请求失败。Open-AutoGLM 通过引入重试机制提升任务成功率&#xff0c;但固定重试次数可能导致资源浪费或容错不足。为此&#xff0c;设计一…

作者头像 李华
网站建设 2026/6/25 17:00:04

Excalidraw入门到精通:掌握这10个技巧就够了

Excalidraw入门到精通&#xff1a;掌握这10个技巧就够了 在远程协作和敏捷开发日益成为常态的今天&#xff0c;团队对可视化工具的需求早已超越“画图”本身。我们不再满足于冷冰冰的几何图形和复杂的操作流程——我们需要的是一个能快速表达想法、激发创意、支持多人实时互动的…

作者头像 李华