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

C语言踩坑题:int8_t类型数据的移位或运算

1.分析如下代码,输出结果是多少

#include <stdio.h>
#include <stdint.h>

int main()
{
	int8_t a = 0x0D;
	int8_t b = 0x9D;
	
	printf("res = 0x%X\n", a << 8| b);
	
	return 0;
}

​

如果你计算的答案是:0x0D9D,那么恭喜你...........

下边来看DEV运算结果:

2.分析原因

        在C语言中,int8_t 是一个8位的有符号整数类型,通常定义为char。当你使用int8_t a=0x0D和int8_t  b = 0x9D时,a和b都是有符号的8位整数。
        在表达式 a<<8 | b中,a被左移8位,然后与b进行按位或操作;由于a是int8_t类型,左移8位会导致 a的值被提升为 int 类型(通常是32位或64位),然后左移8位

详细分析如下:
1. a的值是 0x0D左移8位后变为0x0D00;
2. b的值是 0x9D,由于b是int8t类型,且 0x9D在int8t中是一个负数(因为最高位是1),所以当 b 被提升为int 类型时,会进行符号扩展,变为0xFFFFFF9D;

3.然后进行按位或操作:0x0D00 | 0xFFFFFF9D ,结果是0xFFFFFF9D;

4.最后,printf 函数格式化输出时使用 %x,输出的是 0xFFFFFF9D的低16位,即 0xFF9D;

相关文章:

  • (五)Dart 数据类型
  • 嵌入式人工智能应用- 第十章街景分类
  • 现在有分段、句子数量可能不一致的中英文文本,如何用python实现中英文对照翻译(即每行英文对应相应的中文)
  • C# 建造者模式(Builder Pattern)详细讲解
  • 一文了解CAS
  • 图片标注及流程
  • 如何使用Python的matplotlib.pyplot绘制热图和损失图
  • 二进制数(十进制转二进制)
  • ObjC NSString字符串常量编码格式是编译器决定还是ObjC语言规范决定?字符串默认编码?
  • 【VUE】day02-vue过滤器、计算属性、vue-cli、vue组件
  • ST电机库电流采样 三电阻单ADC
  • 【论文笔记】FFA-Net: Feature Fusion Attention Network for Single Image Dehazing
  • Powershell如何查询 windows defender是否开启
  • 数据库小练习
  • 函数式编程定义
  • 【Msq8.0无需登陆进行重置密码】
  • 数学建模 第一节
  • PAT甲级(Advanced Level) Practice 1019 General Palindromic Number
  • Next.js项目MindAI教程 - 第六章:在线咨询功能
  • Keil5下载教程及安装教程(附安装包)
  • 中国证券监督管理委员会党委委员、副主席王建军接受审查调查
  • 夜读丨跷脚牛肉乐翘脚
  • 辽宁辽阳火灾事故饭店经营者已被控制,善后处置全面展开
  • 专访|首夺天元头衔创生涯历史,王星昊打算一步一步慢慢来
  • 深圳一季度GDP为8950.49亿元,同比增长5.2%
  • 十大券商看后市|A股风险偏好有望边际改善,市场仍处黄金坑