Linux系统API:
打开 open
读写 write/read
光标定位 lseek
关闭 close
SYNOPSIS
**#include
#include
#include
int creat(const char *pathname, mode_t mode);**
pathname:要创建的文件名(包括路径,缺省为当前路径)
mode:创建模式
常见创建模式:
宏表示 数字
S_IRUSR 4 可读
S_IWUSR 2 可写
S_IXUSR 1 可执行
S_IRWXU 7 可读可写可执行
#include
#include
#include
#include
int main()
{
int fd;
// int creat(const char *pathname, mode_t mode);
fd = creat("./file4",S_IRWXU);
return 0;
}
~
2.打开文件
SYNOPSIS
**#include
#include
#include
int open(const char pathname, int flags);
int open(const char pathname, int flags, mode_t mode);
Pathname :要打开的文件名(含路径,缺省为当前路径)
Flags:
O_RDONLY 只读打开
O_WRONLY 只写打开
O_RDWR 可读可写打开
当我们附带了权限后,打开的文件就只能按照这种权限来 *** 作。
以上这三个常数中应当只指定一个。下列常数是可选择的
O_CREAT 若文件不存在则创建它。使用此选项时,需要同时说明第三个参数mode.用其说明该新文件的存取许可权限。
O_EXCL 如果同时指定了OCREAT,而文件己经存在,则出错。
O_APPEND 每次写时都加到文件的尾端
O_TRUNC 属性去打开文件时,如果这个文件中本来是有内容的,而且为只读或只写成功打开,则将其长度截短为0。
Mode:一定是在flags中使用了O_CREAT标志,mode记录待创建的文件的访问权限
文件权限:
可读 r 4
可写 w 2
可执行 x 1
例如:0600->可读可写
#include
#include
#include
#include
int main()
{
int fd;
fd = open("./file1",O_RDWR);
if(fd = -1){
printf("open file failed!\n");
fd = open("./file1",O_RDWR|O_CREAT,0600);
if(fd>0){
printf("creat file1 success\n");
}
}
return 0;
}
3.写入文件
SYNOPSIS
*#include
ssize_t write(int fd, const void buf, size_t count);
DESCRIPTION
最多写入以计数字节数count,从缓冲区指向 buf 到文件描述符 fd 引用的文件。
RETURN VALUE
成功时,将返回写入的字节数(零表示什么也没写)。 出错时,返回 -1。
#include
#include
#include
#include
#include
#include
int main()
{
int fd;
char *buf = "Hello world";
fd = open("./file1",O_RDWR);
if(fd = -1){
printf("open file failed!\n");
fd = open("./file1",O_RDWR|O_CREAT,0600);
if(fd>0){
printf("creat file1 success\n");
}
}
printf("open success:fd = %d\n",fd);
// ssize_t write(int fd, const void *buf, size_t count);
write(fd,buf,strlen(buf));
//计算缓冲区大小时不能用sizeof(),要用strlen。strlen()函数用来计算字符串的长度而sizeof () 是一个判断数据类型或者表达式长度的运算符。
close(fd);
return 0;
4.读取文件
SYNOPSIS
*#include
ssize_t read(int fd, void buf, size_t count);
DESCRIPTION
read() 尝试读取以将文件描述符 fd 中的字节数计算到缓冲区从 buf 开始。
如果 count 为零,则 read() 返回零并且没有其他结果。 如果计数大于 SSIZE_MAX,结果未指定。
RETURN VALUE
成功时,将返回读取的字节数(零表示结束file),并且文件位置按此数字前进。 出错时,返回 -1,并设置 errno。
ERRORS
EAGAIN :文件描述符 fd 引用套接字以外的文件,并且已被标记为非阻塞(O_NONBLOCK),读取将阻塞。
SYNOPSIS
#include
#include
off_t lseek(int fd, off_t offset, int whence);
DESCRIPTION
lseek() 函数根据指令将与文件描述符 fd 关联的打开文件的偏移量重新定位为参数偏移量,如下所示:
SEEK_SET:
偏移量设置为偏移字节。
SEEK_CUR:
偏移量设置为其当前位置加上偏移字节。
SEEK_END:
偏移量设置为文件大小加上偏移字节。
RETURN VALUE
成功完成后,lseek() 将返回从文件开头开始以字节为单位测量的结果偏移位置(可用于计算文件大小)。 出错时,返回值 (off_t) -1,并设置 errno 以指示错误。
#include
#include
#include
#include
#include
#include
#include
int main()
{
int fd;
char *buf = "Hello world!";
fd = open("./file1",O_RDWR);
if(fd = -1){
printf("open file failed!\n");
fd = open("./file1",O_RDWR|O_CREAT,0600);
if(fd>0){
printf("creat file1 success\n");
c }
}
printf("open success:fd = %d\n",fd);
// ssize_t write(int fd, const void *buf, size_t count);
int n_write = write(fd,buf,strlen(buf));
//计算缓冲区大小时不能用sizeof(),要用strlen()a。
if(n_write != -1){
printf("write %d byte to file1\n",n_write);
}
/* 读文件前一定要先解决光标问题,因为在写文件时光标会移动到文件末尾,如果不将光标移动到文件首部,读取到的文件将是空。
方法一:重新关闭打开文件,再读取文件。(很low!!!)
方法二:将光标移动到文件头部。
*/
/* 方法一如下:
close(fd);
fd = open("./file1",O_RDWR);
*/
// 方法二如下:
lseek(fd,0,SEEK_SET);
char *readBuf;
readBuf = (char *)malloc(sizeof(char)*n_write+1);
int n_read = read(fd,readBuf,n_write);
printf("read %d byte,context:%s\n",n_read,readBuf);
close(fd);
return 0;
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)