关于数据在内存中的存储(整形篇)

简介: 关于数据在内存中的存储(整形篇)

1.数据类型介绍


1.整形家族

类型 字节数 取值范围
int(整形) 4

-2147483648~2147483647

short(短整型) 2 -32768~32767
long(长整型) 4/8 -2^31~(2^31-1)
long long(双长型) 8 -2^63~(2^63-1)
char 1 -2^7~(2^7-1)

整形家族又分为无符号和有符号,int 其实为有符号整形,(signed)int , 有符号的我们一般会省略signed。

上表其实都为有符号类型。

       

类型 字节数 取值范围
unsigned int(无符号整形) 4 0~(2^32-1)
unsigned short(无符号短整型) 2 0~(2^16-1)
unsigned long(无符号长整形) 4/8 0~(2^32-1)
unsigned long long(无符号长整形) 8 0~(2^64-1)
unsigned char(无符号字符型) 1 0~255

有符号类型和无符号类型的区别在于无符号类型将存放负数的内存全部放到正数上。

sizeof(short) <= sizeof(int) <= sizeof(long) <= sizeof(long long)

#sizeof是测量类型或变量长度的运算符,%zu是用来专门打印size_t类型的值,也就是sizeof的返回值。

char表示的是字符,但是char类型的本质是ASCII码值,实质为整形,所以划分到整形家族。


  • 大写字母‘A’的ASCII代码是十进制数65,大写字母的范围在65~90。
  • 小写字母‘a’的ASCII代码是十进制数97,小写字母的范围在97~122。
  • 小写字母十进制数 = 大写字母十进制数 + 32

2.浮点数家族

只要是使用小数就可以使用浮点型。

类型 字节数 有效数字 数值范围(绝对值)
float 4 6 0以及1.2*10^(-38)~3.4*10^38
double 8 15

0以及2.3*10^(-308)~1.7*10^308

long double 8

15

0以及2.3*10^(-308)~1.7*10^308
long double 16 19 0以及3.4*10^(-4932)~1.1*10^4932
  • 不同的编译系统对long double型的处理方法不同,分配的字节也会有所不同。

意义:

  • 使用这类型开辟空间的大小(大小决定了使用范围)
  • 如何看待内存空间的视角

3.构造类型 (自定义类型-我们可以自己创造新的类型)

1.数组类型

int arr1[5];   类型: int [5]
int arr2[8];         int [8]
char arr2[5];        char [5]

2.结构体类型 struct

                    结构体介绍   结构体介绍

3.枚举类型 enum

4.联合类型 union

4.空类型

void test(void)
{
  printf("hehe\n");
}
int main()
{
  test();
  return 0;
}

第一个void 表示函数不会返回值

第二个void 表示函数不需要传任何参数

5. 指针类型

 int* p;
 char* i;

2.整形在内存中的存储

1.权重

数值有不同的表现形式:二进制、八进制、十进制、十六进制。

用不同的进制报达十进制的 21

二进制:0b10101(0b表示该表示为二进制)

八进制:025(25前的0表示该表示为八进制)

十六进制:0x15(0x表示该表示为十六进制)

计算机的数值储存方式为二进制,int 的容量为4个字节,也就是32(2^8)个比特位,

每个位置用1或者0来表示21在计算机中就是:

00000000000000000000000000010101(一共32位数字)

可以类比10进制来理解什么是权重   十进制数字123,就可以看作1*10^2+2*10+3*1=123

而10^2就是1的权重,10就是2的权重,1就是3的权重。

2.原码 反码 补码(二进制)

计算机在操作数字时用的是补码。


正数的原码、反码、补码都是一样的。

int a = 21;
  //00000000000000000000000000010101-原码
  //00000000000000000000000000010101-反码
  //00000000000000000000000000010101-补码

负数的原码、反码、补码转换规则:

原码:直接通过正负的形式写出的二进制序列就是原码

反码:原码的符号位不变,其他位按位取反得到的就是反码

补码:反码+1就是补码

int b = -21;
  //10000000000000000000000000010101-原码
  //11111111111111111111111111101010-反码
  //11111111111111111111111111101011-补码

可以看到的是正数和负数是通过第一个比特位来区别符号的

类比:

10000000000000000000000000000001所表达的数为 -1

00000000000000000000000000000001所表达的数为 1

3.大小端介绍

个数据存放在内存中的方式,我们分为大端字节序和小端字节序

不同的编译器采用大端或者小端

大端字节序储存:

  • 把一个数据的高位字节序的内容存放在低地址处,把低位字节序的内容放在高地址处,就是大端字节序。

int a =0x11 22 33 44(这里用十六进制是为了表达)

小端字节序储存:

  • 把一个数据的低位字节序的内容存放在低地址处,把高位字节序的内容放在高地址处,就是小端字节序。


当然我会给大家验证:

我用的是mcvs,可以看到用的是小端字节序存储的,

内存界面看到的15 00 00 00是十六进制,是为了方便我们观察,实际上计入计算机的是二进制。


目录
相关文章
|
2月前
|
存储 编译器 数据处理
C 语言结构体与位域:高效数据组织与内存优化
C语言中的结构体与位域是实现高效数据组织和内存优化的重要工具。结构体允许将不同类型的数据组合成一个整体,而位域则进一步允许对结构体成员的位进行精细控制,以节省内存空间。两者结合使用,可在嵌入式系统等资源受限环境中发挥巨大作用。
69 11
|
3月前
|
监控 算法 应用服务中间件
“四两拨千斤” —— 1.2MB 数据如何吃掉 10GB 内存
一个特殊请求引发服务器内存用量暴涨进而导致进程 OOM 的惨案。
|
3月前
|
存储 C语言
数据在内存中的存储方式
本文介绍了计算机中整数和浮点数的存储方式,包括整数的原码、反码、补码,以及浮点数的IEEE754标准存储格式。同时,探讨了大小端字节序的概念及其判断方法,通过实例代码展示了这些概念的实际应用。
140 1
|
3月前
|
存储
共用体在内存中如何存储数据
共用体(Union)在内存中为所有成员分配同一段内存空间,大小等于最大成员所需的空间。这意味着所有成员共享同一块内存,但同一时间只能存储其中一个成员的数据,无法同时保存多个成员的值。
|
2月前
|
缓存 Prometheus 监控
Elasticsearch集群JVM调优设置合适的堆内存大小
Elasticsearch集群JVM调优设置合适的堆内存大小
340 1
|
28天前
|
存储 监控 算法
深入探索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)程序计数器:保存指令执行的地址,方便线程切回后能继续执行代码
25 3
|
2月前
|
存储 缓存 监控
Elasticsearch集群JVM调优堆外内存
Elasticsearch集群JVM调优堆外内存
54 1
|
2月前
|
Arthas 监控 Java
JVM进阶调优系列(9)大厂面试官:内存溢出几种?能否现场演示一下?| 面试就那点事
本文介绍了JVM内存溢出(OOM)的四种类型:堆内存、栈内存、元数据区和直接内存溢出。每种类型通过示例代码演示了如何触发OOM,并分析了其原因。文章还提供了如何使用JVM命令工具(如jmap、jhat、GCeasy、Arthas等)分析和定位内存溢出问题的方法。最后,强调了合理设置JVM参数和及时回收内存的重要性。

热门文章

最新文章