fseek函数用法_fwrite函数的用法

fseek函数用法_fwrite函数的用法转载请注明出处:https://blog.csdn.net/wl_soft50/article/details/7787521每天进步一点点–>函数fseek()用法在阅读代码时,遇到了很早之前用过的fseek(),很久没有用了,有点陌生,写出来以便下次查阅。函数功能是把文件指针指向文件的开头,需要包含头文件stdio.hfseek函数名:fseek功能:重定位流上的文件…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

转载请注明出处:https://blog.csdn.net/wl_soft50/article/details/7787521

每天进步一点点–>函数fseek() 用法

在阅读代码时,遇到了很早之前用过的fseek(),很久没有用了,有点陌生,写出来以便下次查阅。

函数功能是把文件指针指向文件的开头,需要包含头文件stdio.h

fseek
函数名: fseek
功 能: 重定位流上的文件指针
用 法: int fseek(FILE *stream, long offset, int fromwhere);
描 述: 函数设置文件指针stream的位置。如果执行成功,stream将指向以fromwhere为基准,偏移offset个字 节的位置。如果执行失败(比如offset超过文件自身大小),则不改变stream指向的位置。
返回值: 成功,返回0,否则返回其他值。
fseek position the file position pointer for the file referenced by stream to the byte location calculated by offset.
程序例:

#include <stdio.h>  
  long filesize(FILE *stream);  
  int main(void)  
  {  
    FILE *stream;  
    stream = fopen("MYFILE.TXT", "w+");  
    fprintf(stream, "This is a test");  
    printf("Filesize of MYFILE.TXT is %ld bytes\n", filesize(stream));  
    fclose(stream);  
    return 0;  
  }  
  long filesize(FILE *stream)  
  {  
    long curpos, length;  
    curpos = ftell(stream);  
    fseek(stream, 0L, SEEK_END);  
    length = ftell(stream);  
    fseek(stream, curpos, SEEK_SET);  
    return length;  
  }  

Jetbrains全家桶1年46,售后保障稳定

int fseek( FILE *stream, long offset, int origin );
第一个参数stream为文件指针
第二个参数offset为偏移量,整数表示正向偏移,负数表示负向偏移
第三个参数origin设定从文件的哪里开始偏移,可能取值为:SEEK_CUR、 SEEK_END 或 SEEK_SET
SEEK_SET: 文件开头
SEEK_CUR: 当前位置
SEEK_END: 文件结尾
其中SEEK_SET,SEEK_CUR和SEEK_END和依次为0,1和2.
简言之:
fseek(fp,100L,0);把fp指针移动到离文件开头100字节处;
fseek(fp,100L,1);把fp指针移动到离文件当前位置100字节处;
fseek(fp,100L,2);把fp指针退回到离文件结尾100字节处。(根据评论来看,应该是 fseek(fp,-100L,2) )
使用实例:

#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);  
}  
void main()  
{  
  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: %ld Name: %-8s Scores: ",ss[j].sno, ss[j].name);  
   for (i=0; i<3; i++)   
[cpp] view plain copy
 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: %ld Name: %-8s Scores: ",ss[j].sno, ss[j].name);  
 for (i=0; i<3; i++)   
[cpp] view plain copy
 printf("%6.2f ", ss[j].score[i]);  
 printf("\n");  
}  
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/198339.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 视频监控知识

    视频监控知识CIF分辨率CIF分辨率 CIFcommonintermediateformat DCIFdoubleintermediateformat QCIFquartercommonintermediateformat 图象格式 亮度取样的象素个…

    2022年6月28日
    28
  • idea创建java项目_使用IDEA创建java项目(hello word)

    idea创建java项目_使用IDEA创建java项目(hello word)前提:已安装好jdk,配置好环境变量。我使用的是java8首先在自己的D盘下建一个文件夹,用来存放我们待会新建的项目,我创建了IdeaProject:1,第一步打开idea2,第二步选择创建java项目,并选择自己的jdk(我自己本地已经配置了所以有),没有可以点击new去自己的安装目录下找,一般默认安装C:\ProgramFiles\Java,然后选择next下一步3,第三步将“Creat…

    2022年7月9日
    59
  • 0-1多重背包(单调队列+多重背包)[通俗易懂]

    0-1多重背包(单调队列+多重背包)[通俗易懂]原题链接有 N 种物品和一个容量是 V 的背包。第 i 种物品最多有 si 件,每件体积是 vi,价值是 wi。求解将哪些物品装入背包,可使物品体积总和不超过背包容量,且价值总和最大。输出最大价值。输入格式第一行两个整数,N,V (0<N≤1000, 0<V≤20000),用空格隔开,分别表示物品种数和背包容积。接下来有 N 行,每行三个整数 vi,wi,si,用空格隔开,分别表示第 i 种物品的体积、价值和数量。输出格式输出一个整数,表示最大价值。数据范围0<N≤1

    2022年8月8日
    6
  • CPD 算法实现点云配准(python版本)[通俗易懂]

    CPD 算法实现点云配准(python版本)[通俗易懂]CoherentPointDrift相干点漂移算法实现点云配准(python代码)

    2022年5月28日
    38
  • SENT 协议

    SENT 协议Pending

    2022年6月29日
    72
  • 无插件纯Web 3D机房,HTML5+WebGL倾力打造

    无插件纯Web 3D机房,HTML5+WebGL倾力打造前言-最近项目开发任务告一段落,刚好有时间整理这大半年的一些成果。使用html5时间还不久,对js的认识还不够深入。没办法,以前一直搞java,对js的一些语言特性和概念一时还转换不过来。上一篇大数

    2022年8月3日
    9

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号