UNIX/Linux系统调用下的文件操作

系统调用

UNIX/Linux系统绝大部分功能都是通过系统调用实现,比如:open/close…
UNIX/Linux把系统调用都封装成了C函数的形式,但他们并不是标准C的一部分。

一切皆文件

在UNIX/Linux系统下,几乎所有资源都是以文件形式提供了,所以在UNIX/Linux系统下一切皆文件,操作系统把它的服务、功能、设备抽象成简单的文件,提供一套简单统一的接口,这样程序就可以像访问磁盘上的文件一样访问串口、终端、打印机、网络等功能。
大多数情况下只需要 open/read/write/ioctl/close 就可以实现对各种设备的输入、输出、设置、控制等。 UNIX/Linux下几乎任何对象都可以当作特殊类型的文件,可以以文件的形式访问。

文件相关系统调用

open 打开或创建文件
creat 创建文件
close 关闭文件
read 读文件
write 写文件
lseek 设置文件读写位置
unlink 删除链接
remove 删除文件

(1) open()

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

功能:打开文件

返回值:文件描述符

参数:

pathname:文件的路径
flags:打开的权限

O_RDONLY, 只读
O_WRONLY, 只写
O_RDWR,读写
O_NOCTTY, 当打开的是终端设备文件,不要把该文件当作主控终端。
O_TRUNC,清空
O_APPEND,追加

creat()

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

功能:创建文件

pathname:文件的路径

flags:打开的权限

O_CREAT, 文件不存在则创建
O_EXCL,如果文件存在,则创建失败

mode:设置文件的权限

S_IRWXU 00700 read,write and execute permission
S_IRUSR00400 user has read permission
S_IWUSR 00200 user has writepermission
S_IXUSR 00100 user has execute permission
S_IRWXG 00070 read,write and execute permission
S_IRGRP 00040 group has read permission
S_IWGRP 00020 group has write permission
S_IXGRP 00010 group has execute permission
S_IRWXO 00007 others have read, write and execute permission S_IROTH 00004 others have read permission
S_IWOTH 00002 others have writepermission
S_IXOTH 00001 others have execute permission

read()/write()

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

功能:从文件中读取数据到内存

fd:文件描述符,open函数的返回值

buf:数据的存储位置 count:读取的字节数

返回值:成功读取到的字节数

ssize_t write(int fd,const void *buf, size_t count);

功能:把数据写入到文件

fd:文件描述符,open函数的返回值

buf:要写入的数据内存首地址

count:要写入的字节数

返回值:成功写入的字节数

注意:如果把结构体以文本形式写入到文件,需要先把结构体转换成字符串。

  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值