展开

关键词

Linux编程--文件操作

2 标准错误 STDERR_FILENO stderr 基础系统调用 int Open(pathname,flags,mode):打开文件 说明: 打开pathname所对应的文件路径,返回该文件文件描述符 如果在flags中存在O_CREAT标志位,则当文件不存在时,会创建文件,并且根据mode参数来决定该文件的访问权限 参数: pathname:文件路径 flags:打开方式的掩码 mode:创建文件时的访问权限 O_WRONLY 以只写方式打开文件 此三种读写类型只能有一种 O_RDWR 以读和写的方式打开文件 此三种读写类型只能有一种 O_CREAT 打开文件,如果文件不存在则创建文件 创建文件时会使用Mode RD,WR,RDWR,只要打开就会把文件清空 O_APPEND 强制write()从文件尾开始不care当前文件偏移量所处位置,只会在文件末尾开始添加 如果不使用的话,只会在文件偏移量处开始覆盖原有内容写文件 进程与文件表、i-node表的关系 上图画出了fd与对应的文件i-node之间的关系 多进程中的文件描述符可能指向同一个文件 同进程中的不同文件描述符可能指向同一个文件 多个不同偏移量的文件指针可能指向同一个文件

35220

Linux编程--文件原子操作

当多个进程同时访问一个文件的时候,普通的write/read在执行的时候,无法保证操作的原子性,可能会导致文件被污染,达不到预期的结果。 PS: pread是无法中断的原子操作,无法中断它的定位和读取操作 pread读取过后的文件偏移量不会发生改变 同理pwrite也是一样的 而在文件创建的时候也是一样的,当需要做文件创建同步的时候, int dup2(int filedes,int filedes2): 传入文件描述符,以及新的文件描述符,如果新的文件描述符所指向的文件已经打开,则会强行将其关闭后,将该文件描述符指向到已存在的文件描述符 如果filedes和filedes2指向同一个文件,则不做任何处理,直接返回filedes2,不会关闭文件 新返回回来的filedes2会共享filedes的文件状态标识,文件偏移量等等信息。 因为它们的文件指针会指向文件表的同一个位置。只是fd不一样而已。

76730
  • 广告
    关闭

    腾讯云服务器买赠活动

    腾讯云服务器买赠活动,低至72元1年,买就送,最长续3个月,买2核送4核、买4核送8核

  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Linux编程文件描述符)

    Linux编程世界中,不可能没听过文件描述符这个概念,我们操纵任何设备的时候,几乎都要通过它来达成的,它究竟是何方神圣呢?随我描述符科学家来一探究竟。 首先,我们在Linux下打开文件用的都是如下代码: int fd = open(... ...); 当然有同学可能会说,有时也可以用fopen(),但是fopen()只是标准IO对系统IO的封装,归根结底还是使用 open()来打开一个文件。 很多人就想当然地以为打开嘛,就跟在windows下双击一个文件,或者双击一个文件夹一样,就是一个动作而已,其实不然,常说的打开一个文件实际上最重要的是获取这个文件的描述符,描述符是用来表征这个文件的代表物 内核空间中有一堆数据结构表达一个文件的属性信息,但是用户空间看不见,只看见一个代表了这些信息的整数i,通常我们称之为文件描述符,对文件的读写和ioctl操作都是通过这个东东来达到的呢!

    61720

    Linux下的文件IO编程

    Linux 中,用户程序不能直接访问内核提供的服务,必须通过系统调用来使用内核提供的服务。 Linux 中的用户编程接口(API)遵循了 UNIX 中最流行的应用编程界面标准—— POSIX。这些系统调用编程接口主要是通过 C 库(libc)实现的。 往期传送门: 史上最全的Linux常用命令汇总(超详细! 超全面)收藏这一篇就够了 Linux下标准IO的这些操作你清楚吗(内附有详细的介绍和例程) 文章目录 文件I/O简介 文件描述符 文件I/O与标准I/O区别 打开文件(open) 关闭文件(close 文件描述符是一个非负整数,Linux为程序中每个打开的文件分配一个文件描述符 文件描述符从0开始分配,依次递增 文件IO操作通过文件描述符完成 注意:每个程序中打开的文件系统会单独分配文件描述符,互相不影响

    6310

    Linux编程之删除文件时排除某个文件

    文章目录 导读 实验 C语言Linux编程实现 导读 有时候我们在Linux下删除某个文件夹内的所有文件时需要排除一些文件。 和 test/config/setting.ini这些配置文件,都有不同的作用。 假设我们需要保留test/c.txt和test/config/setting.ini这两个配置文件中的配置信息。 如果需要排除我们不想要的数据的话,Linux也提供了一个egrep命令; # 查看所有的文件 [root@TrueDei test]# ls ./* ./a.txt ./b.txt . /config: setting.ini [root@TrueDei test]# C语言Linux编程实现 通过C语言提供的system函数可以使用shell命令进行操作。

    26330

    Linux内核编程--文件描述符

    Linux操作系统中,一切皆是文件—— "Everything is a file"。 如果要在Linux系统中编写操作文件的代码,需要借助文件描述符。 文件的索引——文件描述符(file descriptor): 文件描述符是一个非负整数,当程序打开一个现有文件或者创建一个新文件时,内核向进程返回一个文件描述符。 文件描述符就是内核为了高效管理已被打开的文件所创建的索引值。 文件描述符指向内核为每一个进程维护的打开文件记录表。当要处理文件时,将文件对应的文件描述符作为参数传给函数。 文件描述符在用户进程和内核之间的映射关系: Linux中查看文件描述符的指令:lsof(list open files) lsof可以打开的文件: 普通文件 目录 网络文件系统的文件 字符或设备文件 i --列出所有的网络连接 lsof -i tcp --列出所有tcp 网络连接信息 *Linux中出现“ Too many open files”报错,如何解决:

    10810

    温故Linux后端编程(一):文件IO

    文章目录 Linux下的文件 文件描述符 文件I/O操作 打开/创建文件 关闭文件 读取/写入文件 文件指针偏移 测试代码示例 ---- Linux下的文件 引用一句经典的话:“UNIX下一切皆文件 文件是一种抽象机制,它提供了一种方式用来存储信息以及在后面进行读取。 在创建一个文件后,它会给文件一个命名。当进程终止时,文件会继续存在,并且其他进程可以使用名称访问该文件文件描述符 在Linux下用文件描述符来表示普通文件和设备文件文件描述符是一个整型的数据,所有对文件的操作都通过文件描述符完成。 在Linux系统中有三个已经被分配的文件描述符,分别是: 0 STDIN_FILENO 标准输入流 1 STDOUT_FILENO 标准输出流 2 STDERR_FILENO 标准错误流 这三个文件描述符和它们各自的功能是绑死的 ---- 文件I/O操作 打开/创建文件Linux下,用open函数可以用来打开或创建一个文件: #include <sys/types.h> #include <sys/stat.h> #include

    14020

    Linux内核编程--常见的文件操作

    fd2); /*把一个文件的旧描述符复制到一个新描述符上*/ 函数执行后,返回的新文件描述符与原有的旧文件描述符共用同一个文件表项,但是文件描述符标志将被清除,进程调用exec时文件描述符将不会被关闭 linux系统中的”快捷方式“被称为软链接。 include \n in FORMAT -t, --terse print the information in terse form 命令执行样例: 3.权限屏蔽字函数umask 在Linux 文件权限在Linux中的表示: [root@VM-4-13-centos cpp_learning]# ls -l hello.txt -rw-r--r-- 1 root root 12 Apr 13 ; } umask(oldmask); } 运行结果: Your old umask is 36 -rwx------ 1 root root 0 Apr 13 10:24 test.txt Linux

    10940

    linux下的文件io编程实现文件的拷贝

    include <stdio.h> #define BUFFER_SIZE 1024 /* 每次读写缓存大小,影响运行效率*/ #define SRC_FILE_NAME "src_file" /* 源文件名 */ #define DEST_FILE_NAME "dest_file" /* 目标文件文件名 */ #define OFFSET 10240 /* 拷贝的数据大小 */ int main () { int src_file, dest_file; unsigned char buff[BUFFER_SIZE]; int real_read_len; /* 以只读方式打开源文件 */ src_file = open(SRC_FILE_NAME, O_RDONLY); /* 以只写方式打开目标文件,若此文件不存在则创建, 访问权限值为644 */ dest_file 10KB的起始位置*/ lseek(src_file, -OFFSET, SEEK_END); /* 读取源文件的最后10KB数据并写到目标文件中,每次读写1KB */ while ((real_read_len

    7630

    Linux编程--解决头文件`redefine of struct xxx`

    问题 在写头文件的时候,将结构体定义在头文件中 #include <linux/elf.h> #include <stdint.h> ... struct ELF_FILE { ELF_Addr included multiple times, additional include site here redefinition of 'ELF_FILE' 但是在检查后发现,并没有出现include多次头文件 ,也只有这一个定义ELF_FILE结构体的地方 原因 在使用#include <xxx.h>的时候,编译器会在预处理阶段,将头文件以及定义的宏铺开在所使用的C文件中。 如果没有使用条件编译的话,如果出现重复引用,以及循环递归使用include的时候,就会在对应的C文件中展开重复定义的代码。 解决办法 加入条件编译,在头文件的头和尾加上条件编译即可 #ifndef SOTEST_ELF_HOOK_H #define SOTEST_ELF_TYPE_DEF_H #include <linux

    82720

    Linux网络编程之使用TCP传输文件

    原创作品,转载时请务必以超链接形式标明文章原始出处:http://blog.csdn.net/gqb666/article/details/8976263,作者:gqb666 最近在写Linux网络方面的 demo,用TCP实现了一个简单的传输文件程序,适用于网卡设备及TCP/IP协议栈及网络环境测试时使用。 /server <端口号> <保存为文件名> 其中,server端先运行,client端与server端的端口号必须一致并且不能与已知端口冲突(例如8888即可) 下面将代码贴上:(使用UDP传输文件请参阅博文 Linux网络编程之使用UDP传输文件) server端代码:server.c [cpp] view plaincopy #include <stdio.h> #include <string.h 网络编程之使用UDP传输文件

    1.1K10

    linux系统编程文件与IO(四):文件的属性

    一、读取文件元数据 int stat(const char *path, struct stat *buf); int fstat(int fd, struct stat *buf); int lstat mode_t    st_mode;    /* protection */ nlink_t   st_nlink;   /* number of hard links */     硬链接是不可以跨越文件系统的 , sbuf.st_mode & 0777, perm);  // 0777 是八进制数     return 0; } 测试如下: simba@ubuntu:~/Documents/code/linux_programming major 8, minor 1 File inode:660022 Filetype:regular file File permission bits=664 -rw-rw-r-- 因为是普通文件 比如在同一个磁盘上面不同的文件系统,设备驱动程序相当,但是次设备号不同。 st_rdev只有字符特殊文件和块特殊文件才有这个值,表示实际设备的设备编号。

    418100

    Linux内核编程--文件流与缓冲区

    Linux系统下,通过编程文件进行操作的方式有两种机制:文件描述符和文件流 1.文件描述符和文件流的区别: 文件描述符的类型为int,文件流的类型为FILE*(文件指针)。 文件描述符的操作更底层,文件流的操作更高级且更丰富。 文件流是基于文件描述符来实现的,所以可以从文件流中提取并操作文件描述符,比如“int fileno(FILE*); fileno(file_stream)”。 character read failed wide orientation narrow character read failed wide character read 'a' 3.缓冲区大小设置 Linux 运行结果: file point position is : 32 B[0] == 4.0 file point position is : 40 B[0] == 5.0 参考教程: 《UNIX环境高级编程

    16410

    linux系统编程文件与IO(二):文件的读取写入

    一、read系统调用 一旦有了与一个打开文件描述相关连的文件描述符,只要该文件是用O_RDONLY或O_RDWR标志打开的,就可以用read()系统调用从该文件中读取字节  函数原型: ssize_t read(int fd, void *buf, size_t count); 参数: fd :想要读的文件文件描述符 buf : 指向内存块的指针,从文件中读取来的字节放到这个内存块中 count : 从该文件复制到buf中的字节个数 返回值: 如果出现错误,返回-1;读文件结束,返回0;否则返回从该文件复制到规定的缓冲区中的字节数 二、write系统调用 用write()系统调用将数据写到一个文件中 四、文件的随机读写 到目前为止的所有文件访问都是顺序访问。这是因为所有的读和写都从当前文件的偏移位置开始,然后文件偏移值自动地增加到刚好超出读或写结束时的位置,使它为下一次访问作好准备。 有个文件偏移这样的机制,在Linux系统中,随机访问就变得很简单,你所需做的只是将当前文件偏移值改变到有关的位置,它将迫使下一次read()或write()发生在这一位置。

    75760

    linux系统编程文件与IO(六):fcntl 函数与文件

    (long) 获取/设置文件锁 F_GETLK F_SETLK,F_SETLKW 其中复制文件描述符可参见《linux系统编程文件与I/O(五):打开文件的内核结构file和重定向》,文件描述符的标志只有一个即 F_SETFL: On Linux  this  command can change only the O_APPEND, O_ASYNC, O_DIRECT, O_NOATIME, and O_NONBLOCK F_SETFL, val) < 0)         ERR_EXIT("fcntl set flag error"); } 测试输出: simba@ubuntu:~/Documents/code/linux_programming } 测试如下: 我们先在一个 终端执行程序: simba@ubuntu:~/Documents/code/linux_programming/APUE/File_IO$ . : simba@ubuntu:~/Documents/code/linux_programming/APUE/File_IO$ .

    76150

    linux系统编程文件与IO(一):文件的打开关闭

    一、文件描述符 对于Linux而言,所有对设备或文件的操作都是通过文件描述符进行的。当打开或者创建一个文件的时候,内核向进程返回一个文件描述符(非负整数)。 后续对文件的操作只需通过该文件描述符,内核记录有关这个打开文件的信息(file结构体)。 (绝对和相对)路径 flags:文件打开模式 mode:  用来规定对该文件的所有者,文件的用户组及系 统中其他用户的访问权限 返回值: 打开成功,返回文件描述符;打开失败,返回-1 打开文件的方式 : O_RDONLY 打开一个供读取的文件 O_WRONLY 打开一个供写入的文件 O_RDWR 打开一个可供读写的文件 O_APPEND 写入的所有数据将被追加到文件的末尾 O_CREAT 打开文件 需要说明的是,在linux系统编程中使用的一些系统调用函数一般如果失败返回-1且会置全局变量errno为特定的错误码,可以使用perror打印,或者通过strerror(errno)打印错误提示。

    61790

    Linux进程编程

    Linux进程编程 3.1 fork系统调用 3.1.1 fork工作原理 3.1.2 fork函数 3.1.3 fork编程示例 3.1.4 小结 3.2 exec系统调用 3.2.1 exec函数族作用 子进程表项的内容来自父进程,fork会将父进程的表项复制为副本,并分配给子进程; Linux内核使父进程的文件表和索引表的节点自增1,创建用户及上下文; 将父进程上下文复制到子进程上下文空间中; fork 3.1.3 fork编程示例 打开Ubuntu终端,切换用户到root,新建一个process文件夹用于存放实验文件,进入该目录下,输入sudo vi forkProcess.c使用vi文本编辑器编辑forkProcess.c 文件; 按下i键进入编辑模式,输入fork编程示例,该示例创建一个子进程,通过fork()函数返回值判断进程是子进程还是父进程,并打印信息。 这里的可执行文件既可以是二进制文件,也可以是任何Linux下可执行的脚本文件

    6720

    Linux环境编程

    一般使用下列方法之一种将 SHMMAX 参数设为 2GB : 通过直接更改 /proc 文件系统,你不需重新启动机器就可以改变 SHMMAX 的默认设置。 我使用的方法是将以下命令放入 />etc/rc.local 启动文件中: # echo "2147483648" > /proc/sys/kernel/shmmax 您还可以使用 sysctl 命令来更改 SHMMAX 的值: # sysctl -w kernel.shmmax=2147483648 最后,通过将该内核参数插入到 /etc/sysctl.conf 启动文件中,您可以使这种更改永久有效 SIGRTMAX-4 61) SIGRTMAX-3 62) SIGRTMAX-2 63) SIGRTMAX-1 64) SIGRTMAX  5.套接字:socket,上面介绍的通讯手段限制了作用域,套接字编程应用则更为广泛 《unix网络编程卷一》对socket编程有详细的介绍。

    4830

    Linux文件文件

    对于文件的操作而言,“锁定”操作是对文件(尤其是对共享文件)的一种高级的文件操作。 当某进程在更新文件内数据时,期望某种机制能防止多个进程同时更新文件从而导致数据丢失,或者防止文件内容在未更新完毕时被读取并引发后续问题,这种机制就是“文件锁”。 在Linux系统中,通常采用“文件锁”的方式,当某个进程独占资源的时候,该资源被锁定,其他进程无法访问,这样就解决了共享资源的竞争问题。 文件锁包括建议性锁(又名“协同锁”)和强制性锁两种。 建议性锁要求每个相关进程访问文件的时候检查是否已经有锁存在并尊重当前的锁。一般情况下不建议使用建议性锁,因为无法保证每个进程都能自动检测是否有锁,Linux内核与系统总体上都坚持不使用建议性锁。 在Linux内核提供的系统调用中,实现文件上锁的函数有lockf()和fcntl(),其中lockf()用于对文件加建议性锁,这里不再讲解。fcntl()函数既可以加建议性锁,也可以加强制性锁。

    8320

    相关产品

    • 文件存储

      文件存储

      文件存储(Cloud File Storage,CFS)为您提供安全可靠、可扩展的共享文件存储服务。CFS 可与腾讯云服务器、容器服务、批量计算等服务搭配使用,为多个计算节点提供容量和性能可弹性扩展的高性能共享存储。腾讯云 CFS 的管理界面简单、易使用,可实现对现有应用的无缝集;按实际用量付费,为您节约成本,简化 IT 运维工作。

    相关资讯

    热门标签

    活动推荐

    扫码关注腾讯云开发者

    领取腾讯云代金券