C语言的基本类型在内存中怎么储存的?

Python010

C语言的基本类型在内存中怎么储存的?,第1张

1、整型数据:所有整数(正负零)在内存中都是以补码的形式存在。对于一个正整数来说,它的补码就是它的原码本身。对于一个负整数来说,它的补码为原码取反再加1。

2、字符型数据:把字符的相对应的ASCII码(整数,映射关系见ASCII码表)放到存储码单元中,而这些ASCII代码值在计算机中同样以二进制补码的形式存放的。

3、实型数据:也叫浮点数,在计算机中也是以二进制的方式存储,关键在于如何将十进制的小数转化为二进制来表示。

扩展资料

C语言存储数据使用注意事项

C语言中(包括C++/Java)实际存储浮点数都不是这样直接存储“整数二进制+小数二进制”就完事的,这只是第一步。转化二进制以后还要进行处理,实际的存储标准是IEEE754

遇见一直“乘不净”的浮点数,最终能取多少位取决于编译器对应的浮点类型数据的分配字节,字节数越多越精确。故double要比float精确不仅仅是整数部分上限更高,小数部分也能取到更低的位数,故而更精确。

尽量避免大的浮点数和小浮点数运算,由于浮点数存储的特点,常常会使小的浮点数丢失且判断两个浮点数或一个浮点数和整数,常量是否相等,使用abs(x-y)<0.000001这种形式。

参考资料来源:百度百科—整型数据

参考资料来源:百度百科—字符型数据

参考资料来源:百度百科—浮点数

C语言中内存为分三类:栈区、堆区、静态数据区。

局部变量在栈上分配,函数调用前的栈指针,要和函数返回后的栈指针一样,否则就会出错。

void test(void)

{

char i,a[10]

printf("0x%x", &i)

printf("0x%x", a)

printf("0x%x", a+1)

printf("0x%x", a+2)

printf("0x%x", a+3)

}

扩展资料

c语言数组在内存分配

示例:

#include<stdio.h>

int main()

{

int a[4] = {11,12,13,14}

int b[4] = {21,22,23,24}

int *pa = &a

int i = 0

while(i<8)

{

i++

printf("now *p value = %d and",*pa)

printf("p addr value = %d \n",pa)

pa++

}

return 0

}