1.两个进程中分别产生生成两个独立的fd
2.两个进程可以任意对文件进行读写操作,操作系统并不保证写的原子性
3.进程可以通过系统调用对文件加锁,从而实现对文件内容的保护
4.
任何一个进程删除该文件时,另外一个进程不会立即出现读写失败
5.两个进程可以分别读取文件的不同部分而不会相互影响
6.一个进程对文件长度和内容的修改另外一个进程可以立即感知
二:文件描述符与打开文件的关系?
内核中,对应于每个进程都有一个文件描述符表,表示这个进程打开的所有文件。文件描述表中每一项都是一个指针,指向一个用 于描述打开的文件的数据块———file对象,file对象中描述了文件的打开模式,读写位置等重要信息,当进程打开一个文件时,内核就会创建一个新的file对象。需要注意的是,file对象不是专属于某个进程的,不同进程的文件描述符表中的指针可以指向相同的file对象,从而共享这个打开的文件。file对象有引用计数,记录了引用这个对象的文件描述符个数,只有当引用计数为0时,内核才销毁file对象,因此某个进程关闭文件,不影响与之共享同一个file对象的进程。
Linux下两个进程可以同时打开同一个文件吗?返回的文件描述符一样吗?一:结论1.两个进程中分别产生生成两个独立的fd2.两个进程可以任意对文件进行读写操作,操作系统并不保证写的原子性3.进程可以通过系统调用对文件加锁,从而实现对文件内容的保护4.任何一个进程删除该文件时,另外一个进程不会立即出现读写失败5.两个进程可以分别读取文件的不同部分而不会相互影响6.一...
LOCK_SH 建立共享锁定。多个
进程
可同时对
同一个
文件
作共享锁定。
LOCK_EX 建立互斥锁定。
一个
文件
同时只有
一个
互斥锁定。
LOCK_UN 解除
文件
锁定状态。
LOCK_NB 无法建立锁定时,此操作可不被阻断,马上
返回
进程
。通常与LOCK_SH或LOCK_EX 做OR(|)组合。
单一
文件
无法同时建立共享锁定和互斥锁定,而当使用dup()或fork
在
Linux
内核中主要有
两个
函数涉及到
文件描述符
的分配:get_unused_fd和locate_fd。本文主要讲解get_unused_fd,将会在下一篇文章中介绍locate_fd。首先给出get_unused_fd的定义(fs/open.c):
int get_unused_fd(void)
struct files_struct * files = current->files;//获得当前
进程
的
打开
文件
列表files
int fd, error;
struct fdtable *fdt;
error = -EMFILE;
spin_lock(&fil
文件描述符
(File Descriptor)和系统调用号(System Call)是
两个
不同的概念,用于在操作系统中进行
文件
操作和系统调用。
1.
文件描述符
(File Descriptor):
文件描述符
是
一个
非负整数,用于标识
打开
的
文件
或其他输入/输出资源。在大多数操作系统中,
文件描述符
的值从0开始,表示标准输入(stdin);1表示标准输出(stdout);2表示标准错误(stderr)。其他
文件描述符
的值可以通过
打开
文件
或创建网络连接等操作获得。
文件描述符
在进行
文件
操作时非常重要。例如,可以使用
文件描述符
来读取或写入
文件
数据,关闭
文件
等。
2. 系统调用号(System Call Number):
系统调用是操作系统提供给应用程序的接口,用于执行各种操作,如
文件
操作、
进程
管理、网络通信等。每个系统调用都有
一个
唯一的系统调用号,用于标识要执行的操作。
操作系统会为每个系统调用分配
一个
特定的系统调用号,应用程序可以使用该号码来请求相应的操作。例如,在
Linux
中,读取
文件
的系统调用是read,它的系统调用号是0;写入
文件
的系统调用是write,它的系统调用号是1。
需要注意的是,
文件描述符
和系统调用号是
两个
不同的概念。
文件描述符
用于标识
打开
的
文件
或其他资源,而系统调用号用于标识要执行的操作。在进行
文件
操作时,应用程序通常会使用
文件描述符
作为参数传递给相应的系统调用,以便进行读写、关闭等操作。