printf 订阅
printf 是指格式化输出函数,主要功能是向标准输出设备按规定格式输出信息。printf 是C语言标准库函数,定义于头文件 。printf 函数的一般调用格式为:printf("<格式化字符串>", <参量表>) [1]  。输出的字符串除了可以是字母、数字、空格和一些数字符号以外,还可以使用一些转义字符表示特殊的含义 [2]  。 展开全文
printf 是指格式化输出函数,主要功能是向标准输出设备按规定格式输出信息。printf 是C语言标准库函数,定义于头文件 。printf 函数的一般调用格式为:printf("<格式化字符串>", <参量表>) [1]  。输出的字符串除了可以是字母、数字、空格和一些数字符号以外,还可以使用一些转义字符表示特殊的含义 [2]  。
信息
外文名
printf [1]
头文件
stdio.h [1]
特    点
变参函数 [1]
中文名
格式化输出函数 [1]
功    能
向标准输出设备按规定格式输出信息 [1]
返回值
打印字符串的长度 [3]
printf函数语法
printf 函数的声明如下: [4]  printf 的格式控制字符串 format 中的转换说明组成如下,其中 [] 中的部分是可选的: [5]  %[flags][width][.precision][length]specifier,即:%[标志][最小宽度][.精度][类型长度]说明符 [5]  。转换说明详解见下文。 printf 函数在输出格式 format 的控制下,将其参数进行格式化,并在标准输出设备(显示器、控制台等)上打印出来。 [1]  如果函数执行成功,则返回所打印的字符总数,如果函数执行失败,则返回一个负数。 [3] 
收起全文
精华内容
参与话题
问答
  • printf

    千次阅读 2017-08-22 23:53:38
    IAR printf举例: http://www.openedv.com/thread-24176-1-1.html /** *Printf打印函数 * @param format Printf格式 */ void Debug_Printf(const char *format, …) { uint32_t length; va_list args; ...

    IAR printf举例:
    http://www.openedv.com/thread-24176-1-1.html
    /**
    *Printf打印函数
    * @param format Printf格式
    */
    void Debug_Printf(const char *format, …)
    {
    uint32_t length;
    va_list args;
    va_start(args, format);
    length = vsnprintf((char*)print_buffer, sizeof(print_buffer), (char*)format, args);//格式化内容
    va_end(args);
    USART1_SendBuffer(print_buffer,length);//发送
    while(!sendDoneFlag);//等待发送完成
    }

    https://www.amobbs.com/thread-3215678-2-1.html

    用vsprintf吧。

    char printbuffer[256];

    int my_printf(const char *format,…)
    {
    int chars;
    va_list ap;

    va_start(ap, format);
    chars = vsprintf(printbuffer, format, ap);
    va_end(ap);
    
    putstring(printbuffer,chars);
    
    return chars ;
    

    }
    记得带上头文件 stdarg.h

    void USART2PC_printf(char *fmt, …)
    {
    char buffer[CMD_BUFFER_LEN+1]; // length自己定义
    u8 i = 0;

        va_list arg_ptr;
        va_start(arg_ptr, fmt);  
        vsnprintf(buffer, CMD_BUFFER_LEN+1, fmt, arg_ptr);
        while ((i < CMD_BUFFER_LEN) && buffer)
        {
                USART_SendData(USART2, (u8) buffer[i++]);
                while (USART_GetFlagStatus(USART2, USART_FLAG_TC) == RESET);  
        }
        va_end(arg_ptr);
    

    }

    VA_ARGS的用法:
    http://velep.com/archives/581.html
    http://www.cnblogs.com/alexshi/archive/2012/03/09/2388453.html

    http://www.360doc.com/content/17/0503/10/33093582_650549328.shtml

    展开全文
  • C printf() 详解之终极无惑

    万次阅读 多人点赞 2016-08-24 20:01:53
    1.printf()简介 printf()是C语言标准库函数,用于将格式化后的字符串输出到标准输出。标准输出,即标准输出文件,对应终端的屏幕。printf()申明于头文件stdio.h。 函数原型: int printf ( const char ...

    编译环境:Linux 环境以 g++ 4.4.6 编译成 64 位程序


    1.printf() 简介

    printf() 是 C 语言标准库函数,用于将格式化后的字符串输出到标准输出。标准输出,即标准输出文件,对应终端的屏幕。printf() 申明于头文件 stdio.h。

    函数原型:

    int printf ( const char * format, ... );
    

    返回值:
    正确返回输出的字符总数,错误返回负值。与此同时,输入输出流错误标志将被置值,可由指示器函数 ferror(FILE *stream) 来检查输入输出流的错误标志,如果 ferror() 返回一个非零值,表示出错。

    调用格式:

    printf("格式化字符串", 输出表列)
    

    格式化字符串包含三种对象,分别为:
    (1)字符串常量;
    (2)格式控制字符串;
    (3)转义字符。

    字符串常量原样输出,在显示中起提示作用。输出表列中给出了各个输出项,要求格式控制字符串和各输出项在数量和类型上应该一一对应。其中格式控制字符串是以 % 开头的字符串,在 % 后面跟有各种格式控制符,以说明输出数据的类型、宽度、精度等。

    2.格式控制字符串详解

    printf() 的格式控制字符串组成如下:

    %[flags][width][.prec][length]type
    

    分别为:

    %[标志][最小宽度][.精度][类型长度]类型。
    

    2.1 类型(type)

    首先说明类型,因为类型是格式控制字符串的重中之重,是必不可少的组成部分,其它的选项都是可选的。type 用于规定输出数据的类型,含义如下:

    字符 对应数据类型 含义 示例
    d/i int 输出十进制有符号 32bits 整数,i 是老式写法 printf("%i",123);输出123
    o unsigned int 无符号8进制(octal)整数(不输出前缀0) printf("0%o",123);输出0173
    u unsigned int 无符号10进制整数 printf("%u",123);输出123
    x/X unsigned int 无符号16进制整数,x对应的是abcdef,X对应的是ABCDEF(不输出前缀0x) printf("0x%x 0x%X",123,123);输出0x7b 0x7B
    f/lf float(double) 单精度浮点数用f,双精度浮点数用lf(printf可混用,但scanf不能混用) printf("%.9f %.9lf",0.000000123,0.000000123);输出0.000000123 0.000000123。注意指定精度,否则printf默认精确到小数点后六位
    F float(double) 与f格式相同,只不过 infinity 和 nan 输出为大写形式。 例如printf("%f %F %f %F\n",INFINITY,INFINITY,NAN,NAN);输出结果为inf INF nan NAN
    e/E float(double) 科学计数法,使用指数(Exponent)表示浮点数,此处"e"的大小写代表在输出时“e”的大小写 printf("%e %E",0.000000123,0.000000123);输出1.230000e-07 1.230000E-07
    g float(double) 根据数值的长度,选择以最短的方式输出,%f或%e printf("%g %g",0.000000123,0.123);输出1.23e-07 0.123
    G float(double) 根据数值的长度,选择以最短的方式输出,%f或%E printf("%G %G",0.000000123,0.123);输出1.23E-07 0.123
    c char 字符型。可以把输入的数字按照ASCII码相应转换为对应的字符 printf("%c\n",64)输出A
    s char* 字符串。输出字符串中的字符直至字符串中的空字符(字符串以空字符’\0‘结尾) printf("%s","测试test");输出:测试test
    S wchar_t* 宽字符串。输出字符串中的字符直至字符串中的空字符(宽字符串以两个空字符’\0‘结尾) setlocale(LC_ALL,"zh_CN.UTF-8");
    wchar_t wtest[]=L"测试Test";
    printf("%S\n",wtest);
    输出:测试test
    p void* 以16进制形式输出指针 printf("0x%p","lvlv");输出:0x000000013FF73350
    n int* 什么也不输出。%n对应的参数是一个指向signed int的指针,在此之前输出的字符数将存储到指针所指的位置 int num=0;
    printf("lvlv%n",&num);
    printf("num:%d",num);
    输出:lvlvnum:4
    % 字符% 输出字符‘%’(百分号)本身 printf("%%");输出:%
    m 打印errno值对应的出错内容 printf("%m\n");
    a/A float(double) 十六进制p计数法输出浮点数,a为小写,A为大写 printf("%a %A",15.15,15.15);输出:0x1.e4ccccccccccdp+3 0X1.E4CCCCCCCCCCDP+3

    注意:
    (1)使用 printf() 输出宽字符时,需要使用 setlocale 指定本地化信息并同时指明当前代码的编码方式。除了使用 %S,还可以使用 %ls。

    (2)printf() 输出 bool 类型无专用类型标识符,实际输出时按照整型 0 或 1 输出布尔值。

    (3)%a 和 %A 是 C99 引入的格式化类型,采用十六进制 p 计数法输出浮点数。p 计数法类似 E 科学计数法,但有所不同。数以 0x 开头,然后是 16 进制浮点数部分,接着是 p 后面是以 2 为底的阶码。以上面输出的 15.15 为例,推算输出结果。15.15 转换成二进制为1111.00 1001 1001 1001 1001 ...,因为二进制表示数值的离散特点,计算机对于小数有时是不能精确表示的,比如 0.5 可以精确表示为0.120.1_20.12,而 0.15 却不能精确表示。将15.15 对应的二进制右移三位,为1.1110 0100 1100 1100 1100 ...转换对应的十六进制就是0x1.e4ccccccccccd,注意舍入时向高位进了1位。由于右移三位,所以二进制阶码是 3。最后的结果就是 0x1.e4ccccccccccdp+3。

    (4)格式控制字符串除了指明输出的数据类型,还可以包含一些其它的可选的格式说明,依序有 flags, width, .precision and length。下面一一讲解。

    2.2 标志(flags)

    flags 规定输出样式,取值和含义如下:

    字符 名称 说明
    - 减号 结果左对齐,右边填空格。默认是右对齐,左边填空格。
    + 加号 输出符号(正号或负号)
    space 空格 输出值为正时加上空格,为负时加上负号
    # 井号 type是o、x、X时,增加前缀0、0x、0X。
    type是a、A、e、E、f、g、G时,一定使用小数点。默认的,如果使用.0控制不输出小数部分,则不输出小数点。
    type是g、G时,尾部的0保留。
    0 数字零 将输出的前面补上0,直到占满指定列宽为止(不可以搭配使用“-”)

    示例:

    printf("%5d\n",1000); 				//默认右对齐,左边补空格
    printf("%-5d\n",1000); 				//左对齐,右边补空格
    
    printf("%+d %+d\n",1000,-1000);		//输出正负号
    
    printf("% d % d\n",1000,-1000);		//正号用空格替代,负号输出
    
    printf("%x %#x\n",1000,1000);		//输出0x
    
    printf("%.0f %#.0f\n",1000.0,1000.0)//当小数点后不输出值时依然输出小数点
    
    printf("%g %#g\n",1000.0,1000.0);	//保留小数点后后的0
    
    printf("%05d\n",1000);				//前面补0
    

    输出结果为:
    这里写图片描述

    2.3 输出最小宽度(width)

    用十进制整数来表示输出的最少位数。若实际位数多于指定的宽度,则按实际位数输出,若实际位数少于定义的宽度则补以空格或0。width的可能取值如下:

    width 描述 示例
    数值 十进制整数 printf("%06d",1000);输出:001000
    * 星号。不显示指明输出最小宽度,而是以星号代替,在printf的输出参数列表中给出 printf("%0*d",6,1000);输出:001000

    2.4 精度(.precision)

    精度格式符以“.”开头,后跟十进制整数。可取值如下:

    .precision描述
    .数值 十进制整数。
    (1)对于整型(d,i,o,u,x,X),precision表示输出的最小的数字个数,不足补前导零,超过不截断。
    (2)对于浮点型(a, A, e, E, f ),precision表示小数点后数值位数,默认为六位,不足补后置0,超过则截断。
    (3)对于类型说明符g或G,表示可输出的最大有效数字。
    (4)对于字符串(s),precision表示最大可输出字符数,不足正常输出,超过则截断。
    precision不显示指定,则默认为0
    .* 以星号代替数值,类似于width中的*,在输出参数列表中指定精度。

    示例:

    printf("%.8d\n",1000);			//不足指定宽度补前导0,效果等同于%08d
    printf("%.8f\n",1000.123456789);//超过精度,截断
    printf("%.8f\n",1000.123456);	//不足精度,补后置0
    printf("%.8g\n",1000.123456);	//最大有效数字为8位
    printf("%.8s\n",“abcdefghij”);	//超过指定长度截断
    

    输出结果:

    00001000
    1000.12345679
    1000.12345600
    1000.1235
    abcdefgh
    

    注意: 在对浮点数和整数截断时,存在四舍五入。

    2.5 类型长度(length)

    类型长度指明待输出数据的长度。因为相同类型可以有不同的长度,比如整型有 char(8bits)、short int(16bits),int(32bits)和 long int(64bits),浮点型有 32bits 的单精度 float 和 64bits 的双精度 double。为了指明同一类型的不同长度,于是乎,类型长度(length)应运而生,成为格式控制字符串的一部分。

    因为 Markdown 表格不支持单元格合并,背景颜色等样式,所以直接引用C++ reference.printf的表格。
    这里写图片描述

    注意: 黄色背景行标识的类型长度说明符和相应的数据类型是C99引入的。

    示例代码:

    printf("%hhd\n",'A');				//输出有符号char
    printf("%hhu\n",'A'+128);			//输出无符号char
    printf("%hd\n",32767);				//输出有符号短整型short int
    printf("%hu\n",65535);				//输出无符号短整型unsigned short int
    printf("%ld\n",0x7fffffffffffffff);	//输出有符号长整型long int
    printf("%lu\n",0xffffffffffffffff);	//输出有符号长整型unsigned long int
    

    输出结果:

    65
    193
    32767
    65535
    9223372036854775807
    18446744073709551615
    

    注意:
    long int 到底是 32bits 还是 64bits 跟生成的程序是 32bits 还是 64bits 一一对应,如果使用 g++ 编译程序的话,可通过-m32-m64选项分别生成 32bits 和 64bits 的程序。因本人测试代码编译生成的是 64bits 的程序,所以 long int 也就是 64btis。

    3.转义字符

    转义字符在字符串中会被自动转换为相应操作命令。printf() 使用的常见转义字符如下:

    转义字符 意义
    \a 警报(响铃)符
    \b 回退符
    \f 换页符
    \n 换行符
    \r 回车符
    \t 横向制表符
    \v 纵向制表符
    \\ 反斜杠
    \" 双引号

    4.关于 printf 缓冲

    在 printf 的实现中,在调用 write 之前先写入 IO 缓冲区,这是一个用户空间的缓冲。系统调用是软中断,频繁调用,需要频繁陷入内核态,这样的效率不是很高,而 printf 实际是向用户空间的 IO 缓冲写,在满足条件的情况下才会调用 write 系统调用,减少 IO 次数,提高效率。

    printf(…) 在 glibc 中默认为行缓冲,遇到以下几种情况会刷新缓冲区,输出内容:
    (1)缓冲区填满;
    (2)写入的字符中有换行符\n或回车符\r
    (3)调用 fflush(…) 手动刷新缓冲区;
    (4)调用 scanf(…) 从输入缓冲区中读取数据时,也会将输出缓冲区内的数据刷新。

    可使用setbuf(stdout,NULL)关闭行缓冲,或者setbuf(stdout,uBuff)设置新的缓冲区,uBuff 为自己指定的缓冲区。也可以使用setvbuf(stdout,NULL,_IOFBF,0);来改变标准输出为全缓冲。全缓冲与行缓冲的区别在于遇到换行符不刷新缓冲区。

    printf(…) 在 VC++ 中默认关闭缓冲区,输出时会及时输到屏幕[3]^{[3]}[3]。如果显示开启缓冲区,只能设置全缓冲。因为微软闭源,所以无法研究 printf(…) 的实现源码。

    Linux 和 Windows 下的缓冲区管理可见:C的全缓冲、行缓冲和无缓冲

    5.printf 与 wprintf 不能同时使用

    该小结写在 2018 年 1 月15 日。两年后的今日,在网上苦苦搜索寻求答案,终于解决了之前的疑惑。

    在输出宽字符串时,发现将 printf 和 wprintf 同时使用时,则后使用的函数没有输出。这里建议不要同时使用 printf 和 wprintf,以免发生错误。

    printf 和 wprintf 不能同时输出宽字符串的示例代码如下:

    #include <stdio.h>
    #include <wchar.h>
    #include <locale.h>
    
    int main(int argc,char* argv[])
    {
    	char test[]="测试Test";
    	setlocale(LC_ALL,"zh_CN.UTF-8");
        wchar_t wtest[]=L"0m~K0m~UTest";
    	printf("printf:%S\n",wtest);     //语句1:可正常输出"测试Test"
        wprintf(L"wprintf:%S\n",wtest);  //语句2:无任何内容输出
    }
    

    上面的代码中语句 1 和语句 2 不能同时存在,否则只能正常输出第一个。也不知道在 Windows 平台是否也存在这种问题,有兴趣的读者可以尝试一下。关于原因,GNU 官方文档中有明确说明不能同时使用 printf 与 wprintf,参见The GNU C Library Section 12.6 Streams in Internationalized Applications,内容如下:

    It is important to never mix the use of wide and not wide operations on a stream. There are no diagnostics issued. The application behavior will simply be strange or the application will simply crash. 
    

    这里是因为输出流在被创建时,不存在流定向,一旦使用了 printf(多字节字符串) 或 wprintf(宽字符串)后,就被设置为对应的流定向,且无法更改。可以使用如下函数获取当前输出流的流定向。

    //
    //@param: stream:文件流;mode:取值可以 >0、=0 或 <0
    //@ret: <0:流已被设置为多字节流定向;=0:流尚未被设置;>0:流已被设置为宽字符流定向
    //
    int fwide (FILE* stream, int mode);
    
    //获取当前标准输出流定向
    int ret=fwide(stdout,0);
    

    通过 fwide 可以设置当前流定向,前提是未有任何的 I/O 操作,也就是当前流尚未被设置任何流定向。顺带吐槽一下,不知为何标准库函数 fwide 实现的如此受限。具体操作如下:

    //设置标准输出流定向为多字节流定向
    fwide(stdout, -1);
    
    //设置标准输出流定向为宽字符流定向
    fwide(stdout, 1);
    

    既然 GNU C 存在这个问题,那该如何解决呢?这里有两种办法:
    (1)统一使用一种函数。
    例如:

    wprintf(L"%s","a\n");
    wprintf(L"b\n");
    
    //或
    printf("a\n");
    printf("%ls\n", L"b");
    

    (2)使用 C 标准库函数 freopen(…) 清空流定向。

    //重新打开标准输出流,清空流定向
    FILE* pFile=freopen("/dev/tty", "w", stdout);
    wprintf(L"wide freopen succeeded\n");
    
    //重新打开标准输出流,清空流定向
    pFile=freopen("/dev/tty", "w", stdout);
    printf("narrow freopen succeeded\n");
    

    上面可以让 printf(…) 与 wprintf(…) 同时使用。

    6.小结

    耗时将近两年,终于完成了此篇看似基础,但却纷繁复杂的 printf(…) 用法。由于时间和个人水平有限,文章不足之处在所难免,也请读者批评指正,不甚感激。


    参考文献

    [1] 浅谈C中的wprintf和宽字符显示
    [2] C++ reference.printf
    [3] Why does printf not flush after the call unless a newline is in the format string?
    [4] 格式规范语法:printf 和 wprintf 函数
    [5] The GNU C Library Section 12.6 Streams in Internationalized Applications
    [6] fwide.C++ reference

    展开全文
  • 1.printf("%3.0f",floatNum):不保留小数 说明:%3.0f表明待打印的浮点数(floatNum)至少占3个字符宽,且不带小数点和小数部分,整数部分至少占3个位宽; 注意:这里的3只代表整数部分至少占3位,舍弃小数点和...

    1.printf("%3.0f",floatNum):不保留小数

    说明:%3.0f表明待打印的浮点数(floatNum)至少占3个字符宽,且不带小数点和小数部分,整数部分至少占3个位宽;

    注意:这里的3只代表整数部分至少占3位,舍弃小数点和小数点后面的部分

    2.printf("%6.2f".floatNum):保留两位小数

    说明:%6.2f 表明待打印的数(floatNum)至少占6个字符宽度(包括两位小数和一个小数点),且小数点后面有2位小数,小数点占一位,所以整数部分至少占3位。

    注意:这里的6是待打印的数至少占据的字符宽度,包括两位小数(如果小数不够两位用0补位,例如100.1打印出来为100.10)和一个小数点,所以整数部分至少占3个字符宽度。

    3.单精度实数的有效位数一般为7位,输出6位小数,超出有效位数输出就是错误的。

    4.双精度数有效位数一般为16位,输出6位小数,超出有效位数可能截断或错误值。

    5.关于保留小数点后有效位数四舍五入原则

     

    #include<stdio.h>
    
    int main()
    {
    	
    	printf("%f\n", 100.00);
    	printf("%.0f\n", 100.00);
    	printf("\n");
    
    	printf("%f\n", 100.30);
    	printf("%.0f\n", 100.30);
    	printf("\n");
    
    	printf("%f\n", 100.50);
    	printf("%.0f\n", 100.50);
    	printf("\n");
    
    	printf("%f\n", 100.53);
    	printf("%.1f\n", 100.53);
    	printf("\n");
    
    	printf("%f\n", 100.55);
    	printf("%.1f\n", 100.55);
    	printf("\n");
    
    	printf("%f\n", 100.56);
    	printf("%.1f\n", 100.56);
    	printf("\n");
    
    	printf("%f\n", 100.563);
    	printf("%.2f\n", 100.563);
    	printf("\n");
    
    	printf("%f\n", 100.565);
    	printf("%.2f\n", 100.565);
    	printf("\n");
    
    	printf("%f\n", 100.566);
    	printf("%.2f\n", 100.566);
    	printf("\n");
    	return 0;
    }

    运行结果:

     

    注意:从图中可以看出,保留0位小数的时候,只要小数点后第一位>=5,就可以进位,但是保留1位或者2位等等,保留小数的后一位要>5才可以进位,否则就舍去。

    我是根据运行结果看到,有可以解释下的,请留言,谢谢!
     

    展开全文
  • printf_s与printf的异同

    千次阅读 2019-09-25 16:16:13
    The main difference between printf_s and printf is that printf_s checks the format string for valid formatting characters, whereas printf only checks if the format string is a null pointer....

    MSDN的解释为:

    The main difference between printf_s and printf is that printf_s checks the format string for valid formatting characters, whereas printf only checks if the format string is a null pointer.

    printf只是检查format字符串是否为空。如果为空,会触发assert(false)。
    而printf_s还会检查format字符串是否有效,即其中格式是否合法。如果不合法,也会触发assert(false)。

    如下代码:

    #include <cstdio>
    #include <string>
    
    int main()
    {
    	char* format = nullptr;
    	printf(format, "hello", 10);
    	return 0;
    } 
    

    运行结果:

    在这里插入图片描述
    执行如下代码:

    #include <cstdio>
    #include <string>
    
    int main()
    {
    	char* format = "%s %d %k";
    	printf_s(format, "hello", 10, 1);
    	return 0;
    } 
    

    format格式错误, 因为没有%k这个格式。
    在这里插入图片描述
    另外:
    在format字符串格式正确的情况下,
    如果参数个数大于需要的个数,多余的参数忽略不处理。
    如果是小于,没填参数的位置随机(或者为乱码)。

    如下示例:

    #include <cstdio>
    #include <string>
    
    int main()
    {
    	char* format1 = "%s %d\n";
    	printf(format1, "hello", 10, 1);
    	printf_s(format1, "hello", 10, 1);
    
    	char* format2 = "%s %d %d %d %s\n";
    	printf(format2, "hello", 10, 1);
    	printf_s(format2, "hello", 10, 1);
    
    	return 0;
    } 
    

    输出为:
    在这里插入图片描述

    展开全文
  • printf实现

    千次阅读 2019-03-06 08:33:02
    printf是c语言下非常常用的一个函数,几乎每个程序员在一开始第一个学的函数应该就是printf吧! 今天来实现一个printf函数,虽然printf是我们常用的函数,但实现起来其实还是蛮考基础的! 下面一步一步带大家实现...
  • cprintfprintf的区别

    千次阅读 2017-10-05 20:14:44
    cprintfprintf的区别如下: 1.cprintf函数用于向当前窗口输出数据,比如你用window函数定义一个窗口 window(20,10,60,20),那么当你调用cprintf函数时,cprintf的输出就是相对于20,10, 60,20这个窗口,当...
  • Java中printf

    万次阅读 2019-03-15 18:21:01
    Java中printf
  • printf重定向

    千次阅读 2019-08-06 16:21:00
    C语言中printf默认输出设备是显示器,当开发板没有时我们就用串口来打印数据 int fputc(int ch,FILE *p) { USART_SendData(USART1,ch); //如果用串口2打印,和换成USART2 while(USART_GetFlagStatus(USART1,USART...
  • 输入输出函数(printf 和 scanf)是C语言中非常重要的两个函数,也是学习C语言必学的两个函数。在C语言程序中,几乎没有一个程序不需要这两个函数,尤其是输出函数(printf),所以这两个函数必须要掌握。 如果在...
  • printf的用法

    千次阅读 多人点赞 2019-03-17 16:47:53
    因为每个程序都会用到 printf() 这个函数,可见他是C语言中最重要的一个函数,输出函数的功能是将程序运行的结果输出到屏幕上,而输入函数是指通过键盘给程序输入变量赋值。可以说输入输出函数是用户和计算机交互的...
  • c语言printf输出语句A printf() function is a standard library function, that is used to print the text and value on the standard output screen. Here, we will evaluate the expression – where a printf()...
  • Shell printf 命令

    千次阅读 2016-08-30 21:45:05
    上篇博文我们说了 Shell echo-使用echo实现更复杂的输出格式控制这篇博文我们来学习 Shell 的另一个输出命令 printf。语法printf 命令模仿 C 程序库(library)里的 printf() 程序。标准所定义,因此使用printf的...
  • cprintfprintf 的区别: printf()格式化输出;cprintf()格式化输出。 printf()不受文本颜色、光标的控制,cprintf()受到这些的控制。
  • printf()用法详解

    万次阅读 多人点赞 2018-05-07 20:04:40
    1.printf()简介printf()是C语言标准库函数,用于将格式化后的字符串输出到标准输出。标准输出,即标准输出文件,对应终端的屏幕。printf()申明于头文件stdio.h。函数原型:int printf ( const char * format, ... );...
  • c++里printfprintf_s有什么区别? 有时候会警告不安全
  • printf()函数详解

    万次阅读 多人点赞 2018-07-21 17:06:44
    1.printf()简介 printf()是C语言标准库函数,用于将格式化后的字符串输出到标准输出。标准输出,即标准输出文件,对应终端的屏幕。printf()申明于头文件stdio.h。 函数原型: int printf ( const char * format,...
  • 嵌入式重定向 printf

    千次阅读 2018-06-04 11:51:20
    学习stm32,打交道最多的莫过于串口通讯了,但是官方的串口发送库太恶心了,完全不好用甚是还念C语言的printf,想输出什么就有什么,现在,一步步来做个重定向,让你的stm32可以跟C语言一样能想看什么就看什么:首先...
  • printf( "%d", printf( "%d", printf( "%d", i ) ) ); return 0; }printf( "%d", printf( "%d", printf( "%d", i ) ) );1,从左向右执行,
  • printf 耗时

    千次阅读 2017-04-13 10:44:33
    经过大量次、差异化、区别运算,得出在inter-i3,ubuntu15.10下单行printf: 平均耗时约43微秒 重定向到文件后耗时减少了73%左右,所以主要耗时是在输出到屏幕上。
  • shell printf命令

    2018-06-21 10:15:29
    Shell printf 命令 上一章节我们学习了 Shell 的 echo 命令,本章节我们来学习 Shell 的另一个输出命令 printfprintf 命令模仿 C 程序库(library)里的 printf() 程序。 printf 由 POSIX 标准所定义,因此...
  • 自己实现printf函数

    千次阅读 2017-12-13 22:39:42
    在嵌入式开发中,常常会通过串口打印一些信息到PC终端,这就需要实现自己的printf函数。我们先通过man 3 printf来看一下printf函数的声明: int printf(const char *format, ...); format:固定参数 … :可变参数...
  • printf输出格式

    千次阅读 2019-08-29 09:45:55
    printf作为C语言中的一种可以自定义输出格式的,非常方便使用,下面是一些常见的printf输出格式: (1)%md %md可以使不足m位的int类型变量以m位进行右对齐输出,其中高位用空格补齐;如果变量本身超过m位,保持...
  • printf的返回值

    2018-09-27 14:48:48
    碰到一段有意思的代码: #include &lt;stdio.h&gt; int main() { int i=43; printf("...,printf("...,printf("...这段代码用了几个printf函数,...首先调用第一个printf输出43,然后第二个prin...
  • printf缓冲区刷新问题

    万次阅读 2020-02-03 22:33:20
    首先,printf缓冲区的问题,平时不大会发现,当时是在使用sleep函数时出现的。先来看一下问题。 #include <stdio.h> int main() { printf("hello\n"); sleep(1); //延迟1秒 printf("world\n"); return 0;...
  • shell printf命令使用

    千次阅读 2016-10-26 08:57:24
    Shell printf 命令 上一章节我们学习了 Shell 的 echo 命令,本章节我们来学习 Shell 的另一个输出命令 printfprintf 命令模仿 C 程序库(library)里的 printf() 程序。 标准所定义,因此使用printf的...
  • C语言 printf函数实现

    千次阅读 2017-02-21 22:51:31
    printf()是控制台程序中最常用的函数,作用是输入的字符、数字等信息拼成完整的句子并且输出到标准输出设备(显示器、控制台等)。 下面是printf()定义:int printf(const char *fmt, ...)printf()实现部分:int ...
  • printf 里面嵌套 printf 会是什么结果

    千次阅读 2015-03-20 15:59:08
    今天在知乎里看到这个话题。瞬间秒杀呀,还没有考虑过这个问题。 #include int main(int argc, char *argv[]) { ...printf("%d",a);...printf("%d",printf("%d",a));//1234566 printf("\n"); printf("%d",p
  • (4)printf输出printf (1)前置加加和后置加加的区别 首先我们先来了解一下前置加加和后置加加的区别。 前置加加在编译器里的操作 //++a int a = 0; a = a + 1; return a; 前置加加是先加一,后赋值,返回的...

空空如也

1 2 3 4 5 ... 20
收藏数 171,005
精华内容 68,402
关键字:

printf