printfprintf

int a=123,b=12345,c=-1; 变量定义,整型,赋初值
float f=123; 变量定义,浮点实数,赋初值
printf("%4d,%4d,%d,%o,%x,%X\n",a,b,c,c,c,c);
printf("%f,%10f,%10.2f,%-10.2f,%e\n",f,f,f,f,f);
printf("%3s,%7.2s\n",“hello”,“HELLO”);
printf("%.4s,%-5.3s\n",“HELLO”,“hello”);
printf(""\x48\x65\x6c\x6c\x6f\x2c\x57\x6f\x72\x6c\x64\x21"\n");

后面五行都是输出,不过格式不同,其具体含义如下(注意:C语言的输出格式非常复杂):

d格式符,用来输出十进制整数.

⑴%d,按整型数据的实际长度输出.

⑵%md,m为指定的输出字段的宽度,数据位数小于m,左边补空格,若大于m,按实际长度输出

⑶%ld,输出长整型数据(long)

o格式符,以八进制输出整数(不带符号,他将符号位也作为八进制数的一部分了)
⑴%o,参考%d的解释.

⑵%lo,参考%ld的解释.

⑶%mo,参考%md的解释.

X格式符,以十六进制输出整数
也是3种参考%d的解释.

★u格式符,用来将unsigned型数据,既无符号数,以十进制形式输出

★c格式符,输出一个字符.

★s格式符,输出一个字符串.

⑴%s,如printf("%s",“CHINA”)

⑵%ms,输出的字符串占m列,字符串长度小于m,左边补空格,如果超出则全部输出.

⑶%-ms,串小于m,则在m列范围内字符串左靠,右补空格.

⑷%m.ns,输出占m列,但只取字符串左端n个字符.这n个字符输出在m列的右边,然后左边补空格.

⑸%-m.ns,和上面的放下,就是n个字符输出在m列的左侧,右边补空格.n>m,那么m自动取n的值,既保证n个字符正常输出.

printf("%3s,%7.2s,%.4s,%-5.3s\n",“CHINA”,“CHINA”,“CHINA”,“CHINA”);

★f格式符,用来输出实数,以小数形式输出.

⑴%f,全部输出,而且输出6位小数.

⑵%m.nf,输出数据共占m列,n位小数,如果数据长度小于m那么左边补空格

⑶%-m.nf,和上面的m.nf相反,为左靠齐,右补空格.

★e,E格式符,以指数形式输出实数

⑴%e,不指定输出数据所占的宽度和数字部分的小数位数.

⑵%m.ne和%-m.ne,这里n指小数部分的位数

★g,G格式符,用来输出实数,它根据数值大小,自动选择f格式还是e格式,(选占宽最少的一种),且不输出无意义的0.这种格式用的不多.

那么,对照以上内容,这个程序的输出就应该是:

第一行 123,12345,-1,177777,ffff,ffff
第二行123.000000,123.000000, 123.00,123.00 ,1.23000e+2
第三行hello, HE
第四行HELL,hel
第五行"Hello,World"

猜你喜欢

转载自blog.csdn.net/weixin_43719397/article/details/84845464
今日推荐