zoukankan      html  css  js  c++  java
  • C语言中输入输出重定向,freopen的用法和实例

    使用的理由(范围):如果输入数据很庞大,需要一次又一次的重新输入和调试时可采用本函数。

    freopen ()函数:

    1.格式

    FILE * freopen ( const char * filename, const char * mode, FILE * stream );

    2.参数说明

    filename: 要打开的文件名

    mode: 文件打开的模式,和fopen中的模式(r/w)相同

    stream: 文件指针,通常使用标准流文件(stdin/stdout/stderr)

    返回值:成功,则返回一个path所指定文件的指针;失败,返回NULL。(一般可以不使用它的返回值) 
    功能:实现重定向,把预定义的标准流文件定向到由path指定的文件中。标准流文件具体是指stdinstdoutstderr。其中stdin是标准输入流,默认为键盘;stdout是标准输出流,默认为屏幕;stderr是标准错误流,一般把屏幕设为默认。通过调用freopen,就可以修改标准流文件的默认值,实现重定向。

    3.使用方法

    因为文件指针使用的是标准流文件,因此我们可以不定义文件指针。

    接下来我们使用freopen()函数以只读方式r(read)打开输入文件slyar.in

    freopen("slyar.in", "r", stdin);

    然后使用freopen()函数以写入方式w(write)打开输出文件slyar.out

    freopen("slyar.out", "w", stdout);

    接下来的事情就是使用freopen()函数的优点了,我们不再需要修改scanfprintf,而是维持代码的原样就可以了。因为freopen()函数重定向了标准流,使其指向前面指定的文件

    最后只要使用fclose关闭输入文件和输出文件即可。

    fclose(stdin);

    fclose(stdout);

    若要恢复句柄,可以重新打开标准控制台设备文件,只是这个设备文件的名字是与操作系统相关的。

    DOS/Windows:

    freopen("CON", "r", stdin);

    Linux:

    freopen("/dev/console", "r", stdin);

    4.算法实例

    输入一些整数,求出它们的最小值、最大值和平均值(保留3位小数)。输入保证这些数都是不超过1000的整数。

    样例输入:2 8 3 5 1 7 3 6

    样例输出:1 8 4.375

    参考程序1

    #define TEST

    #include<stdio.h>

    #define MM 1000

    main()

    {

    #ifdef TEST

    freopen("d:\c2_4_in.txt","r",stdin);

    freopen("d:\c2_4_out.txt","w",stdout);

    #endif

    int i=0,sum=0,n,max=-MM,min=MM;

    while(scanf("%d",&n)==1)

    {

    sum=sum+n;

    if(max<n)

    max=n;

    if(min>n)

    min=n;

    i++;

    }

    printf("%d %d %.3lf ",min,max,(double)sum/i);

    }

    说明:(1)对于本题来说,我们使用了重定向简单地说,就是程序中用标准输入scanf()函数输入的数据从d:c2_4_in.txt中读取,printf()函数输出的数据直接写入d:c2_4_out.txt中去,屏幕上不在等待输入数据和不再显示输出结果。

    2)如果把第一句去掉(#define TEST),

    #ifdef TEST

    freopen("d:\c2_4_in.txt","r",stdin);

    freopen("d:\c2_4_out.txt","w",stdout);

    #endif

    就不起任何作用,这时还必须用标准输入输出。

     

    参考程序2:

    #include<stdio.h>
    #define MM 1000
    main()
    {
     FILE *fin,*fout;
     fin=fopen("d:\c2_4_in.txt","rb");
     fout=fopen("d:\c2_4_out.txt","wb");
     int i=0,n,sum=0,max=-MM,min=MM;
     while(fscanf(fin,"%d",&n)==1)
     {
      sum+=n;
      if(max<n)
       max=n;
      if(min>n)
       min=n;
      i++;
     }
     fprintf(fout,"%d %d %.3lf",min,max,(double)sum/i);
     fclose(fin);
     fclose(fout);
    }

  • 相关阅读:
    poj- 2528 Mayor's posters
    POJ 2631 Roads in the North (树的直径裸题)
    Quoit Design (白话--分治--平面点对问题)
    洛古 P1020 导弹拦截 (贪心+二分)
    D
    代理模式---动态代理之Cglib
    代理模式---动态代理之JDK
    开闭原则
    迪米特法则
    接口隔离原则
  • 原文地址:https://www.cnblogs.com/luckyraye/p/7704287.html
Copyright © 2011-2022 走看看