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

筑基七层 —— 数据在内存中的存储?拿来吧你

目录

零:移步

一.修炼必备

二.问题思考

三.整型在内存中的存储

三.大端字节序和小端字节序

四.浮点数在内存中的存储


零:移步

  CSDN由于我的排版不怎么好看,我的有道云笔记相当的美观,请移步至有道云笔记

一.修炼必备

 1.入门必备:VS2019社区版,下载地址:Visual Studio 较旧的下载 - 2019、2017、2015 和以前的版本 (microsoft.com)

 2.趁手武器:印象笔记/有道云笔记

 3.修炼秘籍:牛客网 - 找工作神器|笔试题库|面试经验|实习招聘内推,求职就业一站解决_牛客网 (nowcoder.com)

 4.雷劫必备:leetcode 力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台 

 注:遇到瓶颈怎么办?百度百科_全球领先的中文百科全书 (baidu.com)

二.问题思考

 1.C语言数据的类型?

 2.整数在计算机中二进制的表示形式有几种?正整数和负整数相同的吗?

 3.整数在内存中的存放的是什么?怎么验证是这样存放的?

 4.为什么计算机中存放的是补码?

 5.什么是字节序?

 6.数据的字节序是在内存中怎么存储的?

 7.如何判断一个数据的字节序是大端字节序还是小端字节序?

 8.浮点数在内存中的存储和整数的存储是一样的吗?

 9.浮点数的存储规则

三.整型在内存中的存储

 1.C语言数据的类型?

1)整型:char,short,int,long,long long

2)浮点型:float,double

3)构造类型:struct,union

4)指针类型:int*,char*,double*等

5)空类型:void(常用于函数的返回类型,指针类型,函数的参数)

 2.如何查看整数类型的值范围?

    ——在limits.h头文件中查看

 3.整数在计算机中二进制的表示形式有几种?正整数和负整数相同的吗?

  1)整数在计算机中的表示形式有:原码、反码、补码

  2)正整数的原码、反码、补码均相同

  3)负整数的原码、反码、补码的规则

原码:把整数直接按照二进制进行转化

反码:原码的符号位不变,其他位按位取反

补码:反码 + 1

#include <stdio.h>//原码、反码、补码的转化规则
int main()
{//正整数的原码、反码、补码相同int num1 = 5;//00000000 00000000 00000000 00000101  num1的补码//负整数的原码、反码、补码转化int num2 = -5;//10000000 00000000 00000000 00000101  原码//(原码符号位不变,其他位取反)//11111111 11111111 11111111 11111010  反码//(反码+1)//11111111 11111111 11111111 11111011  补码return 0;
}

 4.如何证明整型在内存中存储的是补码?

    ——使用负数证明

  1)打印出负数的十六进制形式(十六进制是无符号的打印)

#include <stdio.h>//证明整型在内存中存储的是补码
int main()
{int num1 = 1;//00000000 00000000 00000000 00000001   1的补码int num2 = -1;//11111111 11111111 11111111 11111111  -1的补码//注:每四个2进制位可以组成一个十六进制:ffffffprintf("%x\n", num1);//1printf("%x\n", num2);//fffffffreturn 0;
}

  运行结果如图:

  2)调试查看负数在内存中的存储形式 

 5.为什么计算机中存放的是补码? 

1)方便运算:省去了计算机判断符号位或判断+/-运算的麻烦,采用补码后,不管是加法还是减法均是使用加法进行运算(CPU只有加法器)

2)更加标准:保证了系统的编码的一致性和连续性,也同时避免了+/-0的麻烦 

 6.practice

  case 1:思考并分析

#include <stdio.h>int main()
{char a = -1;//默认是有符号数//10000001 原码//11111110 反码//11111111 补码//11111111 11111111 11111111 11111111 整型提升//11111111 截取(补码)//10000001 原码(-1)signed char b = -1;//b 和 a一样unsigned char c = -1;//10000001 原码//11111110 反码//11111111 补码//11111111 11111111 11111111 11111111 整型提升//11111111 截取 --无符号数:255printf("a=%d,b=%d,c=%d\n", a, b, c);//-1 -1,255return 0;
}

  运行结果如图:

  case 2:思考并分析 

#include <stdio.h>int main()
{char a = -128;//10000000 -- 补码//因为是无符号整型打印,需要整型提升//11111111 11111111 11111111 10000000  -- 4294967168(结果)printf("%u\n", a);//4294967168return 0;
}

  运行结果如图:

  case 3:思考并分析

#include <stdio.h>int main()
{char a = 128;//10000000//11111111 11111111 11111111 10000000 整型提升//-- 4294967168(结果)printf("%u\n", a);//4294967168return 0;
}

  运行结果如图:

  case 4:思考并分析 

#include <stdio.h>int main()
{int a = -20;//10000000 00000000 00000000 00010100 原码//11111111 11111111 11111111 11101011 反码//11111111 11111111 11111111 11101100 补码unsigned int b = 10;//11111111 11111111 11111111 11101100 补码(-20)//00000000 00000000 00000000 00001010 补码 (10)//11111111 11111111 11111111 11110110 运算结果(补码)//11111111 11111111 11111111 11110101//10000000 00000000 00000000 00001010  -10:结果printf("%d\n", a + b);return 0;
}

  运行结果如图:

  case 5:思考并分析 

#include <stdio.h>int main()
{unsigned int i;//为什么进行了死循环?//i是无符号整型//i = 0;执行i--的时候//00000000 00000000 00000000 00000000  0的补码//11111111 11111111 11111111 11111111  -1的补码(无符号数,最高位没有正负之分)//4294967295(-1的时候的值)for (i = 9; i >= 0; i--){printf("%u\n", i);}return 0;
}

  运行结果如图:

  case 6:思考并分析 

#include <stdio.h>
#include <string.h>int main()
{char a[1000];int i;for (i = 0; i < 1000; i++){a[i] = -1 - i;//11111111  -1的补码//11111110  -2的补码//11111101  -3的补码//……//10000000  -128的补码//01111111   127的补码//……//00000000   0的补码('\0')}printf("%d\n", strlen(a));//255return 0;
}

  一图了解char的范围:

  运行结果如图:

  case 7:思考并分析

#include <stdio.h>unsigned char i;
int main()
{for (i = 0; i <= 255; i++){printf("hehe\n");//11111111 i为255的时候//00000000 255+1后的值//所以为死循环}return 0;
}

  运行结果如图:

三.大端字节序和小端字节序

 1.什么是字节序?

    ——字节序又称为端序或尾序,指计算机内存中多字节数据在内存中的排列顺序

 2.数据的字节序是在内存中怎么存储的?

    ——浮点数和整数的字节序都有大端和小端两种字节序

1)小端字节序

        ——数据的低位字节存储在内存的低地址处,高位字节存储在内存的高地址处

2)大端字节序

        ——数据的低位字节存储在内存的高地址处,高位字节存储在内存的低地址处

 3.如何判断一个数据的字节序是大端字节序还是小端字节序?

    ——内存中查看该数据的存储形式,看低位存放在内存中的位置

  图解:

  代码解释:

#include <stdio.h>int main()
{int num = 0x11223344;float data = 5.5;//101.1//01000000101100000000000000000000//40b00000:十六进制形式return 0;
}

  小端字节序在内存中的图解:

  大端字节序在内存中的图解: 

 4.一道笔试题加强巩固

    ——请判断一个机器是大端字节序还是小端字节序

思路分析:我们只需要判断取出1的最低位即可,如果是0,则是大端存储序列,如果是1,则是小端字节序

#include <stdio.h>//判断当前机器是大端还是小端字节序
int main()
{int a = 1;char* p = (char*)&a;if (*p == 1){printf("小端字节序\n");}else{printf("大端字节序\n");}return 0;
}

   代码是写出来了,但是这样写是不是有点太low了,我们换种方式

#include <stdio.h>//判断当前机器是大端还是小端字节序
int judge(int a)
{char* p = (char*)&a;return *p;//如果小端,直接返回1,大端返回0
}int main()
{int a = 1;if (judge(a) == 1){printf("小端字节序\n");}else{printf("大端字节序\n");}return 0;
}

  运行结果如图:

 

四.浮点数在内存中的存储

 1.怎么查看浮点数的值范围?

    ——在float.h头文件中查看

 

 2.浮点数的存储规则

  1)浮点数进行存储的形式:(-1)^S * M * 2^E;

    ——解释:S表示符号位,M表示有效数字:1

  2)在IEEE的规定下,最高位的1位S表示符号位,接下来的八位表示指数E,剩下的23位表示有效数字M

   float图解:

   double图解:

  3)由图知:float的指数位有8位,double的指数位有11位,float的M有23位,double的M有52位

  4)IEEE对M和E还有一些特别的规定

   i.因为1

   ii.指数E是一个无符号整数(unsigned int)

a.float的话,E的值在0~255之间;double的话,E的值在0~2047之间

b.注意,科学计数法中的E是可以是为负数的,所以我们在计算E的时候,应该加上一个中间值,float类型+127,double类型+1023

   iii.E从内存中取出的三种情况

a.E不为全0或全1

        ——使用E转化的十进制值减去127/1023得到真实值,在给有效数字加上小数点前面的1(常用)

b.E全为0

        ——E的值是1-127或1-1023,得到真实值,这个时候我们不需要在加上小数点前面的1了,这样做是为了表示正负0,以及接近0的很小的数值

c.E全为1

        ——这时,如果有效数字全为0,表示±无穷大(正负取决于符号位s)

 3.practice

  case 1:分析解释下面代码 

#include <stdio.h>int main()
{int num = 9;float* p = (float*)&num;printf("%d\n", num);//9printf("%f\n", *p);//0.000000//分析为什么是0.000000//00000000 00000000 00000000 00001001  9的补码//浮点数中看到的形式//0 00000000 00000000000000000001001//相当于0.00000000000000000001001 * (1 - 2^-126)//这个数非常小,而浮点数默认取小数点后6位,所以为0.000000*p = 9.0;//1001.0//1.001 * 2^3//S = 0,E = 2, M = 1.001//可以写出*p的的二进制序列//0 10000010 00100000000000000000000 *p的二进制序列//化为整数:1091567616printf("%d\n", num);//1091567616printf("%f\n", *p);//9.000000return 0;
}

  运行结果如图:

  case 2:分析并解释

#include <stdio.h>int main()
{float num = 5.5;//101.1 --> 1.011//S = 0,E = 2, M = 1.011 --> 得出二进制序列//0 10000001 01100000000000000000000  num的二进制序列int* p = (int*)&num;//01000000101100000000000000000000  结果:1085276160printf("%f\n", num);//5.500000printf("%d\n", *p);//1085276160*p = 5;//01000000 10110000 00000000 00000000序列变为://00000000 00000000 00000000 00000101  5//转化为float类型//0 00000000 00000000000000000000101  //结果:0.00000000000000000000101 * 2 ^ (-126);(极小的数)//转为float即为0.000000printf("%f\n", num);//0.000000printf("%d\n", *p);//5return 0;
}

  运行结果如图:

  !!!恭喜你,突破至筑基七层!!!

相关文章:

筑基七层 —— 数据在内存中的存储?拿来吧你

目录 零&#xff1a;移步 一.修炼必备 二.问题思考 三.整型在内存中的存储 三.大端字节序和小端字节序 四.浮点数在内存中的存储 零&#xff1a;移步 CSDN由于我的排版不怎么好看&#xff0c;我的有道云笔记相当的美观&#xff0c;请移步至有道云笔记 一.修炼必备 1.入门…...

Typecho COS插件实现网站静态资源存储到COS,降低本地存储负载

Typecho 简介Typecho 是一个简单、强大的轻量级开源博客平台&#xff0c;用于建立个人独立博客。它具有高效的性能&#xff0c;支持多种文件格式&#xff0c;并具有对设备的响应式适配功能。Typecho 相对于其他 CMS 还有一些特殊优势&#xff1a;包括可扩展性、不同数据库之间的…...

2月23号作业

题目&#xff1a;题目一&#xff1a;通过操作Cortex-A7核&#xff0c;串口输入相应的命令&#xff0c;控制LED灯进行工作--->上传CSDN 1.例如在串口输入led1on,开饭led1灯点亮 2.例如在串口输入led1off,开饭led1灯熄灭 3.例如在串口输入led2on,开饭led2灯点亮 4.例如在串口输…...

因果推断方法(一)合成控制

知道的跳过下面的简单介绍&#xff1a; 就是比如广告主投放了10w元&#xff0c;那么他的收益怎么算&#xff1f;哪些订单就是广告带来的&#xff0c;哪些是不放广告也会购买&#xff1f; 合成控制法是目前我实际应用发现最好用的。置信度高&#xff0c;且容易理解。 简单讲下思…...

数据结构第12周 :( 有向无环图的拓扑排序 + 拓扑排序和关键路径 + 确定比赛名次 + 割点 )

目录有向无环图的拓扑排序拓扑排序和关键路径确定比赛名次割点有向无环图的拓扑排序 【问题描述】 由某个集合上的一个偏序得到该集合上的一个全序&#xff0c;这个操作被称为拓扑排序。偏序和全序的定义分别如下&#xff1a;若集合X上的关系R是自反的、反对称的和传递的&…...

Linux安装docker(无网)

1. 下载Docker安装包 下载地址&#xff1a;https://download.docker.com/linux/static/stable/x86_64/ 如果服务器可以联网可以通过wget下载安装包 wget https://download.docker.com/linux/static/stable/x86_64/docker-18.06.3-ce.tgz2. 解压安装 tar -zxvf docker-18.06…...

解决JNI操作内核节点出现写操作失败的问题

Android 9.0下&#xff0c;因为采取了SEAndroid/SElinux的安全机制&#xff0c;即使拥有root权限&#xff0c;或者对某内核节点设置为777的权限&#xff0c;仍然无法在JNI层访问。 本文将以用户自定义的内核节点/dev/wf_bt为例&#xff0c;手把手教会读者如何在JNI层获得对该节…...

纵然是在产业互联网的时代业已来临的大背景下,人们对于它的认识依然是短浅的

纵然是在产业互联网的时代业已来临的大背景下&#xff0c;人们对于它的认识依然是短浅的。这样一种认识的最为直接的结果&#xff0c;便是我们看到了各式各样的产业互联网平台的出现。如果一定要找到这些互联网平台的特点的话&#xff0c;以产业端为出发点&#xff0c;无疑是它…...

干翻 nio ,王炸 io_uring 来了 !!(图解+史上最全)

大趋势&#xff1a;全链路异步化&#xff0c;性能提升10倍 随着业务的发展&#xff0c;微服务应用的流量越来越大&#xff0c;使用到的资源也越来越多。 在微服务架构下&#xff0c;大量的应用都是 SpringCloud 分布式架构&#xff0c;这种架构总体上是全链路同步模式。 全链…...

ur3+robotiq ft sensor+robotiq 2f 140+realsense d435i配置rviz,gazebo仿真环境

ur3robotiq ft sensorrobotiq 2f 140realsense d435i配置rviz&#xff0c;gazebo仿真环境 搭建环境&#xff1a; ubuntu: 20.04 ros: Nonetic sensor: robotiq_ft300 gripper: robotiq_2f_140_gripper UR: UR3 reasense&#xff1a; D435i 通过下面几篇博客配置好了ur3、力传…...

ASP.NET Core MVC 项目 AOP之Authorization

目录 一&#xff1a;说明 二&#xff1a;传统鉴权授权的基本配置 三 &#xff1a;角色配置说明 四&#xff1a;策略鉴权授权 五&#xff1a;策略鉴权授权Requirement扩展 总结 一&#xff1a;说明 鉴权&#xff1a;是指验证你是否登录&#xff0c;你登录后的身份是什么。…...

智能新冠疫苗接种助手管理系统

项目背景介绍 近几年来,网络事业&#xff0c;特别是Internet发展速度之快是任何人都始料不及的。目前&#xff0c;由于Internet表现出来的便捷&#xff0c;快速等诸多优势&#xff0c;已经使它成为社会各行各业&#xff0c;甚至是平民大众工作&#xff0c;生活不可缺少的一个重…...

Python+Selenium4元素交互1_web自动化(5)

目录 0. 上节回顾 1. 内置的等待条件 2. 元素属性 1. Python对象属性 2. HTML元素属性 3. 元素的交互 1. 输入框 2. 按钮 3. 单选框和复选框 0. 上节回顾 DEBUG的方式&#xff1a;JS断点 Python断点编程语言提供的等待方式&#xff1a;sleepselenium提供的等待方式&…...

2023双非计算机硕士应战秋招算法岗之深度学习基础知识

word版资料自取链接&#xff1a; 链接&#xff1a;https://pan.baidu.com/s/1H5ZMcUq-V7fxFxb5ObiktQ 提取码&#xff1a;kadm 卷积层 全连接神经网络需要非常多的计算资源才能支撑它来做反向传播和前向传播&#xff0c;所以说全连接神经网络可以存储非常多的参数&#xff0c;…...

Python opencv进行矩形识别

Python opencv进行矩形识别 图像识别中,圆形和矩形识别是最常用的两种,上一篇讲解了圆形识别,本例讲解矩形识别,最后的结果是可以识别出圆心,4个顶点,如下图: 左边是原始图像,右边是识别结果,在我i5 10400的CPU上,执行时间不到8ms。 识别出结果后,计算任意3个顶点…...

网安入门必备的12个kali Linux工具

kali Linux工具帮你评估 Web 服务器的安全性&#xff0c;并帮助你执行黑客渗透测试。 注意&#xff1a;这里不是所提及的所有工具都是开源的。 1. Nmap Nmap &#xff08; 网络映射器 &#xff09;是一款用于 网络发现 和 安全审计 的 网络安全 工具. 主机发现,端口扫描,版本…...

【测试面试】头条大厂,测试开发岗真实一面。你能抵得住吗?

目录&#xff1a;导读前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结&#xff08;尾部小惊喜&#xff09;前言 小吴&#xff1a; 现…...

分享app的测试技巧

前言 今天笔者想和大家来唠唠app测试&#xff0c;现在的app有非常的多&#xff0c;这些app都是需要经过测试之后才能发布到应用市场中&#xff0c;app已经成为了我们日常生活中不可或缺的一部分了&#xff0c;但它的功能必须强大&#xff0c;才能受到消费者的重视&#xff0c;…...

HTML 基础【快速掌握知识点】

目录 一、什么是HTML&#xff1f; 二、HTML的发展史 三、HTML5的优势 四、HTML基本结构 五、DOCTYPE声明 六、title标签 七、meta标签 八、标题标签 九、段落标签 十、换行标签 十一、水平线标签 十二、字体样式标签 十三、特殊符号 十四、图像标签 十五、链接标…...

SpringBoot入门(二)

这里写目录标题一、SpringBoot整合Junit1.1 搭建SpringBoot工程1.2 引入starter-test起步依赖1.3 编写类1.4 测试二、SpringBoot整合mybatis2.1 搭建SpringBoot工程2.2 引入mybatis起步依赖&#xff0c;添加驱动2.3 编写DataSource和MyBatis相关配置2.4 定义表和实体类2.5 编写…...

大数据|大数据基础(概念向)

目录 &#x1f4da;大数据概念 &#x1f407;常见数据存储单位 &#x1f407;大数据的特点&#xff08;5V&#xff09; &#x1f407;大数据 VS 数据库 &#x1f31f;数据库 &#x1f31f;大数据 &#x1f4da;大数据业务分析基本步骤 &#x1f407;收集数据 &#x1f4…...

若依配置教程(九)若依前后端分离版部署到服务器Nginx(Windows版)

搭建若依环境 要部署到服务器上&#xff0c;首先要在本地运行若依系统 文章目录搭建若依环境后端部署1.在application.yml中修改后台端口&#xff0c;这里默认是8080。2.在application-druid.yml中修改正式环境数据库。3.后端打包部署前端部署下载安装NginxNginx代理配置启动N…...

【仔细理解】计算机视觉基础1——特征提取之Harris角点

Harris角点是图像特征提取中最基本的方法&#xff0c;本篇内容将详细分析Harris角点的定义、计算方法、特点。 一、Harris角点定义 在图像中&#xff0c;若以正方形的小像素窗口为基本单位&#xff0c;按照上图可以将它们划分三种类型如下&#xff1a; 平坦区域&#xff1a;在任…...

Elasticsearch7.8.0版本进阶——近实时搜索

目录一、近实时搜索的概述1.1、按段&#xff08;per-segment&#xff09;搜索1.2、更轻量的方式搜索二、为什么Elasticsearch是 近 实时搜索三、如何解决索引了一个文档然后却没有搜到四、哪种情况不需要每秒刷新4.1、使用 Elasticsearch 索引大量的日志文件4.2、使用 Elastics…...

OAK相机深度流探测草莓距离

编辑&#xff1a;OAK中国 首发&#xff1a;oakchina.cn 喜欢的话&#xff0c;请多多&#x1f44d;⭐️✍ 内容可能会不定期更新&#xff0c;官网内容都是最新的&#xff0c;请查看首发地址链接。 ▌前言 Hello&#xff0c;大家好&#xff0c;这里是OAK中国&#xff0c;我是助手…...

文件共享服务器(CIFS)的相关知识及指令

文件共享服务器&#xff08;CIFS&#xff09; 微软开发的 共享服务器概述 通过网络提供文件共享拂去&#xff0c;提供文件下载和上传服务&#xff08;类似于FTP服务器&#xff09; 创建共享 通过本地登录时&#xff0c;仅受NTFS权限的控制通过网络访问时&#xff0c;受共享…...

springcloud-2service consumer

创建使用会员微服务模块-service consumer思路分析/图解创建Moduel(member-service-consumer-80) & 完成配置new Module->member-service-consumer-80->finish检查父子项目的pom是否添加相应的对应module和parent本项目的pom.xml可以参考provider的&#xff0c;并删掉…...

JavaScript 进阶--charater3

文章目录前言一、编程思想1.1 面向过程介绍1.2 面向对象编程 (oop)对比二、构造函数三、原型3.1原型3.2 constructor 属性3.3 对象原型3.4 原型继承3.5 原型链总结前言 &#x1f191;学习目标 理解面向对象思想&#xff0c;掌握函数原型对象运用面向对象封装继承特点&#xf…...

Solon2 之基础:三、启动参数说明

启动参数&#xff0c;在应用启动后会被静态化&#xff08;为了内部更高效的利用&#xff09;。比如&#xff0c;想通过体外扩展加载配置&#xff0c;是不能改掉它们的。 1、启动参数 启动参数对应的应用配置描述–envsolon.env环境&#xff08;可用于内部配置切换&#xff09…...

引入防关联浏览器以防止数据盗窃

目前&#xff0c;互联网已成为我们生活中不可缺少的且不断发展的一部分。因此&#xff0c;互联网变得更加复杂和多样化&#xff0c;每天都有新的技术、服务和应用推出。在这个不断变化的环境中&#xff0c;虚拟浏览器最近作为一种革命性的新方式出现在互联网上。 简而言之&…...