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

【C语言极简自学笔记】重讲运算符

一、算术操作符

算术操作符描述
+把两个操作数相加
-第一个操作数减去第二个操作数
*把两个操作数相乘
/分子除以分母
%取模运算符,整除后的余数

注意:1.除号的两端都是整数的时候执行的是整数的除法,两端只要有一个浮点数,就执行浮点数                的除法;
           2.%取模两端必须为整数 。

二、移位操作符

1.左移位操作符<<

规则:左边抛弃,右边补0

 由于在计算机中存储的数为二进制的补码,正数的原码、反码、补码均一致,负数的补码等于反码加一

则7的原码、补码、反码为:00000000000000000000000000000111

经过左移一位之后的结果为:000000000000000000000000000001110

即为十进制数14

若操作数为负数

 -7的原码为:10000000000000000000000000000111

反码为:11111111111111111111111111111000

补码为:11111111111111111111111111111001

左移一位后的结果为:11111111111111111111111111110010

原码为:10000000000000000000000000001110,即十进制数-14

2.右移操作符>>

右移操作符分为两种①:算术移位:右边抛弃,左边补原值符号位

                                ②:逻辑移位:右边抛弃,左边补0

一般编译器均为算术移位

-7的补码为:11111111111111111111111111111001 
右移一位后的结果为:11111111111111111111111111111100
原码为:10000000000000000000000000000100,即十进制数-4

7的原码、补码、反码为:00000000000000000000000000000111
右移一位后的结果为: 00000000000000000000000000000011,即十进制数3

 三、位操作符

位操作符主要分为三类:

&:按(二进制)位与

|:按(二进制)位或

^:按(二进制)位异或

注意❗❗❗:操作数均为整数

原理:通过存储在计算机中的二进制数进行按位操作,若操作数为正数,则直接输出其对应的数值;若操作数为负数,则求得其对应的原码所代表的数值后输出。

int main()
{int a = 3;//a的补码  00000000000000000000000000000011int b = -5;//b的原码  10000000000000000000000000000101//b的反码  11111111111111111111111111111010//b的补码  11111111111111111111111111111011int c = a & b;printf("c = %d\n",c);//a和b的补码按位与结果:00000000000000000000000000000011    即十进制数3int d = a | b;printf("d = %d\n", d);//a和b的补码按位或结果:11111111111111111111111111111011//反码为:11111111111111111111111111111010//原码为:10000000000000000000000000000101  即十进制数 -5int e = a ^ b;printf("e = %d\n", e);//a和b的补码按位异或结果:11111111111111111111111111111000//反码为:11111111111111111111111111110111//原码为:10000000000000000000000000001000   即十进制数 -8return 0;
}

四、赋值操作符

运算符描述
=赋值运算符,把右边操作数的值赋给左边操作数
+=加且赋值运算符,把右边操作数加上左边操作数的结果赋值给左边操作数
-=减且赋值运算符,把左边操作数减去右边操作数的结果赋值给左边操作数
*=乘且赋值运算符,把右边操作数乘以左边操作数的结果赋值给左边操作数
/=除且赋值运算符,把左边操作数除以右边操作数的结果赋值给左边操作数
%=求模且赋值运算符,求两个操作数的模赋值给左边操作数
<<=左移且赋值运算符
>>=右移且赋值运算符
&=按位与且赋值运算符
^=按位异或且赋值运算符
|=按位或且赋值运算符

http://www.lryc.cn/news/571934.html

相关文章:

  • LVS+Keepliaved高可用群集
  • 【MySQL数据库 | 第五篇】DDL操作2
  • RabbitMQ概念
  • 深入解析线程池与队列系统设计原理
  • 【网工】华为配置专题进阶篇②
  • Oracle 创建定时任务
  • Web服务器/tmp隔离的安全性与绕过分析
  • VSCode 插件 Remote - SSH:开启高效远程开发之旅
  • SpringBoot电脑商城项目--新增收获地址
  • 系统的性能优化
  • kettle好用吗?相较于国产ETL工具有哪些优劣之处?
  • git的使用——初步认识git和基础操作
  • 【Datawhale组队学习202506】零基础学爬虫 01 初始爬虫
  • Goursat问题解的公式推导
  • TikTok 矩阵如何快速涨粉
  • html中的table标签以及相关标签
  • 微信二次开发,对接智能客服逻辑
  • 百度下拉框出词技术解密:72小时出下拉词软件原理分享
  • 5G光网络新突破:<Light: Science Applications>报道可适应环境扰动的DRC实时校准技术
  • OpenStack 入门与实践
  • 激光雷达与视频融合(DeepFusion)的多模态高精度目标定位
  • PostgreSQL的扩展bloom
  • 数学建模会议笔记
  • STM32 HAL 库串口收发完全指南:从基础配置到实战应用
  • 标杆确立!永洪科技位于IDC报告Data Analytics领域象限排头位!
  • 操作系统期末复习--操作系统初识以及进程与线程
  • 实时中值滤波 + 低通滤波 示例程序(STM32环境)
  • CTF解题:[NSSCTF 2022 Spring Recruit]弱类型比较绕过
  • YOLOv11改进 | BiFormer注意力与C2PSA机制融合指南
  • Jupyter 是什么?基于浏览器的交互式计算环境