数据在内存中的存储(整型篇)

1.辨析原码反码补码:

        1.原码:有32位(int类四个字节,一个字节八个比特位),第一位是符号位,0正1负,其余为二进制位。

        2.计算一般是对原码进行计算,但在负数计算使用原码会导致程序出错,所以负数计算中使用反码,反码就是除了符号位,其余位置取反,反码存在的原因就是负数的计算

        3.虽然有了反码,但遇到负数跨0比如-6+7=1的问题时无法解决,所以产生了补码,补码等于负数的反码加1

2.正整数的原码补码反码都相等,负数的原码正常,反码为第一位不变其余位按位取反,补码位反码加一

3.在整形存储中一般以补码的形式存在,因为这样可以使符号位与数值位统一处理,加法和减肥都可以统一处理(cpu只有加法器),其运算过程是相同的不需要额外硬件

4.大端和小端:超过1字节的数据在存储的时候就会存储顺序的问题,按照不同的存储顺序,分为大端字节序存储和小端字节序存储:

        1.大端模式:数据的低位字节内容保存在内存的高地址处,数据的高位字节内容保存在内存的低地址处

        2.小端模式:低位字节内容保存在内存的低地址处,高位字节内容保持在高地址处

5.大小端存在的原因:

6.判断大小端的方法

7.例题:

析题:在内存中,数据储存首先进行一个截断操作,将变量补码的后八位取出,然后会进行一个还原操作,会用符号位的数值将截断码补成32位,补充之后的码继续作为原码。以‘%d'的形式打印,就是打印一个十进制有符号的整数,而操作对象是变量的补码,a,b两个变量的补码的运算结果为-1,而c的补码首位是0.所以它的补码等于原码等于它本身,所以是255

8.例题2:

析题:内存存储

%u表示打印十进制无符号整型,上表表示了在内存中所有有符号字符型的存储可能(8个字节),可以发现范围是+127到-128,而中间的0000000会自动解析为128,无符号字符型的取值为0到255,

而无符号整型的补码是它自己,直接把128的补码的截断补充的形式打印出来

9.例题3

答案是256,为啥?

析题:

char类型的整型范围有以上规律,是一个闭合的环,而strlen函数就是找\0,而'\0'的asc码值为0,就是找char 0的位置,按照上图正好循环一圈,为255个数

10.例题4

析题:无符号整型也是一个闭环,0-1等于2的33次方-1(2的33次方减1然后加一为2的33次方,但int只能储存2的32次方,所有按照截断方法来看该值就是0),就是所有位都是1然后再减。

11.在强转出现时,应先计算右侧式子,然后再进行强转

12.例题五

析题:

先假设数据的存储是小端类型:

01 00 00 00 02 00 00 00 03 00 00 00 04 00 00 00

p1取的是数组的地址,加一代表指针指向了数组最后一个元素的后面,此时指针类型为数组指针,

此时将指针转化为int*型,每次进行运算时移动四个字节,而p1[-1]代表向前移动四个字节,然后读取,为4,而p2的运算,依据11,指向2的同时进行类型转换为int类型,而转换为int类型的同时编译器会读取向后的四位为一个数字2000000,前面的0不读取,然后转换为int*类型然后读取打印,结果为2000000。
 

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

笔记本电脑安装了Ubuntu系统设置关盖/合盖不挂起/不睡眠

文章目录 简介通过gnome-tweaks设置通过更改登录配置文件logind.conf设置参考资料 简介 学习工作中需要用到笔记本安装Ubuntu Linux系统,并且需要关盖电脑不关机、不挂起且不睡眠。为此,本篇博客整理了两种常规操作方式,并给了详细的步骤&am…

centos7安全防护_CPU占用率超过百分之300_centos7.4中毒CPU百分之百_清理毒源---Linux工作笔记068

执行top命令的时候看到有个进程: sshd占用cpu百分之300多...而且就算是kill -9 杀掉进程以后,进程又会自动启动 ll /proc/7298 我们执行这个命令,可以看到有个/var/tmp/sshd的文件 我们进入cd /var/tmp 然后我们执行 rm -rf sshd删除这个文件,然后我们再去top可以看到 cpu就…

人工智能(pytorch)搭建模型22-基于pytorch搭建SimpleBaseline(人体关键点检测)模型,并详细介绍该网络模型与代码实现

大家好,我是微学AI,今天给大家介绍一下人工智能(pytorch)搭建模型22-基于pytorch搭建SimpleBaseline(人体关键点检测)模型,并详细介绍该网络模型与代码实现。本文将介绍关于SimpleBaseline模型的原理,以及利用pytorch框架搭建模型…

轻阅书城图书交易平台

SpringBoot MySQL JSP等技术实现的博客系统 技术栈 后端: 核心框架:SpringBoot 持久层框架:MyBatis 分页插件:PageHelper 数据库:MySQL 前端: JS、Jquery、CSS、Bootstrap 项目包含源码和数据库文件。…

Leetcode刷题笔记题解(C++):92. 反转链表 II

思路:获取要反转的区间,拆开之后进行反转再拼接 /*** Definition for singly-linked list.* struct ListNode {* int val;* ListNode *next;* ListNode() : val(0), next(nullptr) {}* ListNode(int x) : val(x), next(nullptr) {}* …

vue零基础

vue 与其他框架的对比 框架设计模式数据绑定灵活度文件模式复杂性学习曲线生态VueMVVM双向灵活单文件小缓完善ReactMVC单向较灵活all in js大陡丰富AngularMVC双向固定多文件较大较陡(Typescript)独立 更多对比细节:vue 官网:ht…

WhatsApp获客怎么做?记住这几个技巧!

一、背景介绍 随着全球数字化趋势的不断发展,越来越多的企业开始将目光转向数字化营销,WhatsApp作为一种国际通用的社交媒体平台,具有广泛的使用群体和强大的社交功能,成为了很多企业进行营销推广的重要渠道。 那么,…

Redis对象——内存回收,对象共享和空转时长

一. 内存回收 因为C语言不具备内存回收功能,所以Redis在自己的对象系统中构建了一个引用计数技术实现内存回收机制。通过这一机制,程序可以通过跟踪对象的引用计数信息,在适当的时候自动释放对象并进行内存回收。 内每一个对象的引用计数信息…

LangChain(0.0.340)官方文档七:Retrieval——document_loaders

LangChain官网、LangChain官方文档 、langchain Github、langchain API文档、llm-universe 文章目录 一、简介1.1 BaseLoader1.2 文本加载(TextLoader) 二、 CSV(CSVLoader)2.1 默认加载2.2 指定一列来标识文档来源​ 三、 HTML l…

马尔科夫决策过程(Markov Decision Process)揭秘

RL基本框架、MDP概念 MDP是强化学习的基础。MDP能建模一系列真实世界的问题,它在形式上描述了强化学习的框架。RL的交互过程就是通过MDP表示的。RL中Agent对Environment做出一个动作(Action),Environment给Agent一个反馈&#xff…

mysql原理--B+树索引的使用

1.索引的代价 在介绍如何更好的使用索引之前先要了解一下使用这玩意儿的代价,它在空间和时间上都会拖后腿: (1). 空间上的代价 这个是显而易见的,每建立一个索引都要为它建立一棵 B 树,每一棵 B 树的每一个节点都是一个数据页&…

mmseg上手自己的数据集

制作自己的数据集,VOC格式为例。 这三个文件包括数据集的名称。可以使用labelme脚本自动生成。 跟据预测类别修改配置文件 D:\projects\mmsegmentation-main\mmseg\datasets\voc.py 因为是voc格式的数据集,在这个文件里进行配置,修改成自己数…