printf的格式控制字符串
printf(“格式控制字符串”, 输出表列)
其中格式控制字符串⽤于指定输出格式。格式控制串可由格式字符串和⾮格式字符串两种组成。格式字符串是以%开头的字符串,在%后⾯跟有各种格式字符,以说明输出数据的类型、形式、长度、⼩数位数等。如:
“%d”表⽰按⼗进制整型输出;
“%ld”表⽰按⼗进制长整型输出;
“%c”表⽰按字符型输出等。
⾮格式字符串原样输出,在显⽰中起提⽰作⽤。输出表列中给出了各个输出项,要求格式字符串和各输出项在数量和类型上应该⼀⼀对应。
格式字符串
在Turbo C中格式字符串的⼀般形式为:
[标志][输出最⼩宽度][.精度][长度]类型。
其中⽅括号[]中的项为可选项。
各项的意义介绍如下。
1) 类型
类型字符⽤以表⽰输出数据的类型,其格式符和意义如下表所⽰:
格式字符  意义
d  以⼗进制形式输出带符号整数(正数不输出符号)
o  以⼋进制形式输出⽆符号整数(不输出前缀0)
x, X  以⼗六进制形式输出⽆符号整数(不输出前缀Ox)
u  以⼗进制形式输出⽆符号整数
f  以⼩数形式输出单、双精度实数
e, E  以指数形式输出单、双精度实数
printf怎么输出字符
g, G  以%f或%e中较短的输出宽度输出单、双精度实数
c  输出单个字符
s  输出字符串
2) 标志
标志字符为 - 、 + 、# 和空格四种,其意义下表所⽰:
标 志  意义
- 结果左对齐,右边填空格
+ 输出符号(正号或负号)
空格  输出值为正时冠以空格,为负时冠以负号
#  对c、s、d、u类⽆影响;
对o类,在输出时加前缀o;
对x类,在输出时加前缀0x;
对e、g、f 类当结果有⼩数时才给出⼩数点。
3) 输出最⼩宽度
⽤⼗进制整数来表⽰输出的最少位数。若实际位数多于定义的宽度,则按实际位数输出,若实际位数少于定义的宽度则补以空格或0。
4) 精度
精度格式符以“.”开头,后跟⼗进制整数。本项的意义是:如果输出数字,则表⽰⼩数的位数;如果输出的是字符,则表⽰输出字符的个数;若实际位数⼤于所定义的精度数,则截去超过的部分。
5) 长度
长度格式符为h、l两种,h表⽰按短整型量输出,l表⽰按长整型量输出。
#include "stdafx.h"
#include<stdio.h>
#include<string.h>
int main()
{
char c, s[20];
int a = 1234;
float f = 3.141592653589;
double x = 0.12345678912345678;
strcpy(s, "Hello,World");
c = '\x41';
printf("a=%d\n", a);//按照⼗进制整数格式输出,显⽰ a=1234
printf("a=%d%%\n", a);//输出%号结果 a=1234%
printf("a=%6d\n", a);//输出6位⼗进制整数左边补空格,显⽰ a= 1234
printf("a=%06d\n", a);//输出6位⼗进制整数左边补0,显⽰ a=001234
printf("a=%2d\n", a);//a超过2位,按实际输出 a=1234
printf("a=%-6d\n", a);///输出6位⼗进制整数右边补空格,显⽰ a=1234
printf("f=%f\n", f);//浮点数有效数字是7位,结果 f=3.141593
printf("f=%6.4f\n", f);//输出6列,⼩数点后4位,结果 f=3.1416
printf("x=%lf\n", x);//输出长浮点数 x=0.123457
printf("x=%18.16lf\n", x);//输出18列,⼩数点后16位,x=0.1234567891234567
printf("c=%c\n", c);    //输出字符 c=A
printf("c=%x\n", c);//以⼗六进制输出字符的ASCII码 c=41
printf("s[]=%s\n", s);//输出数组字符串s[]=Hello,World
printf("s[]=%6.9s\n", s);//输出最多9个字符的字符串 s[]=Hello,Wor
int i = 10;
int errcode = 10;
#if (defined(WIN32) || defined(_WIN32) || defined(__WIN32__) || defined(__NT__))
#define Log(_t,_f,...) printf("[%-s %4u %-s]%-5s: "##_f##"\n", __FILE__,__LINE__,__FUNCTION__,#_t,##__VA_ARGS__)
#elif defined(__linux__) || defined(__linux)
#define Log(_t,_f,...) printf("[%-s %4u %-s]%-5s: "_f"\n", __FILE__,__LINE__,__FUNCTION__,#_t,##__VA_ARGS__)
#endif
Log(Info, "---------%d-------------", i);
#define LOGI(message, ...) printf("\n(%04X)%s[%04d]%16s: " message, (unsigned int)1,__FILE__,__LINE__,__FUNCTION__ ,##__VA_ARGS__);fflush(stdout) #define LOGW(message, ...) printf("\n(%04X)%s[%04d]%-16s:: " message, (unsigned int)2,__FILE__,__LINE__,__FUNCTION__ ,##__VA_ARGS__);fflush(stdou #define LOGE(message, ...) printf("\n(%04X)%s[%04d]%-16s::: " message, (unsigned int)3,__FILE__,__LINE__,__FUNCTION__ ,##__VA_ARGS__);fflush(stdou #define LOGF(message, ...) printf("\n(%04X)%s[%04d]%-16s:::: " message, (unsigned int)4,__FILE__,__LINE__,__FUNCTION__ ,##__VA_ARGS__);fflush(stdou
LOGI("xxxxxxxxxxxxxxxxxxxxxxxxx");
LOGW("xxxxx    Err:%d  xxxxxxxx", errcode);
return 0;
}

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。