【控制器局域网】CAN报文学习笔记(三)之 字节移位运算

字节位移运算是计算机编程中常用的一种位运算。在字节位移运算中,通常使用两个运算符:左移运算符(<<)和右移运算符(>>)。这两个运算符分别用于将二进制表示的数值向左或向右移动指定的位数。

1. 左移位运算(<<):

左移位运算将二进制数的所有位向左移动指定的位数,右侧用零填充。在C++中,左移位运算的语法如下:

result = value << num_bits;

其中,value 是要进行左移的值,num_bits 是左移的位数。

示例代码:

#include <iostream>
int main() {
    int x = 13; // 二进制表示为 1101
    int result = x << 2; // 左移位运算 2 位 右侧用0填充 110100 对应十进制52
    std::cout << "Result: " << result << std::endl; // 输出:52
    return 0;
}

2. 右移位运算(>>):

右移位运算将二进制数的所有位向右移动指定的位数,左侧用原始符号位填充(对于有符号整数)或者用零填充(对于无符号整数)。在C++中,右移位运算的语法如下:

result = value >> num_bits;

其中,value 是要进行右移的值,num_bits 是右移的位数。

示例代码:

#include <iostream>

int main() {
    int x = 13; // 二进制表示为 1101
    int result = x >> 1; // 右移位运算 1 位 左边用0填充 0110 对应十进制6
    std::cout << "Result: " << result << std::endl; // 输出:6
    return 0;
}

需要注意的是,右移位运算的结果取决于移位的对象是有符号整数还是无符号整数。在处理有符号整数时,右移位可能会导致符号位的复制,而在处理无符号整数时,右移位总是用零填充。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

SensizliKLoU

感谢您的慷慨支持和鼓励!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值