【C语言进阶】整型在内存中的存储(下)

简介: 【C语言进阶】整型在内存中的存储

2.unsigned和signed整型类的区别

先来一道题,通过题目来摸索!


char a= -1;


  原码:10000000 00000000 00000000 00000001


  反码:111111111  11111111  11111111 11111110


  补码:11111111 11111111 11111111 11111111(内存中存储方式:补码)


  但是char 占一个字节


 11111111


 要以%d输出,那么就会涉及整型提升。


                        整型提升的规则:与比自身类型低或者一些运算时,会发生整型提升


                        1.signed类型:正数提升时,补0;负数补1;(补当作最高位的符号位)


                        2.unsigned类型:提升时,直接补0;


那么,char a= -1,以%d输出时,整型提升时,


11111111


补后:11111111 11111111 11111111 11111111 存在内存中为补码,输出时要以原码输出


原码:10000000 00000000 00000000 00000001


(补码变原码,依旧是先取反(符号位不变!),再加一)


所以最终结果为 -1


signed char a = -1与char a = -1 是一样的。


在很多环境下,char,int都是有符号数!


所以结果还是 -1


unsigned char a = -1


  原码:10000000 00000000 00000000 00000001


  反码:111111111  11111111  11111111 11111110


  补码:11111111 11111111 11111111 11111111


  只取后面一个字节


 11111111


  整型提升(无符号数提升时补0 ):00000000 00000000 00000000 11111111(内存以补       码方式存储)


  最高位为0,是正数,正数原反补都相同,所以结果是  255.


一起来看结果

相信大家已经有所了解,并且熟悉了吧,当然还需要多多练习!

趁热打铁吧!

(%u为无符号输出)


原10000000 00000000 00000000 10000000


反11111111 11111111 11111111 01111111


补11111111 11111111 11111111 10000000


char 10000000


整型提升 11111111 11111111 11111111 10000000


结果 :4294967168

答案:-10


结果对了吗?


总结

     1.在内存中,不管是正数还是负数,存储形式都是以补码的形式存储!!


     2.一般情况下,int,char等整型通常是有符号数。


     3.大小端


          大端:数据的低位保存到了内存中的高地址处,数据的高位保存到了内存的低地址处


          小段:数据的低位保存到了内存中的低地址处,数据的高位保存到了内存的高地址处

目录
相关文章
|
1月前
|
存储 编译器 程序员
【C语言】内存布局大揭秘 ! -《堆、栈和你从未听说过的内存角落》
在C语言中,内存布局是程序运行时非常重要的概念。内存布局直接影响程序的性能、稳定性和安全性。理解C程序的内存布局,有助于编写更高效和可靠的代码。本文将详细介绍C程序的内存布局,包括代码段、数据段、堆、栈等部分,并提供相关的示例和应用。
51 5
【C语言】内存布局大揭秘 ! -《堆、栈和你从未听说过的内存角落》
|
1月前
|
存储 缓存 算法
【C语言】内存管理函数详细讲解
在C语言编程中,内存管理是至关重要的。动态内存分配函数允许程序在运行时请求和释放内存,这对于处理不确定大小的数据结构至关重要。以下是C语言内存管理函数的详细讲解,包括每个函数的功能、标准格式、示例代码、代码解释及其输出。
68 6
|
2月前
|
传感器 人工智能 物联网
C 语言在计算机科学中尤其在硬件交互方面占据重要地位。本文探讨了 C 语言与硬件交互的主要方法,包括直接访问硬件寄存器、中断处理、I/O 端口操作、内存映射 I/O 和设备驱动程序开发
C 语言在计算机科学中尤其在硬件交互方面占据重要地位。本文探讨了 C 语言与硬件交互的主要方法,包括直接访问硬件寄存器、中断处理、I/O 端口操作、内存映射 I/O 和设备驱动程序开发,以及面临的挑战和未来趋势,旨在帮助读者深入了解并掌握这些关键技术。
57 6
|
2月前
|
大数据 C语言
C 语言动态内存分配 —— 灵活掌控内存资源
C语言动态内存分配使程序在运行时灵活管理内存资源,通过malloc、calloc、realloc和free等函数实现内存的申请与释放,提高内存使用效率,适应不同应用场景需求。
|
2月前
|
存储 算法 程序员
C 语言指针详解 —— 内存操控的魔法棒
《C 语言指针详解》深入浅出地讲解了指针的概念、使用方法及其在内存操作中的重要作用,被誉为程序员手中的“内存操控魔法棒”。本书适合C语言初学者及希望深化理解指针机制的开发者阅读。
|
2月前
|
并行计算 算法 测试技术
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面,旨在通过综合策略提升程序性能,满足实际需求。
71 1
|
2月前
|
缓存 Prometheus 监控
Elasticsearch集群JVM调优设置合适的堆内存大小
Elasticsearch集群JVM调优设置合适的堆内存大小
421 1
|
1月前
|
存储 监控 算法
深入探索Java虚拟机(JVM)的内存管理机制
本文旨在为读者提供对Java虚拟机(JVM)内存管理机制的深入理解。通过详细解析JVM的内存结构、垃圾回收算法以及性能优化策略,本文不仅揭示了Java程序高效运行背后的原理,还为开发者提供了优化应用程序性能的实用技巧。不同于常规摘要仅概述文章大意,本文摘要将简要介绍JVM内存管理的关键点,为读者提供一个清晰的学习路线图。
|
2月前
|
Java
JVM内存参数
-Xmx[]:堆空间最大内存 -Xms[]:堆空间最小内存,一般设置成跟堆空间最大内存一样的 -Xmn[]:新生代的最大内存 -xx[use 垃圾回收器名称]:指定垃圾回收器 -xss:设置单个线程栈大小 一般设堆空间为最大可用物理地址的百分之80
|
2月前
|
Java
JVM运行时数据区(内存结构)
1)虚拟机栈:每次调用方法都会在虚拟机栈中产生一个栈帧,每个栈帧中都有方法的参数、局部变量、方法出口等信息,方法执行完毕后释放栈帧 (2)本地方法栈:为native修饰的本地方法提供的空间,在HotSpot中与虚拟机合二为一 (3)程序计数器:保存指令执行的地址,方便线程切回后能继续执行代码
27 3
下一篇
开通oss服务