c语言中int long float double 等类型所占字节及输出表示

c语言中int long float double 等类型所占字节及输出表示

 

16位编译器

 

char :1个字节
char*(即指针变量): 2个字节
short int : 2个字节
int: 2个字节
unsigned int : 2个字节
float: 4个字节
double: 8个字节
long: 4个字节
long long: 8个字节
unsigned long: 4个字节

 

 

32位编译器(看这里就行了,与16位机,64位机比较,粗体type为不同的,其余的都是相同)

 

char :1个字节
char*(即指针变量): 4个字节(32位的寻址空间是2^32, 即32个bit,也就是4个字节。同理64位编译器)(16位机,32位机,64位机各不相同)

short int : 2个字节
int: 4个字节(16位机是2B,32位&64位是4B)
unsigned int : 4个字节(16位机是2B,32位&64位是4B)

float: 4个字节
double: 8个字节

long: 4个字节(16位&32位是4B,64位是8B)
long long: 8个字节
unsigned long: 4个字节(16&32位是4B,64位是8B)

 

 

64位编译器

 

char :1个字节
char*(即指针变量): 8个字节
short int : 2个字节
int: 4个字节
unsigned int : 4个字节
float: 4个字节
double: 8个字节
long: 8个字节
long long: 8个字节
unsigned long: 8个字节

 

%c输出的是一个单字节字符

%f输出的是单精度实数

%d输出的是十进制整形数

%e输出的是科学记数法的实行数

%s输出是字符串

%g输出双精度实型数

%ld输出的是long类型的数

%lld输出的是long long 类型的数

%u输出的是无符号整形数

printf("%.10lf\n",f_a)输出小数点后10位,否则默认是小数点后6位

double 类型的输出为printlf("%lf",a);

例如:    double d=123456789.12345;
             printf("%.2lf",d);

输出为123456789.12,如果对小数点不控制,输出则为123456789.123450

结论:格式控制字符串的一般形式: %[修饰符]转换说明符,其中修饰符为任选项

表1:转换说明符

 

  • 6
    点赞
  • 32
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值