欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語(yǔ)言中的setlinebuf()、utmpname()、rewind函數(shù)使用

 更新時(shí)間:2015年08月30日 17:36:55   投稿:goldensun  
這篇文章主要介紹了C語(yǔ)言中的setlinebuf()、utmpname()、rewind函數(shù)使用,是C語(yǔ)言中操作文件的一些基本函數(shù),需要的朋友可以參考下

C語(yǔ)言setlinebuf()函數(shù):設(shè)置文件流為線性緩沖區(qū)
頭文件:

#include <stdio.h>

定義函數(shù):

void setlinebuf(FILE * stream);

函數(shù)說(shuō)明:setlinebuf()用來(lái)設(shè)置文件流以換行為依據(jù)的無(wú)緩沖IO. 相當(dāng)于調(diào)用:setvbuf(stream, (char*)NULL, _IOLBF, 0);請(qǐng)參考setvbuf().

C語(yǔ)言u(píng)tmpname()函數(shù):設(shè)置文件路徑
頭文件:

#include <utmp.h>

定義函數(shù):

void utmpname(const char * file);

函數(shù)說(shuō)明:utmpname()用來(lái)設(shè)置utmp 文件的路徑, 以提供utmp 相關(guān)函數(shù)的存取路徑. 如果沒有使用utmpname()則默認(rèn)utmp 文件路徑為/var/run/utmp。

C語(yǔ)言rewind()函數(shù):將文件指針重新指向文件開頭
頭文件:

 #include <stdio.h>

rewind()函數(shù)用于將文件指針重新指向文件的開頭,同時(shí)清除和文件流相關(guān)的錯(cuò)誤和eof標(biāo)記,相當(dāng)于調(diào)用fseek(stream, 0, SEEK_SET),其原型如下:

  void rewind(FILE * stream);

【參數(shù)】stream為以打開文件的指針。

注意:準(zhǔn)確的說(shuō),這里的指針不是文件指針stream,而是文件內(nèi)部的位置指針,隨著對(duì)文件的讀寫文件的位置指針(指向當(dāng)前讀寫字節(jié))向后移動(dòng)。而文件指針是指向整個(gè)文件,如果不重新賦值文件指針不會(huì)改變。

文件指針FILE *stream中,包含一個(gè)讀寫位置指針char *_nextc,它指向下一次文件讀寫的位置。其結(jié)構(gòu)如下:

typedef struct
{
  int _fd; // 文件號(hào)
  int _cleft; // 緩沖區(qū)中剩下的字節(jié)數(shù)
  int _mode; // 文件操作模式
  char * _nextc; // 下一個(gè)字節(jié)的位置
  char * _buff; // 文件緩沖區(qū)位置
}FILE;

每當(dāng)進(jìn)行一次讀寫后,該指針自動(dòng)指向下一次讀寫的位置。當(dāng)文件剛打開或創(chuàng)建時(shí),該指針指向文件的開始位置。可以用函數(shù)ftell()獲得當(dāng)前的位置指針,也可以用rewind()/fseek()函數(shù)改變位置指針,使其指向需要讀寫的位置。

【實(shí)例】讀取文件的數(shù)據(jù)后再回到開頭重新讀取。

#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);/*關(guān)閉流*/
  }
}

運(yùn)行結(jié)果:

8
13
22
24
a_string

程序先創(chuàng)建一個(gè)文件寫入一些數(shù)據(jù),然后使用feeek函數(shù)定位文件指針到文件開頭逐個(gè)讀取數(shù)據(jù),讀取完畢后使用rewind函數(shù)將文件的讀/寫指針重新定位到文件的開頭,再次讀取時(shí)發(fā)現(xiàn)讀取的是開頭的字符a_string。

又如,把一個(gè)文件的內(nèi)容顯示在屏幕上,并同時(shí)復(fù)制到另一個(gè)文件。

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

相關(guān)文章

  • c++雙向鏈表操作示例(創(chuàng)建雙向鏈、雙向鏈表中查找數(shù)據(jù)、插入數(shù)據(jù)等)

    c++雙向鏈表操作示例(創(chuàng)建雙向鏈、雙向鏈表中查找數(shù)據(jù)、插入數(shù)據(jù)等)

    這篇文章主要介紹了c++雙向鏈表操作示例,包括創(chuàng)建雙向鏈、刪除雙向鏈表、雙向鏈表中查找數(shù)據(jù)、插入數(shù)據(jù)等,需要的朋友可以參考下
    2014-05-05
  • C++實(shí)現(xiàn)LeetCode(205.同構(gòu)字符串)

    C++實(shí)現(xiàn)LeetCode(205.同構(gòu)字符串)

    這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(205.同構(gòu)字符串),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • 一文讀懂C++中Protobuf

    一文讀懂C++中Protobuf

    Protocol Buffers 是一種輕便高效的結(jié)構(gòu)化數(shù)據(jù)存儲(chǔ)格式,可以用于結(jié)構(gòu)化數(shù)據(jù)串行化、或者說(shuō)序列化,本文詳解了Protobuf的使用,具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-05-05
  • C語(yǔ)言實(shí)現(xiàn)求最大公約數(shù)的三種方法

    C語(yǔ)言實(shí)現(xiàn)求最大公約數(shù)的三種方法

    最大公因數(shù),也稱最大公約數(shù)、最大公因子,指兩個(gè)或多個(gè)整數(shù)共有約數(shù)中最大的一個(gè)。本文將為大家介紹三種方法來(lái)實(shí)現(xiàn)求解兩個(gè)正整數(shù)的最大公約數(shù),需要的可以參考一下
    2021-12-12
  • 對(duì)for循環(huán)中表達(dá)式和循環(huán)體的執(zhí)行順序詳解

    對(duì)for循環(huán)中表達(dá)式和循環(huán)體的執(zhí)行順序詳解

    今天小編就為大家分享一篇對(duì)for循環(huán)中表達(dá)式和循環(huán)體的執(zhí)行順序詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-06-06
  • C++實(shí)現(xiàn)LeetCode(58.求末尾單詞的長(zhǎng)度)

    C++實(shí)現(xiàn)LeetCode(58.求末尾單詞的長(zhǎng)度)

    這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(58.求末尾單詞的長(zhǎng)度),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • C++?正則表達(dá)式的應(yīng)用詳解

    C++?正則表達(dá)式的應(yīng)用詳解

    正則表達(dá)式(regular?expression)描述了一種字符串匹配的模式(pattern),可以用來(lái)檢查一個(gè)串是否含有某種子串、將匹配的子串替換或者從某個(gè)串中取出符合某個(gè)條件的子串等
    2021-11-11
  • C語(yǔ)言字符/字符串相關(guān)函數(shù)收藏大全

    C語(yǔ)言字符/字符串相關(guān)函數(shù)收藏大全

    這篇文章主要給大家介紹了關(guān)于C語(yǔ)言字符/字符串的相關(guān)函數(shù),文中通過(guò)示例代碼總結(jié)的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用C語(yǔ)言具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • c++模擬實(shí)現(xiàn)string類詳情

    c++模擬實(shí)現(xiàn)string類詳情

    這篇文章主要介紹了c++模擬實(shí)現(xiàn)string類詳情,string表示可變長(zhǎng)的字符序列,使用string類型必須首先包含string頭文件。作為標(biāo)準(zhǔn)庫(kù)的一部分,string定義在命名空間std中,下面進(jìn)入文章一起看看詳細(xì)內(nèi)容吧
    2022-01-01
  • openCV4.1.1+VS2019環(huán)境配置詳解

    openCV4.1.1+VS2019環(huán)境配置詳解

    這篇文章主要介紹了openCV4.1.1+VS2019環(huán)境配置詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08

最新評(píng)論