c语言-整型在内存的存储

news2024/11/18 11:47:46

文章目录

  • 前言
  • 一、整型数值在内存中的存储
    • 1.1 整型数值的表示形式
    • 1.2 二进制的表示形式
    • 1.3 整数在内存中存储
  • 二、大端字节序存储和小端字节序存储
    • 2.1 大端字节序存储
    • 2.2 小端字节序存储
    • 2.3 练习
  • 总结


前言

本篇文章叙述c语言中整型数据在内存中的存储方式。


一、整型数值在内存中的存储

1.1 整型数值的表示形式

形式数值范围
二进制{0,1}
八进制{0,1,2,3,4,5,6,7}
十进制{0,1,2,3,4,5,6,7,8,9}
十六进制{0,1,2,3,4,5,6,7,8,9,a,b,c,d,e,f}

1.2 二进制的表示形式

正整数:原码、反码、补码相同。
负整数:原码、反码、补码需要计算。

形式计算规则
原码直接通过整数正负写出的二进制序列
反码原码符号位不变,其余按位取反
补码反码+1

例如:32位机器为例
正整数

	int a = 20;
	//原码:	00000000 00000000 00000000 00010100
	//反码:	00000000 00000000 00000000 00010100
	//补码:	00000000 00000000 00000000 00010100

负整数

	int a = -20
	//原码:	10000000 00000000 00000000 00010100
	//反码:	11111111 11111111 11111111 11101011
	//补码:	11111111 11111111 11111111 11101100

原码和补码的相互转换:

原码->补码:
方式一: 原码符号位不变,其余为按位取反,然后+1;
补码->原码:
方式一:补码符号位不变,其余按位取反,然后+1;
方式二:补码-1,符号位不变,其余位按位取反。

1.3 整数在内存中存储

整数在内存中存储方式是以二进制的补码方式存储

以补码方式存储的原因:

  1. 在计算机系统中,数值一律用补码来表示和存储,原因在于使用补码,可以将符号位和数值域统一处理
  2. 加法和减法可以统一处理(CPU只有加法器),补码与原码转换的运算过程是相同的,不需要额外的硬件电路

二、大端字节序存储和小端字节序存储

2.1 大端字节序存储

大端字节序存储:指数据的低位保存在内存的高地址中;数据的高位保存在低地址中。
以int a = 0x11223344为例:
在这里插入图片描述

图2.1 大端字节序存储

2.2 小端字节序存储

小端字节序存储:指数据的低位保存在内存的低地址中,数据的高位保存在高地址中。
在这里插入图片描述

图2.1 小端字节序存储

2.3 练习

设计一个小程序判断当前机器的字节序
思路:
假设int a = 1 时,a的补码转换成16进制0x00000001
取a的第一个字节,即低位;
如果第一个字节为01,则为小端字节序;
如果第一个字节为00,则为大端字节序。

代码实现如下:

//判断一个编译器的大小端字节序
// 0 大端字节序
// 1 小端字节序

int sys_mode()
{
	int a = 1;
	//a的补码16进制  0x 00 00 00 01
	//利用char*指针取int的第一个字节的值
	return (*((char*)&a));
}
int main()
{
	if (sys_mode() == 1)
		printf("小端字节序\n");
	else
		printf("大端字节序\n");
	return 0;
}

总结

本篇文章介绍了c语言中整型数值的表示形式,二进制的表示形式,整型数据在内存中的存储方式;最后介绍了关于大端字节序和小端字节序的概念。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1352093.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

设计模式:简单工厂模式、工厂方法模式、抽象工厂模式

简单工厂模式、工厂方法模式、抽象工厂模式 1. 为什么需要工厂模式?2. 简单工厂模式2.1. 定义2.2. 代码实现2.3. 优点2.4. 缺点2.5. 适用场景 3. 工厂方法模式3.1. 有了简单工厂模式为什么还需要有工厂方法模式?3.2. 定义3.3. 代码实现3.4. 主要优点3.5.…

在较高时间周期 这些现货黄金投资法值得一用

以日线图和周线图为代表的较高时间周期,一直是投资者很少利用的。之所以这么说,不是说投资者不会在日线图上分析,而是很少利用日线图交易。一来持仓过夜,会有相关的费用产生。二来很多人做现货黄金以短线为主。其实这种较高的时间…

Windows中磁盘未知没有初始化怎么办?

当我们尝试在Windows11/10/8/7上使用外部硬盘驱动器时,在小概率情况下可能会遇到磁盘未知没有初始化情况,此时如果您进入磁盘管理工具中查看,将会发现您的外部硬盘驱动器显示为未知、未初始化、没有磁盘空间,或者在某些情况下它还…

阿里云服务器8080端口安全组开通图文教程

阿里云服务器8080端口开放在安全组中放行,Tomcat默认使用8080端口,8080端口也用于www代理服务,阿腾云atengyun.com以8080端口为例来详细说下阿里云服务器8080端口开启教程教程: 阿里云服务器8080端口开启教程 阿里云服务器8080端…

Mac 安装 Adobe AE/PS 软件报错 “Failed with error code 146“

文章目录 1. 安装 AE 软件报错2. 网上的方法2.1 删除 caps 文件夹2.2 删除 Adobe Sync 文件夹 3. 我的解决方法 1. 安装 AE 软件报错 我在尝试安装 Adobe AE 软件的时候,报错 “Failed with error code 146” 2. 网上的方法 2.1 删除 caps 文件夹 在 finder 的…

众和策略股市行情分析:股票分红是按持股比例来分的吗?

股票分红立足于同股同利的准则,按股东的持股比例来进行股利的派发分红。持股多的股东按比例所得的分红就多,持股少的股东按比例所得的分红就少。 另外,分红详细是指的股票发行公司分配股利的行为。股利包含股息和盈利,股息是指的…

【Web】CTFSHOW元旦水友赛部分wp

目录 ①easy_include ②easy_web ③easy_login web一共5题,我出了3题,巧的是好像师傅们也只出了3题,跨年拿旗还是很快乐的,下面直接贴出自己的wp. ①easy_include pearcmd不解释 这里主要是 ,file://协议支持以fi…

Java中的序列化方法探索

.为什么要序列化 对象不序列化,能直接存储吗? 在 Java 中,序列化是将对象的状态信息转换为可以存储或传输的形式(例如,转换为字节流)的过程。在对象数据需要在网络上传输或需要在磁盘上持久化存储时&#…

Spring Boot学习随笔- 集成MyBatis-Plus(二)条件查询QueryWrapper、聚合函数的使用、Lambda条件查询

学习视频:【编程不良人】Mybatis-Plus整合SpringBoot实战教程,提高的你开发效率,后端人员必备! 查询方法详解 普通查询 // 根据主键id去查询单个结果的。 Test public void selectById() {User user userMapper.selectById(1739970502337392641L);System.out.print…

opencv期末练习题(3)附带解析

创建黑色画板,并支持两种画图功能 import mathimport cv2 import numpy as np """ 1. 创建一个黑色画板 2. 输入q退出 3. 输入m切换画图模式两种模式,画矩形和画圆形。用户按住鼠标左键到一个位置然后释放就可以画出对应的图像 "&qu…

Eureka学习思维导图

一、Eureka Server原理解析 参考:https://www.jianshu.com/p/eb690e6ab11d 二、Eureka Client源码解析 参考:https://www.jianshu.com/p/6e8850387da6

Threejs项目实战之四:实现地图雷达效果

目录 最终效果代码实现创建项目DigitalMapView.vue的核心代码 最终效果 最近事情比较多,今晚难得有空,就抽空完成了一个使用Threejs实现地图雷达扫描效果的程序,下面说下代码实现的原理及核心代码,老规矩,先看下效果图…

专业服务新篇章:ToB行业运营达人的能力与策略

又逢年底,这两天冷空气南袭,深圳的天气也转为湿冷,又到了年终总结复盘的时候了,其实这样的天气挺适合做深度的思考,清冷的空气,可以让人保持清醒。 月初市场同事希望我写点东西,题目内容自拟&a…

7-验证码识别

文章目录 验证码识别1、验证码的用途和分类验证码的作用验证身份验证行为 验证码的类型静态验证码:图片验证码问答式验证码问答式验证码行为式验证码:点击行为式验证码:拖动间接式验证码:短信、邮件、语音电话无感验证码 2、验证码…

2023年12月青少年软件编程Python等级考试(三级)真题试卷

2023年12月青少年软件编程Python等级考试(三级)真题试卷 题目总数:38 总分数:100 选择题 第 1 题 单选题 一个非零的二进制正整数,在其末尾添加两个“0”,则该新数将是原数的?&#x…

虹科方案丨从困境到突破:TigoLeap方案引领数据采集与优化变革

来源:虹科工业智能互联 虹科方案丨从困境到突破:TigoLeap方案引领数据采集与优化变革 原文链接:https://mp.weixin.qq.com/s/H3pd5G8coBvyTwASNS_CFA 欢迎关注虹科,为您提供最新资讯! 导读 在数字化工厂和智能制造时…

mcu与上位机通讯数据传输测速

问题 如何测量mcu与上位机通讯数据传输速度?(串口、USB) 解决 可以借助Bus Hound 将显示时间戳勾上。 发送一段固定长度的数据,然后除起始和结束的时间差 最后计算即可。

xadmin-plus

python之Xadmin-plus是什么? xadmin-plus: xadmin的django3.2版本支持。 Xadmin是一个非常优秀的Django Admin插件,可惜的是已经停止更新。Xadmin-plus对其进行了升级兼容。支持python3.10、Django3.2。 特性 Django Admin直接替换基于Twitter Boots…

安装Keras用于影像分割

conda create -n tfkears2024 python3.9.18 activate tfkeras2024 pip install tensorflow-gpu2.9.0 pip install keras pip install scipy pip install ipykernel ipython python -m ipykernel install --name tfkears2024

深度生成模型之GAN基础 ->(个人学习记录笔记)

文章目录 深度生成模型之GAN基础生成对抗网络1. 生成对抗网络如何生成数据2. 生成对抗原理3. GAN的核心优化目标4. D的优化5. GAN的理想状态6. GAN的训练7. 梯度不稳定与模式崩塌(collapse mode)问题8. 梯度消失问题 深度生成模型之GAN基础 生成对抗网络 1. 生成对抗网络如何…