• scanf、printf、gets、puts的应用及区别


    1、scanf()函数

    函数scanf()按指定的格式从键盘读取数据,并将其赋给一个或多个变量。例如: scanf(“%d %f”, &x,&rate);  输入多个变量时,scanf()使用空白将输入隔开。空白可以是空格、制表符或者换行符。格式化字符串中的每一个转换说明符对应一个输入字段,并且空白标识每个字段的结束。使用scanf()函数必须包含头文件stdio.h

    char a[10];
    scanf("%s", a);

    scanf函数会从a的首地址开始存放用户输入的字符,存放完毕后,系统会自动在尾部加上一个结束标记

    注意,不要写成scanf("%s", &a),因为a已经代表了数组的地址,没必要再加上&这个地址运算符。

    2、gets()函数

    函数gets()从键盘读取一个字符串。当gets()函数被调用时,它不断从键盘读取字符,直到遇到换行符(通过按enter键生成)为止。该函数丢弃换行符,添加一个空字符,然后将字符串返回给调用程序。字符串被存储到传递给gets()的char指针指向的位置。

    gets()函数的语法如下:

    #include <stdio.h>
    char *gets(char *str);

     

    char [6];
    gets a;

    gets跟scanf一样,会从a的首地址开始存放用户输入的字符,存放完毕后,系统会自动在尾部加上一个结束标记。

    * gets一次只能读取一个字符串,scanf则可以同时读取多个字符串

    * gets可以读入包含空格、tab的字符串,直到遇到回车为止;scanf不能用来读取空格、tab

    3、printf()函数

    (1)调用格式为  printf("<格式化字符串>", <参量表>);   其中格式化字符串包括两部分内容: 一部分是正常字符, 这些字符将按原样输出; 另一部分是格式化规定字符, 以"%"开始, 后跟一个或几个规定字符, 用来确定输出内容格式。参量表是需要输出的一系列参数, 其个数必须与格式化字符串所说明的输出参数个数一样多, 各参数之间用","分开, 且顺序一一对应, 否则将会出现意想不到的错误。

    (2)格式化字符

    %d 十进制有符号整数

    %u 十进制无符号整数

    %f 浮点数

    %s 字符串

    %c 单个字符

    %p 指针的值

    %e 指数形式的浮点数

    %x, %X 无符号以十六进制表示的整数

    %0 无符号以八进制表示的整数

    %g 自动选择合适的表示法

    说明:

    (1). 可以在"%"和字母之间插进数字表示最大场宽。 例如: %3d 表示输出3位整型数, 不够3位右对齐。 %9.2f 表示输出场宽为9的浮点数, 其中小数位为2, 整数位为6, 小数点占一位, 不够9位右对齐。%8s 表示输出8个字符的字符串, 不够8个字符右对齐。 如果字符串的长度、或整型数位数超过说明的场宽, 将按其实际长度输出。 但对浮点数, 若整数部分位数超过了说明的整数位宽度, 将按实际整数位输出; 若小数部分位数超过了说明的小数位宽度, 则按说明的宽度以四舍五入输出。另外, 若想在输出值前加一些0, 就应在场宽项前加个0。 例如: %04d 表示在输出一个小于4位的数值时, 将在前面补0使其总宽度为4位。如果用浮点数表示字符或整型量的输出格式, 小数点后的数字代表最大宽度, 小数点前的数字代表最小宽度。 例如: %6.9s 表示显示一个长度不小于6且不大于9的字符串。若大于9, 则第9个字符以后的内容将被删除。

    (2). 可以在"%"和字母之间加小写字母l, 表示输出的是长型数。例如: %ld 表示输出long整数, %lf 表示输出double浮点数。

    (3). 可以控制输出左对齐或右对齐, 即在"%"和字母之间加入一个"-" 号可说明输出为左对齐, 否则为右对齐。例如: %-7d 表示输出7位整数左对齐,%-10s 表示输出10个字符左对齐。

    (3)一些特殊规定字符

    换行

    f清屏并换页

    回车

    Tab符

    xhh表示一个ASCII码用16进表示, 其中hh是1到2个16进制数

     1     int a=1234;
     2     printf("a=%d
    ",a);    //a=1234
     3     printf("a=%2d
    ",a);   //a=1234    超过2位,按实际输出
     4     printf("a=%6d
    ",a);   //a=  1234  不足6位,右对齐
     5     printf("a=%06d
    ",a);  //a=001234  不足6位,前面补0
     6     printf("a=%-6d
    ",a);  //a=1234    '-'左对齐
     7     
     8 
     9     int* i=&a;
    10     printf("i=%p
    ",i);    //i=0012FF44  输出指针的值,即地址
    11 
    12     float m=8888.8888;     //float 单精度型浮点数 有效位数是6位或7位,根据不同的浮点数会有不同
    13     float m1=8888.8888f;    //在后面加上f或F,编译警告:truncation from'const double'to 'float'
    14                             //编译器默认浮点数为double
    15     float m2=8888.888f;  
    16     double n=8888.8888;
    17     double n1=8888888888.88888888;  //double 双精度型浮点数 有效位数是15位
    18     printf("m=%f
     m1=%f
     m2=%f
     n=%lf
     n1=%f
    ",m,m1,m2,n,n1); // m=8888.888672
    19                                                                 //  m1=8888.888672     
    20                                                                 //  m2=8888.887695
    21                                                                // n=8888.888800
    22                                                                // n1=8888888888.888889
    23                                                                //%f的默认输出小数位数就是6位不管有没有l
    24     /*printf的%f说明符的确既可以输出float型又可以输出 double型。 根据"默认参数提升"规则(在printf这样的函数的
    25     可变参数列表中 ,不论作用域内有没有原型,都适用这一规则)float型会被提升为double型。因此printf()只会看到
    26     双精度数。严格地讲,%lf在printf下是未定义的,但是很多系统可能会接受它。要确保可移植性,就要坚持使用%f。*/
    27 
    28     printf("m4=%4.2f
    ",m);   //宽度总共4位,小数两位,小数点一位,整数一位,这里整数超过宽度规定,按实际整数位输出
    29     printf("m5=%9.6f
    ",m);   //浮点数小数部分不足6位,右对齐
    30     printf("m6=%9.2f
    ",m);   //整数部分不足6位,右对齐;小数部分超过2位,四舍五入
    31 
    32     char c[20]="Hello,world!";
    33     printf("c=%s
    ",c);    
    34     printf("c=%6.9s
    ",c);  //c=Hello,wor  6.9s表示输出一个长度长度不小于6且不大于9的字符串。若大于9, 则第9个字符以后的内容将被删除。

    * 我们再来看一个例子

    1 char a[3] = {'m', 'j', ''}; // 添加了结束符
    2 char b[] = {'i', 's'}; // 假设忘记添加结束符
    3 printf("字符串a:%s", a); // 输出字符串a
    4 printf("
    "); // 换行
    5 printf("字符串b:%s", b); // 输出字符串b

    程序输出的结果:字符串a:mj
                           字符串b:ismj

    当我们尝试输出b的时候,把a也输出了。

    要搞清楚为什么,首先要看看a和b的内存地址:

    1 printf("a的地址:%x", a);
    2 printf("
    ");
    3 printf("b的地址:%x", b);

    输出结果:a的地址:5fbff809
                  b的地址:5fbff807

    所以a、b的内存空间分布情况如下:

    可以看出来,数组b和a的内存地址是连续的。我们再回到输出b的代码:

    printf("字符串b:%s", b); // 输出字符串b
    

    %s表示期望输出一个字符串,因此printf函数会从b的首地址开始按顺序输出字符,一直到字符为止,因为是字符串的结束标记。

    所以,如果想要创建一个字符串,记得加上结束符,不然后果很严重,会访问到一些垃圾数据。

    4、使用puts()显示消息

    puts()d 语法如下:

    #include<stdio.h>

    puts(string);  (和printf()一样,使用puts()的程序也必须包含头文件stdio.h)

    函数puts()也可用来在屏幕上显示文本消息,但它不能显示数值变量。puts函数接受一个字符串参数,显示该参数并自动换行。

    例如: puts(“Hello world.”);   ==  printf(“Hello world. ”);

  • 相关阅读:
    nginx重启命令
    Java中Vector笔记
    JAVA中字符串比较equals()和equalsIgnoreCase()的区别
    HashMap和TreeMap的常用排序方法
    Logger用法
    HashMap和Hashtable的区别
    class.getDeclaredFields()与class.getFields()
    java中 文件压缩处理
    Java远程执行Shell命令
    python 学习笔记 redis操作
  • 原文地址:https://www.cnblogs.com/chensup/p/5798112.html
Copyright © 2020-2023  润新知