指针读取文件(简单、干净的知识点罗列)

2024-05-13 18:20

本文主要是介绍指针读取文件(简单、干净的知识点罗列),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一.基本操作

FILE *fp;//定义一个文件指针

fp=fopen("打开文件名","打开方式");//把文件指针具体的去指向一个文件

//然后对文件进行操作

fclose(fp);//要关闭文件

二.对文件操作的函数

Ⅰ:

1)fgetc函数:

功能:从fp所指向的文件里面读取出一个字符。 (r)

格式:字符型变量=fget(fp); //fp是一个文件指针

文件一定要以读的方式打开,之后指针会自动向后移动一个位置

2)fputc函数:

功能:从fp所指向的文件里面写入一个字符。 (w)

格式:fputc(要写入的字符,fp);

文件一定要以写的方式打开,之后指针会自动向后移动一个位置

3)fgets函数:

功能:从fp所指向的文件里面读取出来一个字符串

格式:fgets(str,n,fp);它会读出n-1个字符,留一个字符为\0

str:存放字符串的一个数组,n表示读取出来字符的个数,fp是文件的指针

4)fputs函数

功能:把字符串写入到fp和指向的文件当中去

格式:fputs(str,fp);把str当中所有的字符写入到fp里面去

5)专门用来对二进制文件进行操作

A:fwrite函数:

功能:把一个结构体变量当中的信息以二进制的形式写入到指定的文件当中去

格式:fwrite(&结构体变量名,sizeof(结构体类型),1,fp);

B:fread函数:

功能:从fp所指向的文件当中读出一条信息,存放在一个结构体变量当中

格式:fread(&结构体变量名,sizeof(结构体类型),1,fp);

6) feof函数;

功能:判断指向文件的指针是否指向文件的末尾

格式:feof(文件指针);返回1则代表指向了文件的末尾,返回0则代表没有指向文件末尾

feof(fp);

一般的用法:while(!feof(fp));

//(!feof(fp))返回0则代表指向了文件的末尾,返回1则代表没有指向文件末尾

Ⅱ:

这些函数都是C语言标准库`cstdio.h`中提供的文件操作函数,用于进行文件的读写操作。

1. `fgetc`:用于从文件中读取一个字符,并将该字符作为无符号字符类型(`unsigned char`)返回

2. `fputc`:用于向文件中写入一个字符。它接受一个字符和一个文件指针作为参数,将字符写入到文件中。

3. `fgets`:用于从文件中读取一行字符串。它接受一个字符数组、数组长度和一个文件指针作为参数,将读取到的字符串存储到指定的字符数组中。

4. `fputs`:用于向文件中写入一个字符串。它接受一个字符串和一个文件指针作为参数,将字符串写入到文件中。

5. `fwrite`:用于向文件中写入一块内存的数据。它接受一个指向要写入数据的指针、数据块的大小、数据块数量和一个文件指针作为参数,将数据写入到文件中。

6. `fread`:用于从文件中读取一块内存的数据。它接受一个指向存储读取数据的指针、数据块的大小、数据块数量和一个文件指针作为参数,将文件中的数据读取到指定的内存区域中

7. `feof`:用于检测文件流的结束标志。当文件指针已经指向文件尾部时,`feof`函数返回非零值,否则返回 0。

Ⅲ:

在 C 语言中, `SEEK_SET`、`SEEK_END` 和 `SEEK_CUR` 是 `fseek` 函数中用于指定偏移量计算方式的三个常量。

1. `SEEK_SET`:表示从文件的起始位置开始计算偏移量。当调用 `fseek` 函数时,如果指定了 `SEEK_SET` 作为第三个参数,那么偏移量就是相对于文件的开头位置进行计算的。

2. `SEEK_END`:表示从文件的尾部位置开始计算偏移量。当调用 `fseek` 函数时,如果指定了`SEEK_END` 作为第三个参数,那么偏移量就是相对于文件尾部位置进行计算的。通常用于定位到文件的末尾,例如获取文件的大小。

3. `SEEK_CUR`:表示从文件当前位置开始计算偏移量。当调用 `fseek` 函数时,如果指定了 `SEEK_CUR` 作为第三个参数,那么偏移量就是相对于当前文件指针位置进行计算的。通常用于在文件中移动文件指针的位置。

Ⅳ:

在C语言中,以下函数在读取或写入数据后会自动将文件指针向后移动一位

1. `fgetc`:读取一个字符后,文件指针自动向后移动一位。

2. `fputc`:写入一个字符后,文件指针自动向后移动一位。

3. `fgets`:读取一行字符串后,文件指针会移动到下一行的起始位置,即换行符后一位。

4. `fputs`:写入一个字符串后,文件指针会移动到写入字符串的尾部位置。

5. `fwrite`:写入数据后,文件指针会根据写入的数据量自动向后移动相应的字节数。

6. `fread`:读取数据后,文件指针会根据读取的数据量自动向后移动相应的字节数。

这些函数在执行完读写操作后会自动调整文件指针的位置,使其指向下一个可读取或可写入的位置。

Ⅴ:

`rewind`函数是C语言中用来将文件指针重置回文件的开头位置的函数。这个函数接受一个文件指针(`FILE*`类型)作为参数,并且将该文件指针设置到该文件的起始位置,同时还会清除文件的错误标志和文件结束标志(即`feof`和`ferror`的状态会被重置)。

使用`rewind`函数是操作文件时重置读写位置的一种简便方式,特别是在需要多次从文件开始位置读取数据的情况下,使用它可以简化代码,因为它不需要像`fseek`那样需要指定偏移量和起始位置。`rewind`与执行`fseek(file, 0, SEEK_SET)`相比,更为简洁,且无需处理`fseek`的返回值。

总结一下,`rewind`函数的主要作用是:

- 将文件指针移动到文件的开始位置。

- 清除关联文件流的错误标志和文件结束标志。

这篇关于指针读取文件(简单、干净的知识点罗列)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/986470

相关文章

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

基本知识点

1、c++的输入加上ios::sync_with_stdio(false);  等价于 c的输入,读取速度会加快(但是在字符串的题里面和容易出现问题) 2、lower_bound()和upper_bound() iterator lower_bound( const key_type &key ): 返回一个迭代器,指向键值>= key的第一个元素。 iterator upper_bou

hdu2289(简单二分)

虽说是简单二分,但是我还是wa死了  题意:已知圆台的体积,求高度 首先要知道圆台体积怎么求:设上下底的半径分别为r1,r2,高为h,V = PI*(r1*r1+r1*r2+r2*r2)*h/3 然后以h进行二分 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#includ

usaco 1.3 Prime Cryptarithm(简单哈希表暴搜剪枝)

思路: 1. 用一个 hash[ ] 数组存放输入的数字,令 hash[ tmp ]=1 。 2. 一个自定义函数 check( ) ,检查各位是否为输入的数字。 3. 暴搜。第一行数从 100到999,第二行数从 10到99。 4. 剪枝。 代码: /*ID: who jayLANG: C++TASK: crypt1*/#include<stdio.h>bool h

uva 10387 Billiard(简单几何)

题意是一个球从矩形的中点出发,告诉你小球与矩形两条边的碰撞次数与小球回到原点的时间,求小球出发时的角度和小球的速度。 简单的几何问题,小球每与竖边碰撞一次,向右扩展一个相同的矩形;每与横边碰撞一次,向上扩展一个相同的矩形。 可以发现,扩展矩形的路径和在当前矩形中的每一段路径相同,当小球回到出发点时,一条直线的路径刚好经过最后一个扩展矩形的中心点。 最后扩展的路径和横边竖边恰好组成一个直

poj 1113 凸包+简单几何计算

题意: 给N个平面上的点,现在要在离点外L米处建城墙,使得城墙把所有点都包含进去且城墙的长度最短。 解析: 韬哥出的某次训练赛上A出的第一道计算几何,算是大水题吧。 用convexhull算法把凸包求出来,然后加加减减就A了。 计算见下图: 好久没玩画图了啊好开心。 代码: #include <iostream>#include <cstdio>#inclu

uva 10130 简单背包

题意: 背包和 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#include <stack>#include <vector>#include <queue>#include <map>

两个月冲刺软考——访问位与修改位的题型(淘汰哪一页);内聚的类型;关于码制的知识点;地址映射的相关内容

1.访问位与修改位的题型(淘汰哪一页) 访问位:为1时表示在内存期间被访问过,为0时表示未被访问;修改位:为1时表示该页面自从被装入内存后被修改过,为0时表示未修改过。 置换页面时,最先置换访问位和修改位为00的,其次是01(没被访问但被修改过)的,之后是10(被访问了但没被修改过),最后是11。 2.内聚的类型 功能内聚:完成一个单一功能,各个部分协同工作,缺一不可。 顺序内聚:

【C++学习笔记 20】C++中的智能指针

智能指针的功能 在上一篇笔记提到了在栈和堆上创建变量的区别,使用new关键字创建变量时,需要搭配delete关键字销毁变量。而智能指针的作用就是调用new分配内存时,不必自己去调用delete,甚至不用调用new。 智能指针实际上就是对原始指针的包装。 unique_ptr 最简单的智能指针,是一种作用域指针,意思是当指针超出该作用域时,会自动调用delete。它名为unique的原因是这个

C语言指针入门 《C语言非常道》

C语言指针入门 《C语言非常道》 作为一个程序员,我接触 C 语言有十年了。有的朋友让我推荐 C 语言的参考书,我不敢乱推荐,尤其是国内作者写的书,往往七拼八凑,漏洞百出。 但是,李忠老师的《C语言非常道》值得一读。对了,李老师有个官网,网址是: 李忠老师官网 最棒的是,有配套的教学视频,可以试看。 试看点这里 接下来言归正传,讲解指针。以下内容很多都参考了李忠老师的《C语言非