本文目录一览:
- 1、在C语言中各种数据类型各占多少位
- 2、C语言中128L与128所占存储空间的区别?
- 3、c语言 1个字节 范围为什么是 -128 — 127,-128怎么算的
- 4、如何在c语言中构造一个128位数
在C语言中各种数据类型各占多少位
(一)32位平台:
分为有符号型与无符号型。
有符号型:
short 在内存中占两个字节,范围为-2^15~(2^15-1)
int 在内存中占四个字节,范围为-2^31~(2^31-1)
long在内存中占四个字节,范围为-2^31~2^31-1
无符号型:最高位不表示符号位
unsigned short 在内存中占两个字节,范围为0~2^16-1
unsigned int 在内存中占四个字节,范围为0~2^32-1
unsigned long在内存中占四个字节,范围为0~2^32-1
实型变量:
分单精度 float 和双精度 double 两种形式:
float:占四个字节,提供7~8位有效数字。
double: 占八个字节,提供15~16位有效数字。
(二)16位平台:
1)整型(基本型):类型说明符为int,在内存中占2个字节。
2)短整型:类型说明符为short int或short。所占字节和取值范围均与整型(基本型)相同。
3)长整型:类型说明符为long int或long,在内存中占4个字节。
无符号型:类型说明符为unsigned。
无符号型又可与上述三种类型匹配而构成:
各种无符号类型量所占的内存空间字节数与相应的有符号类型量相同。但由于省去了符号位,故不能表示负数。
实型变量:
分为单精度(float型)、双精度(double型)和长双精度(long double型)三类。
单精度型占4个字节(32位)内存空间,其数值范围为3.4E-38~3.4E+38,只能提供七位有效数字。
双精度型占8 个字节(64位)内存空间,其数值范围为1.7E-308~1.7E+308,可提供16位有效数字。
长双精度型16 个字节(128位)内存空间,可提供18-19位有效数字。
C语言中128L与128所占存储空间的区别?
在32位的编译系统中他们两个都是占四个字节的存储空间。
如果是在16位的编译系统中,他们所占的存储空间分别是4和2个字节。
c语言 1个字节 范围为什么是 -128 — 127,-128怎么算的
正数一个字节最大只能是127,128超过了一个字节能表示的最大值,127是01111111,加1, 00000001等于
10000000,最高为是2的7次方等于128,由于一个字节的最大值是127,所以128就只能是-128,但是这里的符号位应该是补全的码,由于只有一个字节看不到
如何在c语言中构造一个128位数
在C语言中,并没有任何数据类型可以表示精确的128位数。所以要表示128位数,就必须用数组模拟。比如,用字符数组模拟,每位字符表示一位数,使用'0'~'9'表示各个位上的数值。
例如:
char num[129] = "12345678……";
表示数字12345678。 由于128位过长,就不举128位的例子了。
输入输出均可以用字符串的方式。
另外,做计算的话,就必须自己写函数了,如加减乘除模除等,对于这类实现,在算法中称为大数计算,如果需要,可以对此进行搜索,有很多优秀算法。