• 【字符串】fputs函数详解


    fputs() 函数也是用来显示字符串的,它的原型是:

    1 #include <stdio.h>
    2 int fputs(const char*s,FILE *stream);

    s代表要输出的字符串的首地址,可以是字符数组名或字符指针变量名。

    stream 表示向何种流中输出,可以是标准输出流 stdout,也可以是文件流。标准输出流即屏幕输出,printf 其实也是向标准输出流中输出的。

    fputs() 和 puts() 有两个小区别:

    1. puts() 只能向标准输出流输出,而 fputs() 可以向任何流输出。
    2. 使用 puts() 时,系统会在自动在其后添加换行符;而使用 fputs() 时,系统不会自动添加换行符。

    那么这是不是意味着使用 fputs() 时就要在后面添加一句“printf(" ");”换行呢?看情况!如果输入时使用的是 gets(),那么就要添加 printf 换行;但如果输入时用的是 fgets(),则不需要。

    因为使用 gets() 时,gets() 会将回车读取出来并丢弃,所以换行符不会像 scanf 那样被保留在缓冲区,也不会被 gets() 存储;而使用 fgets() 时,换行符会被 fgets() 读出来并存储在字符数组的最后,这样当这个字符数组被输出时换行符就会被输出并自动换行。

    但是也有例外,比如使用fgets()时指定了读取的长度,如只读取 5 个字符,事实上它只能存储 4 个字符,因为最后还要留一个空间给 '',而你却从键盘输入了多于 4 个字符,那么此时“敲”回车后换行符就不会被 fgets() 存储。数据都没有地方存放,哪有地方存放换行符呢!此时因为 fgets() 没有存储换行符,所以就不会换行了。

    下面写一个程序验证一下:

    1 #include <stdio.h>
    2 int main(void)
    3 {
    4     char str[20];//定义一个最大长度为19,末尾是''的字符数组来存储字符串
    5     printf("请输入一个字符串:");
    6     fgets(str,19,stdin);//从输入流stdin中读取18个字符到字符数组str中
    7     fputs(str,stdout);//将字符数组的内容输出到输出流stdout中
    8     return 0;
    9 }

    我们看到读取 18个字符足够存储“我很想你 你在哪里”,上述共8*2+1=17个字符,所以 fgets() 最后会存储换行符。这样 fputs() 输出时这个换行符就能换行了。一个汉字两个字符。

    下面再将读取的字符改小一点看看:

    1 #include <stdio.h>
    2 int main(void)
    3 {
    4     char str[20];//定义一个最大长度为19,末尾是''的字符数组来存储字符串
    5     printf("请输入一个字符串:");
    6     fgets(str,5,stdin);//从输入流stdin中读取4个字符到字符数组str中
    7     fputs(str,stdout);//将字符数组的内容输出到输出流stdout中
    8     return 0;
    9 }

    我们看到并没有换行。

    值得说明的是,虽然 gets()、fgets()、puts()、fputs() 都是字符串处理函数,但它们都包含在 stdio.h 头文件中,并不是包含在 string.h 头文件中。

     
  • 相关阅读:
    Don't set high speed for the 'DoubleClick'
    How to set UITextField to ReadOnly
    Parallel World 1 并行世界的两个基本问题
    Parallel World 3 – Parallel Loop (2)
    hdu 2680 Choose the best route Dijkstra 虚拟点
    hdu 2255 KM算法
    最小生成树 kruskal 和 pime 模版
    hdu 1863 畅通工程 最小生成树+并查集
    hdu 2603 过山车 最大匹配,匈牙利算法模板(易理解)
    KM 最优匹配 讲解
  • 原文地址:https://www.cnblogs.com/Luthais/p/10218375.html
Copyright © 2020-2023  润新知