当前位置: 首页 > news >正文

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

一、自增自减运算符

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程序的基础。特别要注意自增自减的副作用和逻辑运算符的短路特性。

http://www.cnnetsun.cn/news/173216.html

相关文章:

  • AI+科学发现:从药物分子到新材料,加速科研进程
  • Open-AutoGLM控件状态精准识别实战(工业级UI自动化新突破)
  • FCKEditor支持Word图片上传转存保留图文混排结构
  • 无需设计功底!Excalidraw让你秒变架构图绘画高手
  • Excalidraw如何导出高清图片?避免模糊的三大要点
  • 组织结构图数据批量导入 快速生成工具
  • Excalidraw图形伦理审查标记
  • 【反自动化检测终极武器】:Open-AutoGLM如何绕过行为风控系统?
  • 大同市软件公司哪个口碑好
  • 为什么你的Open-AutoGLM总是超时?重试次数设置不当正在拖垮性能
  • Open-AutoGLM权限管理难题终结者,企业级共享架构设计全揭秘
  • 大数据领域数据架构的自动化运维模式
  • 揭秘Open-AutoGLM多手指同步机制:从延迟优化到事件分发的底层逻辑
  • Open-AutoGLM文本生成提速全攻略(内部优化模型首次公开)
  • 从零构建控件识别系统,基于Open-AutoGLM的自动化测试进阶之路
  • 【Open-AutoGLM多指协同操作解密】:揭秘智能自动化中手势交互的核心算法与实现路径
  • 【Open-AutoGLM控件识别核心技术】:揭秘高精度状态识别的5大实现策略
  • Excalidraw支持网络拓扑自动发现
  • 【Open-AutoGLM高效运维必修课】:从入门到精通的5个核心步骤
  • 掌握这4个技巧,轻松实现Open-AutoGLM无缝版本切换
  • Python数据结构(上):字符串、列表、元组
  • Excalidraw图形权限细粒度控制
  • Excalidraw图形导出为React组件
  • HLS用于应用加速
  • 从入门到精通:Open-AutoGLM账号权限管理的8个必知功能模块
  • 我要搞个ai程序操控鼠标,截取屏幕,识别刀路,给ai一个刀路寻找规则的prompt,然后ai自己去按规则顺序点亮刀路
  • JavaScript 数据类型详解:分类、种类、判断方法及深浅差异
  • Excalidraw与Notion集成实践:构建智能笔记系统
  • 永磁同步电机多物理场仿真案例:电磁、谐响应与噪声分析,适合学习
  • gcc-c++-7.3.0 rpm安装方法 Linux麒麟KY10完整步骤