c的 write read open close

本文详细介绍了C语言中关于文件操作的基本函数,包括open函数的函数原型、flag参数及如何处理不存在的文件,close函数的使用,read函数的函数原型、返回值解析及实例,以及write函数的说明。通过这些函数,开发者可以实现对文件的打开、关闭、读取和写入操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、open

1、函数原型

#include <sys/types.h>  
#include <sys/stat.h>  
#include <fcntl.h>
int open(const char *pathname, int flags);

根据pathname,按flag所指的方式,打开一个文件,返回fd

int fd;
fd = open ("/home/username/file.ext",  O_WRONLY | O_TRUNC);

2、 flag

 3、打开存在和不存在的文件

对于一个不存在的文件,函数原型应该多一个参数:

int open(const char *pathname, int flags,mode_t mode);

其中mode表示创建的这个文件的权限,权限可以用预先定义的宏来表示(下标第一列),也可以用数字来表示(下标第二列):

如果要用数字表示,应该怎么计算数字呢?

数字里的第一个0表示这是八进制,第二个数字表示user的权限,第三个数字表示group的权限,第四个表示other的权限。

那每一位数字又是怎么算出来的呢?假设我有user的权限是6,6代表user有什么样的权限呢?

6实际上是将三个二进制数转换成八进制的结果,这三个二进制数分别表示读,写,执行。

如果希望user可以读写,不能执行,就写出三个二进制数:110,第一个1表示可以读,第二个1表示可以写,第三个0表示不可以执行,然后转换为八进制,就是6.

来看例子:

 

 
 二、close 

#include <unistd.h>  
int close(int fd);

 关闭这个fd,返回0表示成功,返回1表示失败。

#include <stdio.h>  
#include <stdlib.h>  
#include <sys/types.h>  
#include <sys/stat.h>  
#include <fcntl.h>  
#include <unistd.h>  
#define MODE 0644

int main() {
int fd;

//myfile.txt is in the same folder.
fd = open ("myfile.txt", O_RDWR | O_CREAT, MODE);  if (fd == -1) {
fprintf(stderr, "Open failed.\n");  exit(1);
}

//close myfile.txt
if (close(fd) == -1) {
fprintf(stderr, "Close failed.\n");  exit(1);
}


return 0;
}

三、read

1、函数原型

#include <unistd.h>
ssize_t read(int fd, void *buf, size_t count);

从fd所指的file里,一次读count位,到buf里。

如果成功,返回读取的位数(如果count>sizeof(fd),那显然只能读取sizeof(fd)位,如果count<sizeof(fd),那显然只能读取count位;

如果失败,则返回-1;

如果读取到文件末尾,则返回0(文件里已经没有可读的东西了,即使文件里剩余的大小小于我一次读取的大小,文件里也是有可以读取的大小的,这时会返回实际读取的字节大小).

举例,buffer大小为7,一次读3位,循环读取,则前两次返回3,第三次返回1,第四次返回0.

2、sszie_t

ssize_t一般被用来表示有多少字节。它的值域是整数,当它为负数的时候,表示返回的这个函数出了问题。

虽然它的值域是整数,但是它不等于int。

但是我们依旧可以把把int赋给返回值为ssize_t的函数:

int n=read(int fd, void *buf, size_t count);

假如我们读取的了四个char,一个char占一个字节,所以n就会等于4;

如果我们读取了四个int,一个int占四个字节,所以n就等于16;

一个字节(byte)有8位(bit)

我们常说的1kb=1024b中的b指的是字节

ps:字(word)说的是操作系统一次可以处理的数据,字长就是说这个数据有几个bit。

也就是说字只是一个概念,它的大小(也就是字长)是随操作系统改变而改变的。对于32位的系统,一次可以处理32bit(4字节),它的字长就是32,对于64位系统,字长就是64.

3.例子

#include <stdlib.h>  、
#include <sys/types.h>  
#include <sys/stat.h>  
#include <fcntl.h>  
#include <unistd.h>
#define MODE S_IRWXU | S_IRGRP | S_IWGRP | S_IXOTH
#define SIZE 25

int main() {
int fd;
int temp;
char buf[SIZE];

//myfile.txt is in the same folder.
fd = open ("myfile.txt", O_RDWR | O_CREAT, MODE); 
//这是不是就很像打开一个文件了呢,读取这个文件的fd,之后read的时候就可以找到这个file了
 if (fd == -1) {
fprintf(stderr, "Open failed.\n");  exit(1);
}
// Read myfile.txt.
if ((temp = read(fd, buf, (size_t) SIZE)) == -1) {  fprintf(stderr, "Error in read.\n");
exit(1);
}
if (temp == 0) {/* Code for handling EOF. */
}
return 0;
}

四、write

#include <unistd.h>
ssize_t write(int fd, const void *buf,size_t count);  

Return the number of bytes written on success, -1 on  error 

#include <stdio.h>  
#include <stdlib.h>  
#include <sys/types.h>  
#include <sys/stat.h>  
#include <fcntl.h>  
#include <unistd.h>
#define MODE S_IRWXU | S_IRGRP | S_IWGRP | S_IXOTH
#define SIZE 25

int main() {
int fd;  int temp;
char buf[SIZE];

//myfile.txt is in the same folder.
fd = open ("myfile.txt", O_RDWR | O_CREAT, MODE);  if (fd == -1) {
fprintf(stderr, "Open failed.\n");  exit(1);
}

// Write to myfile.txt.
temp = write(fd, buf, (size_t) SIZE);  if (temp == -1) {
fprintf(stderr, "Error in write.\n");  exit(1);
}
return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值