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

詳解C語言中fseek函數(shù)和ftell函數(shù)的使用方法

 更新時間:2016年03月14日 18:13:41   作者:YoferZhang  
這篇文章主要介紹了C語言中fseek函數(shù)和ftell函數(shù)的使用方法,兩個函數(shù)分別用于設(shè)置和返回文件指針stream的位置,需要的朋友可以參考下

fseek函數(shù):

int fseek(FILE * _File, long _Offset, int _Origin); 

函數(shù)設(shè)置文件指針stream的位置。如果執(zhí)行成功,stream將指向以fromwhere為基準,偏移offset(指針偏移量)個字節(jié)的位置,函數(shù)返回0。如果執(zhí)行失敗則不改變stream指向的位置,函數(shù)返回一個非0值。
超出文件末尾位置,還是返回0。往回偏移超出首位置,還是返回0,小心使用。
第一個參數(shù)stream為文件指針。
第二個參數(shù)offset為偏移量,正數(shù)表示正向偏移,負數(shù)表示負向偏移。
第三個參數(shù)origin設(shè)定從文件的哪里開始偏移,可能取值為:SEEK_CUR、SEEK_END或SEEK_SET。
SEEK_SET:文件開頭
SEEK_CUR:當(dāng)前位置
SEEK_END:文件結(jié)尾
eg:

#include<stdio.h>
#define N 5
typedef struct student{
 long sno;
 char name[10];
 float score[3];
}STU;
 
void fun(char*filename,STU n)
{
 FILE*fp;
 fp=fopen(filename,"rb+");
 fseek(fp,-1L*sizeof(STU),SEEK_END);
 fwrite(&n,sizeof(STU),1,fp);
 fclose(fp);
}
 
int main()/*修改覆蓋最后一個學(xué)生數(shù)據(jù)*/
{
 STU t[N]={
  {10001,"MaChao",91,92,77},
  {10002,"CaoKai",75,60,88},
  {10003,"LiSi",85,70,78},
  {10004,"FangFang",90,82,87},
  {10005,"ZhangSan",95,80,88}
 };
  
 STU n={10006,"ZhaoSi",55,70,68},ss[N];
 
 int i,j;FILE*fp;
  
 fp=fopen("student.dat","wb");
  
 fwrite(t,sizeof(STU),N,fp);
  
 fclose(fp);
  
 fp=fopen("student.dat","rb");
  
 fread(ss,sizeof(STU),N,fp);
  
 fclose(fp);
  
 printf("\nThe original data:\n\n");
  
 for(j=0;j<N;j++)
 {
  printf("\nNo:%ldName:%-8sScores:",ss[j].sno,ss[j].name);
  for(i=0;i<3;i++)
    printf("%6.2f",ss[j].score[i]);
  printf("\n");
 }
 fun("student.dat",n);
 printf("\nThe data after modifing:\n\n");
 
 fp=fopen("student.dat","rb");
 fread(ss,sizeof(STU),N,fp);
 fclose(fp);
 
 for(j=0;j<N;j++)
 {
  printf("\nNo:%ldName:%-8sScores:",ss[j].sno,ss[j].name);
  for(i=0;i<3;i++)
    printf("%6.2f",ss[j].score[i]);
  printf("\n");
 }
 return 0;
}

ftell函數(shù)
ftell函數(shù)用于得到文件位置指針當(dāng)前位置相對與文件首的偏移字節(jié)數(shù)。在隨機方式存取文件時,由于文件位置頻繁的前后移動,程序不容易確定文件的當(dāng)前位置。

long len = ftell(fp) 

eg1:

#include <stdio.h>
int main( void )
{
 FILE *stream;
 stream = fopen( "MYFILE.TXT", "w+" );
 fprintf( stream, "This is a test" );
 printf( "The file pointer is at byte \
%ld\n", ftell( stream ) );
 fclose( stream );
 return(0);
}

eg2:
ftell一般用于讀取文件的長度,下面補充一個例子,讀取文本文件中的內(nèi)容:

#include <stdio.h>
#include <stdlib.h>
int main()
{
 FILE *fp;
 int flen;
 char *p;
/* 以只讀方式打開文件 */
 if ( (fp = fopen( "1.txt", "r" ) ) == NULL )
 {
 printf( "\nfile open error\n" );
 exit( 0 );
 }
 fseek( fp, 0L, SEEK_END );       /* 定位到文件末尾 */
 flen = ftell( fp );         /* 得到文件大小 */
 p = (char *) malloc( flen + 1 ); /* 根據(jù)文件大小動態(tài)分配內(nèi)存空間 */
 if ( p == NULL )
 {
 fclose( fp );
 return(0);
 }
 fseek( fp, 0L, SEEK_SET );       /* 定位到文件開頭 */
 fread( p, flen, 1, fp );        /* 一次性讀取全部文件內(nèi)容 */
 p[flen] = '\0';             /* 字符串結(jié)束標志 */
 printf( "%s", p );
 fclose( fp );
 free( p );
 return(0);
}


程序改進

#include <stdio.h>
main()
{
 FILE *myf;
 long f1; /* 此處將f1設(shè)置為long 可以讀取更長的文件 */
 myf = fopen( "1.txt", "rb" );
 fseek( myf, 0, SEEK_END );
 f1 = ftell( myf );
 fclose( myf );
 printf( “ % d \ n ”, f1 );
}

相關(guān)文章

  • 使用C++中的ADO對SQLite進行增刪改查

    使用C++中的ADO對SQLite進行增刪改查

    本文將介紹如何使用C++的ADO (ActiveX Data Objects)對SQLite數(shù)據(jù)庫進行增刪改查操作,文中有詳細的代碼示例,需要的朋友可以參考下
    2023-06-06
  • C語言求解最長公共子字符串問題及相關(guān)的算法分析

    C語言求解最長公共子字符串問題及相關(guān)的算法分析

    最長公共子字符串問題即是求一個字符串在另一個字符串中出現(xiàn)的連續(xù)最多字符,這里我們來看一下面試中經(jīng)常出現(xiàn)的C語言求解最長公共子字符串問題及相關(guān)的算法分析
    2016-06-06
  • C語言控制臺打磚塊小游戲

    C語言控制臺打磚塊小游戲

    這篇文章主要為大家詳細介紹了C語言控制臺打磚塊小游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • 深入分析C中不安全的sprintf與strcpy

    深入分析C中不安全的sprintf與strcpy

    本篇文章是對C中不安全的sprintf與strcpy函數(shù)的使用進行了詳細的分析介紹,需要的朋友參考下
    2013-05-05
  • C語言之如何求三次方根

    C語言之如何求三次方根

    這篇文章主要介紹了C語言之如何求三次方根問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • C語言實現(xiàn)猜數(shù)字小游戲

    C語言實現(xiàn)猜數(shù)字小游戲

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)猜數(shù)字小游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-11-11
  • C++計數(shù)排序詳解

    C++計數(shù)排序詳解

    計數(shù)排序的思想我們之前接觸過的例如:插入排序,歸并排序,快速排序,堆排序等都是基于集合元素之間的比較這一基本的思想,它們執(zhí)行的時間復(fù)雜度最優(yōu)是趨于O(nlgn),而計數(shù)排序的運行機制不是基于集合元素之間的大小比較
    2016-04-04
  • linux c 獲得當(dāng)前進程的進程名和執(zhí)行路徑(示例)

    linux c 獲得當(dāng)前進程的進程名和執(zhí)行路徑(示例)

    如何得到當(dāng)前進程的進程名和執(zhí)行路徑。寫了個程序分享一下
    2013-07-07
  • C++中perror和fprintf區(qū)別解析

    C++中perror和fprintf區(qū)別解析

    本文主要對比了C語言中的兩個函數(shù)perror和fprintf的區(qū)別,perror主要用于輸出與系統(tǒng)錯誤相關(guān)的消息,根據(jù)全局變量errno的值生成錯誤信息,而fprintf則用于格式化輸出任意類型的信息到指定的文件流
    2024-10-10
  • Qt實現(xiàn)蘋果狀態(tài)切換按鈕

    Qt實現(xiàn)蘋果狀態(tài)切換按鈕

    這篇文章主要為大家詳細介紹了Qt實現(xiàn)蘋果狀態(tài)切換按鈕,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-08-08

最新評論