以open为例,在linux下使用man 2 open /man open 可得到open的头文件与函数的用法。(其他相同)
open的返回值是整型,错误返回-1,所以在返回值判断的时候可以用-1来判断是否出错(相同)
一下是open的两种函数用法
int open(const char *pathname, int flags);
int open(const char *pathname, int flags, mode_t mode);
*pathname是路径(要给文件命名), flags是标志位(可读或者可写),可以再man中查询到。mode,是属性(使用者,或者作者有权利访问或者组内成员使用)
int fd = open("hello.txt", O_RDWR); //以读写的方式打开文件
if (-1 == fd)//返回-1表示出错,出错原因在errno里面
{
printf("%d\n", errno);
perror("open");//打印错误信息
exit(1);//退出程序
}
fd = open("hello.c", O_RDWR | O_CREAT, 00400 | 00200); //创建文件,并以读写方式打开文件 。使用者有权利读或者写。
if (-1 == fd)
{
perror("open1");
exit(2);
}
write 和read返回类型相同,使用方法也相似。用法简单,可以通关man手册查询。
ssize_t write(int fd, const void *buf, size_t count);
ssize_t read(int fd, void *buf, size_t count);
举例:
ssize_t ret = write(fd, s, strlen(s));
if (-1 == ret)
{
perror("write");
exit(3);
}
ssize_t ret = read(fd, s, strlen(s));
if (-1 == ret)
{
perror("write");
exit(3);
}
简单的copy实例
#include <stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <stdlib.h>
#include <string.h>
int main(int argc, char *argv[])
{
if (argc != 3)
{
printf("error\n");
exit(1);
}
int fd_from = open(argv[1], O_RDONLY);
if (-1 == fd_from)
{
perror("open2");
exit(2);
}
int fd_to = open(argv[2], O_WRONLY | O_CREAT, 00700);
if (-1 == fd_to)
{
perror("open3");
exit(3);
}
char buf[128] = {0};
ssize_t ret;
while(1)
{
ret = read(fd_from, buf, sizeof(buf) - 1);
if (-1 == ret)
{
perror("read");
}
else if (0 == ret)
{
printf("copy competely\n");
break;
}
ret = write(fd_to, buf, ret);
if (-1 == ret)
{
perror("write");
}
}
close(fd_from);
close(fd_to);
return 0;
}
注意:文件的方法肯定先打开,否则无法读写。然后进行读写操作,最后关闭。在你读写的操作时,文件中有一个指针的位置,类似于windows下的光标。lseek函数用于操纵光标指向。不操纵指针的位置容易读写操作的结果为空
lseek(fd, 0, SEEK_SET); //置于开头
lseek(fd,0, SEEK_END);//置于结尾