C语言函数printf(“%*.*s“,2,4,“abcdefg“);的解释

C语言中,格式输出函数printf的一般使用形式为:

 

printf(“格式控制字符串”,输出项列表);

而格式说明部分的形式是: 

 

 

%[flags] [width] [.precision] [F|N|h|l] type

   各部分说明如下:

  • “[]”表示该项为可选项,即可有可无,如 printf("%d",100);
  • flags为可选择的标志字符,常用的标志字符有:
 -   ——左对齐输出,默认为右对齐输出;
+   ——正数输出加号(+),负数输出减号(-);
空格 ——正数输出空格代替加号(+),负数输出减号(-)。
  • width为可选择的宽度指示符。
用十进制正整数表示 设置输出值得最少字符个数。不足则补空格,多出则按实际输出,默认按实际输出,例如:
printf("%8d\n",100);       printf("%6d\n",100);       printf("%-8d\n",100);        printf("%+8\n",100);

输出结果为:

└┘└┘└┘└┘└┘100      

└┘└┘└┘100          

100└┘└┘└┘└┘└┘     

└┘└┘└┘└┘+100

  • [.prec]为可选的精度指示符

用“小数点”加“十进制正整数”表示,对“整数”、“实数”和“字符串”的输出有如下功能:

对“整数”,表示至少要输出的数字个数,不足补数字0,多则原样输出;

对“实数”,表示小数点后至多输出的数字个数,不足则补数字0,多则做舍入处理;

对“字符串”,表示最多输出的字符个数,不足原样输出,多则丢弃。

例如: printf("%8.2f\n",3.14159);                     
printf("%8.5f\n",3.14159);
输出结果为:  └┘└┘└┘└┘3.14                                
└┘3.14159
  • [F|N|h|I]为可选的输出长度修饰符,其功能如下:
F ——输出远指针存放的地址;
N——输出近指针存放的地址;
h——输出短整型数据的值;
l——输出长整型或双精度型数据的值。
例如:long  n=40000;

            printf("%8ld\n",n);/*因为200*200是长整型数据*/

  • type为可选的格式字符,用来进行格式转换。

 

对于

 printf("%*.*s",m,n,"abcdefg");

中,参数[width]和参数[.precision]用*表示,* 表示不定长度,其值由m和n决定。在这里

 

printf("%*.*s",m,n,"abcdefg");  等价于  printf("%m.ns","abcdefg");

结合上述分析,printf("%*.*s",2,4,"abcdefg"); 其输出结果为 abcd 。

 

  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值