一、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;
}