目录
前篇:数据类型介绍:
C语言类型 : 内置类型 和 自定义类型
其中常见的内置类型如:
类型的意义:
1.使用这个类型开辟空间的大小 //如 int 开辟4个字节的空间 char 开辟一个字节的空间
2.如何看待内存空间的视角
类型基本分类:
整形家族:
浮点数家族
.
构造类型
指针类型
空类型
正文:整形在内存中的存储
上文提到内存的类型决定内存开辟空间的大小 那么内存空间的大小是怎么开辟的呢???
带着疑问我们来学习下面的内容:
原码反码补码
计算机中的整数有三种2进制表示方法,即原码、反码和补码。
三种表示方法均有符号位和数值位两部分,符号位都是用0表示“正”,用1表示“负”,而数值位
正数的原、反、补码都相同。
负整数的三种表示方法各不相同。
原码:
直接将数值按照正负数的形式翻译成二进制就可以得到原码。
反码:
将原码的符号位不变,其他位依次按位取反就可以得到反码。
补码:
反码+1就得到补码。
例:
1 :
00000000000000000000000000000001 -- 原码=反码=补码
-1:
10000000000000000000000000000001 -- 原码 第一位是符号位 (0为正 1为负)
1111111111111111111111111111111111110 -- 反码 除符号位外 按位取反
1111111111111111111111111111111111111 -- 补码 反码+1
对于整形来说 在内存中存放的就是补码
WHY??? 这里不禁有个大大滴问号 大到你们看不见
咳咳 言归正传 我们注意到CPU只有加法器 怪了 那我们平时的减法是谁做的 莫非....
呃 没错 就是转化成了1+(-1) 你猜对了
我们看下他们是怎么运算的
1:00000000000000000000000000000001 -- 补码
-1:
10000000000000000000000000000001 -- 原码
1111111111111111111111111111111111110 -- 反码
1111111111111111111111111111111111111 -- 补码
1+(-1)=
00000000000000000000000000000001
1111111111111111111111111111111111111
00000000000000000000000000000000 --> 0
到这里 我们的内容就结束了...
然后回顾所学:
这里存储的顺序不一样。。。why???
带着这个疑问 ,我们再看看 再看看
大小端
什么大端小端:
大端(存储)模式,是指数据的低位保存在内存的高地址中,而数据的高位,保存在内存的低地址
中;
小端(存储)模式,是指数据的低位保存在内存的低地址中,而数据的高位,,保存在内存的高地
址中。
什么意思?我看不懂...
画图来证:
为什么有大端和小端:
为什么会有大小端模式之分呢?这是因为在计算机系统中,我们是以字节为单位的,每个地址单元
都对应着一个字节,一个字节为8 bit。但是在C语言中除了8 bit的char之外,还有16 bit的short
型,32 bit的long型(要看具体的编译器),另外,对于位数大于8位的处理器,例如16位或者32
位的处理器,由于寄存器宽度大于一个字节,那么必然存在着一个如何将多个字节安排的问题。因
此就导致了大端存储模式和小端存储模式。
例如:一个 16bit 的 short 型 x ,在内存中的地址为 0x0010 , x 的值为 0x1122 ,那么 0x11 为
高字节, 0x22 为低字节。对于大端模式,就将 0x11 放在低地址中,即 0x0010 中, 0x22 放在高
地址中,即 0x0011 中。小端模式,刚好相反。我们常用的 X86 结构是小端模式,而 KEIL C51 则
为大端模式。很多的ARM,DSP都为小端模式。有些ARM处理器还可以由硬件来选择是大端模式
还是小端模式。
一些知识点补充:
char 类型的范围是 -128 ->127
数字放到char 类型中时会发生截断
同时再用%d输出char 类型上面的数字时 应进行整形提升:
这里我们浅举一个栗子
这里小伙伴们就要问了 为啥C是255呢 ??
这里的c存储在char 中的也是11111111
进而进行整形提升 无符号位提升时整形补0
00000000000000000000000011111111
有符号数和无符号数的取值范围怎么界定?