(1)各种数据类型在16位、32位和64位系统下所占字节差异简介(2)各种数据类型的输出控制符

参考:
链接:https://blog.csdn.net/liu1055087125/article/details/66478048

一、各种数据

编写C、C++程序时需要考虑每种数据类型在内存中所占的内存大小,即使同一种数据类型在不同平台下所占内存大小亦不相同,具体对比如下:

数据类型16位系统(byte)32位系统(byte)64位系统(byte)备注
char111
short 、unsigned short222
int、unsigned int244
long、unsigned long448
float444
double888
long long888
long double10/1210/16有效位10字节。32位为了对齐实际分配12字节;64位分配16字节
指针248

二、输出控制符

http://c.biancheng.net/cpp/html/33.html
文章目录
C语言输出格式控制符汇总
0.格式字符串通用格式

  1. 标志位
    2.输出最小宽度
    3.精度
    4.长度
    5.类型 (由于经常用,所以放在了前面)

5.类型

类型字符用以表示输出数据的类型,其格式符和意义如下表所示:

格式字符意义
d以十进制形式输出带符号整数(正数不输出符号)
o以八进制形式输出无符号整数(不输出前缀0)
x,X以十六进制形式输出无符号整数(不输出前缀Ox)
u以十进制形式输出无符号整数
f以小数形式输出单、双精度实数
e,E以指数形式输出单、双精度实数
g,G以%f或%e中较短的输出宽度输出单、双精度实数
c输出单个字符
s输出字符串

这个不予演示。

0.格式字符串通用格式

在Turbo C中格式字符串的一般形式为:

[标志] [输出最小宽度] [.精度] [长度] 类型
其中方括号[]中的项为可选项。

1. 标志位

标 志 意义

  • 结果左对齐,右边填空格
  • 输出符号(正号或负号)
    空格 输出值为正时冠以空格,为负时冠以负号
    #对c、s、d、u类无影响; 对o类,在输出时加前缀o; 对x类,在输出时加前缀0x; 对e、g、f 类当结果有小数时才给出小数点。
    演示:

在这里的左对齐的演示和第二部分最小宽度放在一起.

int a = -100, b = 101;
printf("%+d|%+d|\n", a, b);
/输出结果
-100|+101| //将符号也输出出来了
*********************/

int a = 100, b = -101;
printf("|% d|% d|\n", a, b);
/输出结果
| 100|-101|//注意到100前面有个空格 正数符号用空格表示 负数直接输出符号
*********************/

int a = 100;
float b = 99.99, c = 99;
printf("%x|%f|\n", a, b);//%x 表示以十六进制输出这个数
printf("%#x|%#f|\n", a, b);
/输出结果
64|99.989998|
0x64|99.989998|//注意前缀
*********************/

2.输出最小宽度

用十进制整数来表示输出的最少位数。若实际位数多于定义的宽度,则按实际位数输出,若实际位数少于定义的宽度则补以空格或0。

int a=100,b=101,c=102;
printf("%6d|%6d|%6d|\n",a,b,c);//每一个数字占6位 不足处补空格 注意printf是默认右对齐
printf("%-6d|%-6d|%-6d|",a,b,c);//- 标志位表示左对齐,右边不足的地方补空格
/输出结果
100| 101| 102|//第一行默认右对齐 左边补空格
100 |101 |102 |//第二行-表示 左对齐 右边补空格
*********************/

3.精度

精度格式符以“.”开头,后跟十进制整数。
本项的意义是:

如果输出数字,则表示小数的位数;
如果输出的是字符,则表示输出字符的个数;
若实际位数大于所定义的精度数,则截去超过的部分。
演示:

char a[]=“abcdef”;
float b = 99.12345, c = 99;
printf("%s|%f|%f\n", a, b, c);//正常输出
printf("%.5s|%.3f|%.2f\n", a, b, c);//控制字符长度 以及小数位数
/输出结果
abcdef|99.123451|99.000000
abcde|99.123|99.00 //字符串a只输出了前5位 后面两个小数都被控制了小数位数
*********************/

4.长度

长度格式符为h、l两种,h表示按短整型量输出,l表示按长整型量输出。

long int a = 270000000;
printf(“long int = %d;int = %d.\n”,sizeof(long int),sizeof(int));
printf("|%d|%d|%d|\n",a,a,a);
printf("|%hd|%ld|%d|",a,a,a);
/输出结果
long int = 4;int = 4.//在笔者电脑上两个编译器long int的实现的长度都和int 一致 所以这里%d 和%ld 都还可以的 但是在其他电脑上就不一定了
|270000000|270000000|270000000|
|-8320|270000000|270000000| //短整型时出错了
*********************/

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值