C语言中的setlinebuf()、utmpname()、rewind函数使用

C语言setlinebuf()函数:设置文件流为线性缓冲区
头文件:

#include <stdio.h>

定义函数:

void setlinebuf(FILE * stream);

函数说明:setlinebuf()用来设置文件流以换行为依据的无缓冲IO. 相当于调用:setvbuf(stream, (char*)NULL, _IOLBF, 0);请参考setvbuf().

C语言utmpname()函数:设置文件路径
头文件:

#include <utmp.h>

定义函数:

void utmpname(const char * file);

函数说明:utmpname()用来设置utmp 文件的路径, 以提供utmp 相关函数的存取路径. 如果没有使用utmpname()则默认utmp 文件路径为/var/run/utmp。

C语言rewind()函数:将文件指针重新指向文件开头
头文件:

 #include <stdio.h>

rewind()函数用于将文件指针重新指向文件的开头,同时清除和文件流相关的错误和eof标记,相当于调用fseek(stream, 0, SEEK_SET),其原型如下:

  void rewind(FILE * stream);

【参数】stream为以打开文件的指针。

注意:准确的说,这里的指针不是文件指针stream,而是文件内部的位置指针,随着对文件的读写文件的位置指针(指向当前读写字节)向后移动。而文件指针是指向整个文件,如果不重新赋值文件指针不会改变。

文件指针FILE *stream中,包含一个读写位置指针char *_nextc,它指向下一次文件读写的位置。其结构如下:

typedef struct
{
  int _fd; // 文件号
  int _cleft; // 缓冲区中剩下的字节数
  int _mode; // 文件操作模式
  char * _nextc; // 下一个字节的位置
  char * _buff; // 文件缓冲区位置
}FILE;

每当进行一次读写后,该指针自动指向下一次读写的位置。当文件刚打开或创建时,该指针指向文件的开始位置。可以用函数ftell()获得当前的位置指针,也可以用rewind()/fseek()函数改变位置指针,使其指向需要读写的位置。

【实例】读取文件的数据后再回到开头重新读取。

#include<iostream.h>
#include<stdio.h>
void main(void)
{
  FILE* stream;
  long l;
  float fp;
  char s[81];
  char c;
  stream = fopen("fscanf.txt","w+");
  if(stream == NULL)/*打开文件失败*/
  {
    printf("the file is opeaned error!\n");
  }
  else/*成功则输出信息*/
  {
    fprintf(stream,"%s %ld %f %c","a_string",6500,3.1415,'x');
    fseek(stream,0L,SEEK_SET);      /*定位文件读写指针*/
    fscanf(stream,"%s",s);
    printf("%ld\n",ftell(stream));
    fscanf(stream,"%ld",&l);
    printf("%ld\n",ftell(stream));
    fscanf(stream,"%f",&fp);
    printf("%ld\n",ftell(stream));
    fscanf(stream," %c",&c);
    printf("%ld\n",ftell(stream));
    rewind(stream);/*指向文件开头*/
    fscanf(stream,"%s",s);
    printf("%s\n",s);
    fclose(stream);/*关闭流*/
  }
}

运行结果:

8
13
22
24
a_string

程序先创建一个文件写入一些数据,然后使用feeek函数定位文件指针到文件开头逐个读取数据,读取完毕后使用rewind函数将文件的读/写指针重新定位到文件的开头,再次读取时发现读取的是开头的字符a_string。

又如,把一个文件的内容显示在屏幕上,并同时复制到另一个文件。

#include "stdio.h"
void main()
{
  FILE *fp1, *fp2;
  fp1 = fopen("file1.c", "r"); // 源文件
  fp2 = fopen("file2.c", "w"); // 复制到file2.c
  while(!feof(fp1)) putchar(fgetc(fp1)); // 显示到屏幕上
  rewind(fp1);  // fp回到开始位置
  while(!feof(fp1)) fputc(fgetc(fp1), fp2);
  fclose(fp1);
  fclose(fp2);
}
(0)

相关推荐

  • 详解C语言中的wait()函数和waitpid()函数

    C语言wait()函数:结束(中断)进程函数(常用) 头文件: #include <sys/types.h> #include <sys/wait.h> 定义函数: pid_t wait (int * status); 函数说明:wait()会暂时停止目前进程的执行, 直到有信号来到或子进程结束. 如果在调用wait()时子进程已经结束, 则wait()会立即返回子进程结束状态值. 子进程的结束状态值会由参数status 返回, 而子进程的进程识别码也会一快返回. 如果不在意结束状

  • 简要对比C语言中的truncate()函数与ftruncate()函数

    C语言truncate()函数:改变文件大小 头文件: #include <unistd.h> 定义函数: int truncate(const char * path, off_t length); 函数说明:truncate()会将参数path 指定的文件大小改为参数length 指定的大小. 如果原来的文件大小比参数length 大, 则超过的部分会被删去. 返回值:执行成功则返回0, 失败返回-1, 错误原因存于errno. 错误代码: 1.EACCESS 参数path 所指定的文件无

  • 对比C语言中execv相关的执行文件的三个函数

    C语言execv()函数:执行文件函数 头文件: #include <unistd.h> 定义函数: int execv (const char * path, char * const argv[]); 函数说明:execv()用来执行参数path 字符串所代表的文件路径, 与execl()不同的地方在于execve()只需两个参数, 第二个参数利用数组指针来传递给执行文件. 返回值:如果执行成功则函数不会返回, 执行失败则直接返回-1, 失败原因存于errno 中. 错误代码:请参考 ex

  • C语言中strlen() strcpy() strcat() strcmp()函数的实现方法

    strlen函数原型:unsigned int strlen(const char *);返回的是字符串中第一个\0之前的字符个数. 1.strcat函数原型char* strcat(char* dest,const char* src); 进行字符串的拼接,将第二个字符串连接到第一个字符串中第一个出现\0开始的地方.返回的是拼接后字符的首地址.并不检查第一个数组的大小是否可以容纳第二个字符串.如果第一个数组的已分配的内存不够容纳第二个字符串,则多出来的字符将会溢出到相邻的内存单元. 2.str

  • 浅谈C语言中strcpy,strcmp,strlen,strcat函数原型

    实例如下: //strcat(dest,src)把src所指字符串添加到dest结尾处(覆盖dest结尾处的'\0')并添加'\0' char *strcat(char * strDest, const char *strSrc) { char *res=strDest; assert((strDest!=NULL)&&(strSrc!=NULL)); while(*strDest)strDest++; while(*strDest=*strSrc) { strDest++; strSrc

  • R语言中的fivenum与quantile()函数算法详解

    fivenum()函数: 返回五个数据:最小值.下四分位数数.中位数.上四分位数.最大值 对于奇数个数字=5,fivenum()先排序,依次返回最小值.下四分位数.中位数.上四分位数.最大值 > fivenum(c(1,12,40,23,13)) [1] 1 12 13 23 40 对于奇数个数字>5,fivenum()先排序,我们可以求取最小值,最大值,中位数.在排序中,最小值与中位数中间,若为奇数,取其中位数为下四分位数,若为偶数,取最中间两个数的平均值为下四分位数:在排序中,中位数与最大

  • 详解C语言中sizeof如何在自定义函数中正常工作

    1.在main函数中,sizeof是可以正常工作的,比如: int main() { int n[5]; printf("input: \n"); int i ; for(i = 0; i < 5; i++) { scanf("%d",n + i); } int len = sizeof(n)/sizeof(n[0]); printf("%d\n",len); return 0; } 2.但是在自定义函数中就不可以了,如下: #includ

  • C语言中的setlinebuf()、utmpname()、rewind函数使用

    C语言setlinebuf()函数:设置文件流为线性缓冲区 头文件: #include <stdio.h> 定义函数: void setlinebuf(FILE * stream); 函数说明:setlinebuf()用来设置文件流以换行为依据的无缓冲IO. 相当于调用:setvbuf(stream, (char*)NULL, _IOLBF, 0);请参考setvbuf(). C语言utmpname()函数:设置文件路径 头文件: #include <utmp.h> 定义函数: v

  • 举例详解Go语言中os库的常用函数用法

    (f *File).Name()这个函数是返回文件的名称,函数原型func (f *File) Name() string要文件的指针操作,返回字符串,感觉比较鸡助的方法底层实现 复制代码 代码如下: func (f *File) Name() string { return f.name }  import (  "fmt"  "os" ) func main() {  f, _ := os.Open("1.go")  fmt.Println(

  • 浅析C语言中的setjmp与longjmp函数

    setjmp和longjmp是C语言独有的,只有将它们结合起来使用,才能达到程序控制流有效转移的目的,按照程序员的预先设计的意图,去实现对程序中可能出现的异常进行集中处理. 先来看一下这两个函数的定义吧: setjmp和longjmp的函数原型在setjmp.h中 函数原型:int setjmp(jmp_buf envbuf); setjmp函数用缓冲区envbuf保存系统堆栈的内容,以便后续的longjmp函数使用.setjmp函数初次启用时返回0值. void longjmp(jmp_buf

  • C语言中socket相关网络编程函数小结

    C语言socket()函数:建立一个socket通信 头文件: #include <sys/types.h> #include <sys/socket.h> 定义函数: int socket(int domain, int type, int protocol); 函数说明:socket()用来建立一个新的socket, 也就是向系统注册, 通知系统建立一通信端口. 参数domain 指定使用何种的地址类型, 完整的定义在/usr/include/bits/socket.h 内,

  • Go语言中append函数用法分析

    本文实例分析了Go语言中append函数用法.分享给大家供大家参考.具体如下: Go语言中append的功能十分强大,使用它可以使很多功能的实现变得更加简洁.以下为简单对比: .将一个slice插入到另一个slice的指定位置: 不使用append: 复制代码 代码如下: func insertSliceAtIndex(slice_origin []int, slice_to_insert []int,      insertIndex int) (result []int, err error

  • 详解C语言中rand函数的使用

    前言 我们在编程实现算法的过程中,往往需要使用到随机数.由于计算机是一台以逻辑为基础的机器,没法做到真正的随机(大概量子计算机可以?).所以计算机生成的是伪随机数,供我们使用. 我们使用C语言的rand函数,生成的也是伪随机数. c语言之rand函数的使用 1.写入头文件 #include <stdlib.h> #include <stdio.h> #include <time.h> 2.变量的定义 void main( void ) { int i,k; 3.sran

随机推荐