概述
1.read
#include <unistd.h>
ssize_t read(int filedes,void *buf,size_t nbytes);
read函数从filedes指定的已打开文件中读取nbytes字节到buf中。
返回值:读取到的字节数,0代表读到EOF,-1代表出错。
2.write
#include <unistd.h>
ssize_t write(int filedes,const void *buf,size_t nbytes);
write函数向filedes中写入nbytes字节数据,数据来源为buf。
返回值一般等于nbytes,否则就是出错了。
3.fputs
#include <stdio.h>
fputs(char *str,FILE *stream);
把str中零结束符之前的全部文件输入到文件中。
输入完成后,不会增加额外的特殊字符,如换行符等。
4fgets
#include <stdio.h>
char *fgets(char *str,int num,FILE *stream);
函数fgets()从给定的文件流中读取num-1个字符并且把它们转到stream中
5.fread
size_t fread ( void *buffer, size_t size, size_t count, FILE *stream) ;
fread与read的区别:
fread是C标准库。而后者的是UNIX下的系统调用。fread带有缓冲,是read的衍生,或者说fread是通过read实现的。要想直接和硬件打交道,必须用read。
另外,fread操作的对象是file stream,而read操作的对象是: “file descriptor”。
如果文件的大小是8k。你如果用read/write(需要自己设定缓冲区的大小),且只分配了2k的缓存,则要将此文件读出需要做4次系统调用来实际从磁盘上读出。
如果你用fread/fwrite,则系统自动分配缓存,则读出此文件只要一次系统调用从磁盘上读出。
6.fopen
函数原型:FILE * fopen(const char * path, const char * mode);
open 是系统调用 返回的是文件句柄,文件的句柄是文件在文件描述副表里的索引,fopen是C的库函数,返回的是一个指向文件结构的指针。
7.gets
函数原型:char*gets(char*buffer);//读取字符到数组:gets(str);str为数组名。
函数功能:从键盘上输入字符,直至接受到换行符或EOF时停止,并将读取的结果存放在buffer指针所指向的字符数组中。
读取的换行符被转换为null值,做为字符数组的最后一个字符,来结束字符串。
注意:gets函数由于没有指定输入字符大小,所以会无限读取,一旦输入的字符大于数组长度,就会发生内存越界,从而造成程序崩溃或其他数据的错误。
最后
以上就是眼睛大大米为你收集整理的C语言中的read()、write()、fputs()、fgets()的全部内容,希望文章能够帮你解决C语言中的read()、write()、fputs()、fgets()所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复