linux文件编程

一、系统调用
所谓系统调用是指操作系统提供给用户的一组“特殊”接口,用户程序可以通过这组“特殊”接口来获得操作系统内核提供的的服务。
由于在Linux中,为了更好地保护内核空间,将程序的运行空间分为内核空间和用户空间(也就是常称的内核态和用户态),它们分别运行在不同的级别上,在逻辑上是相互隔离的。
因此,用户进程在通常情况下不允许访问内核数据,也无法使用内核函数,它们只能在用户空间操作用户数据,调用用户空间的函数。
二、用户编程接口(API)
系统调用并不是直接与程序员进行交互的,它仅仅是一个通过软中断机制向内核提交请求,以获取内核服务的接口。在实际使用中程序员调用的通常是用户编程接口—API。
系统命令相对API更高了一层,它实际上一个可执行程序,它的内部引用了用户编程接口(API)来实现相应的功能。
三、Linux 文件
Linux一点哲学,“一切皆为文件”;在Linux中对目录和设备的操作都等同于对文件的操作,都是使用文件描述符来进行的。
Linux文件可分为:普通文件,目录文件,链接文件,设备文件。
四、文件及文件描述符
当打开一个现存文件或创建一个新文件时,内核就向进程返回一个文件描述符;当需要读写文件时,也需要把文件描述符作为参数传递给相应的函数。
文件描述符是一个非负的整数,它是一个索引值,并指向在内核中每个进程打开文件的记录表。
一个进程启动时,都会打开3个文件:标准输入、标准输出和标准出错处理。
标准输入的文件描述符:0
标准输出的文件描述符:1
标准出错的文件描述符:2
五、不带缓存的(系统调用)-文件访问
1.creat(不常用)
int creat(const char *filename, mode_t mode )

filename :创建的文件名(包含路径,缺省为当前路径)
mode:创建模式
常创建模式:S_IRUSR(可读)、S_IWUSR(可写)、S_IXUSR(可执行)、S_IXRWU(可读、可写、可执行) 除用以上宏来选择创建模式,也可以用数字来表示。

#include<stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include<stdlib.h>

int main()
{
    int ret;
    ret = creat("hello.txt",00700 | 00400);
    if(ret == -1)
    {
        perror("creat");
    }
        exit(1);

    return 0;
}

2.open
open可用来打开文件或者创建文件
int open(const char *pathname, int flags);
int open(const char *pathname,int flags, mode_t mode);

pathname:文件名(路径)
flags:打开的方式(只读、只写、读写)
mode:创建时定义的用户权限
返回值:成功返回新分配的文件描述符,
出错返回-1并设置errno
操作完成后close ,int close(int fd)

#include <stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <stdlib.h>

int main()
{
    int fd, ret;

    fd = open("hello.txt", O_RDWR | O_CREAT | O_EXCL, S_IRWXU);
    if(-1 == fd)
    {
        perror("open");
        exit(1);
    }

    close(fd);
    return 0;
}

3.read
int read(int fd, const void *buf, size_t length)
功能:
从文件描述符fd所指定的文件中读取length个字节到buf所指向的缓冲区中,返回值为实际读取的字节数。

#include <stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <stdlib.h>
#include <errno.h>
#include <string.h>
#include <unistd.h>

int main()
{
    int fd, ret;
    char buf[100] = {0};
    fd = open("hello.txt", O_RDWR | O_CREAT, S_IRWXU);
    if(-1 == fd)
    {
        perror("open");
        exit(1);
    }

    ret = read(fd, buf, sizeof(buf));
    if(-1 == ret)
    {
         perror("read");
         exit(1);
    }
    printf("Read is :%s\n", buf); 

    close(fd);
    return 0;
}

4.write
int write(int fd, const void * buf, size_t length)
功能:
把length个字节从buf指向的缓冲区中写到文件描述符fd所指向的文件中,返回值为实际写入的字节数。

#include <stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <stdlib.h>
#include <errno.h>
#include <string.h>
#include <unistd.h>

int main()
{
    int fd, ret;
    char buf[100] = "hello world!";

    fd = open("hello.txt", O_RDWR | O_CREAT, S_IRWXU);
    if(-1 == fd)
    {
        perror("open");
        exit(1);
    }

    ret = write(fd, buf, sizeof("hello world!"));
    if(-1 == ret)
    {
        perror("write");
        exit(1);
    }

    close(fd);
    return 0;
}

5.lseek(定位)
int lseek(int fd, offset_t offset, int whence)
功能:
将文件读写指针相对whence移动offset个字节。操作成功时,返回文件指针相对于文件头的位置。
SEEK_SET:相对文件开头
SEEK_CUR:相对文件读写指针的当前位置
SEEK_END:相对文件末尾

六、带缓存的(库函数)- 文件访问
在linux系统下带缓存和不带缓存的都可使用,当处理数据较多时,使用带缓存的比较方便。
标准I/O提供缓存的目的就是减少调用read和write的次数,它对每个I/O流自动进行缓存管理(标准I/O函数通常调用malloc来分配存)。
2) 行缓存。当输入输出遇到新行符或缓存满时,才由标准I/O库执行实际I/O操作。stdin、stdout通常是行缓存的。 (如printf就是一个行缓存,遇到换行(\n)才会刷新缓存)。
3) 无缓存。相当于read、write了。stderr通常是无缓存的,因为它必须尽快输出。
1.fopen
FILE *fopen(const char *filename, const char *mode)
filename:打开的文件名(包含路径,缺省为当前路径)
r:只读 w:只写
int fclose(FILE * stream);

#include<stdio.h>
#include<stdlib.h>

int main()
{
    FILE *fp;

    fp=fopen("hello.txt","w");
    if(NULL==fp)
    {
        perror("fopen");
        exit(1);
    }

    fp=fopen("hello.txt","r+");
    if(NULL==fp)
    {
        perror("fopen");
        exit(1);
    }

    fclose(fp);

    return 0;
}

2.fread
size_t fread(void * ptr,size_t size,size_t nmemb, FILE * stream)
函数说明: fread()用来从文件流中读取数据。
参数:stream为已打开的文件指针,
ptr: 指向欲存放读取进来的数据空间,读取的字符数以参数size*nmemb来决定。
返回值:返回实际读取到的nmemb数目。

#include<stdio.h>
#include<stdlib.h>

int main()
{
    FILE *fp;
    char buf[100]={0};
    size_t ret;

    fp=fopen("hello.txt","r");
    if(NULL==fp)
    {
        perror("fopen");
        exit(1);
    }

    ret=fread(buf,1,sizeof(buf),fp);
    if(0==ret)
    {
        perror("fread");
        exit(1);
    }
    printf("Read From Txt:%s\n",buf);


    return 0;
}

3.fwrite
size_t fwrite(const void * ptr, size_t size, size_t nmemb, FILE * stream)
函数说明:fwrite()用来将数据写入文件流中。
参数:stream:为已打开的文件指针,
ptr: 指向欲写入的数据地址,总共写入的字符数以参数size*nmemb来决定。
返回值:返回实际写入的nmemb数目。

#include<stdio.h>
#include<stdlib.h>
#include<string.h>

int main()
{
    FILE *fp;
    char buf[100]={0};
    size_t ret;
    scanf("%s",buf);

    fp=fopen("hello.txt","w");
    if(NULL==fp)
    {
        perror("fopen");
        exit(1);
    }

    ret=fwrite(buf,strlen(buf),1,fp);
    if(0==ret)
    {
        perror("fwrite");
        exit(1);
    }


    return 0;
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值