文件句柄备忘

简介: 句柄是什么? Handle本身是一个32位的无符号整数,它用来代表一个内核对象。它并不指向实际的内核对象。 句柄不是指针,但利用句柄能够得到一段内存地址, 句柄的设计目标是防止用户随意修改内核中文件,因此用户模式下的程序永远不可能获得一个内核对象的实际地址(一般情况下)。 那么Handle的意义何在? 它实际上是作为一个索引在一个表中查找对应的内核对象的实际地址。 那么这个表在

句柄是什么?

Handle本身是一个32位的无符号整数,它用来代表一个内核对象。它并不指向实际的内核对象。
句柄不是指针,但利用句柄能够得到一段内存地址,
句柄的设计目标是防止用户随意修改内核中文件,因此用户模式下的程序永远不可能获得一个内核对象的实际地址(一般情况下)。

那么Handle的意义何在?
它实际上是作为一个索引在一个表中查找对应的内核对象的实际地址。

那么这个表在哪里呢?
每个进程都有这样的一个表,叫句柄表。
该表的第一项就是进程自己的句柄,这也是为什么你调用GetCurrentProcess()总是返回0x7FFFFFFF原因。

简单地说,Handle就是一种用来"间接"代表一个内核对象的整数值。你可以在程序中使用handle来代表你想要操作的内核对象。这里的内核对象包括:事件(Event)、线程、进程、Mutex等等。我们最常见的就是文件句柄(file handle)。

 

linux 中通常默认都只能够同时打开 1024 个文件。

通常 linux 系统中文件打开的设定分成系统级别设定及用户级别设定
常见的文件限制令系统产生下面错误
 Socket/File: Can‘t open so many files

系统级别定义方法
 /etc/sysctl.conf 或 /proc/sys/fs/file-max

用户级别定义方法
 /etc/security/limits.conf 或 ulimit 命令

 


查询进程打开文件的方法, 以当前 ssh 链接到服务器的终端作为例子, 先查询到进程号

ps aux | grep pts/0 | grep ssh | grep -v grep | awk '{print $2}'
1859

利用 lsof 查询当前进程打开的文件数量 
lsof -p 1859  | wc -l (直接查询当前进程)
59

lsof -n | grep 1859 | wc -l  (查询整个系统中打开的文件再执行过滤)
58


查询某个文件被什么进程使用中的方法

lsof -f -- /lib/security/pam_keyinit.so
COMMAND  PID USER  FD   TYPE DEVICE SIZE/OFF   NODE NAME
login   1019 root mem    REG    8,1     5740 133255 /lib/security/pam_keyinit.so
sshd    1859 root mem    REG    8,1     5740 133255 /lib/security/pam_keyinit.so
sshd    4468 root mem    REG    8,1     5740 133255 /lib/security/pam_keyinit.so


查询分区打开文件方法
[root@station11 proc]# lsof +f -- /dev/sda1 | head -5
COMMAND    PID      USER   FD   TYPE DEVICE SIZE/OFF   NODE NAME
init         1      root  cwd    DIR    8,1     4096      2 /
init         1      root  rtd    DIR    8,1     4096      2 /
init         1      root  txt    REG    8,1   145180 139646 /sbin/init
init         1      root  mem    REG    8,1   122232 162307 /lib/libgcc_s-4.4.5-20110214.so.1

目录
相关文章
|
7月前
|
数据可视化 Linux
Linux常用命令太多,按这6种方法,帮助你有效掌握命令
Linux常用命令太多,按这6种方法,帮助你有效掌握命令
|
4月前
|
存储 API Windows
8.3 Windows驱动开发:内核遍历文件或目录
在笔者前一篇文章`《内核文件读写系列函数》`简单的介绍了内核中如何对文件进行基本的读写操作,本章我们将实现内核下遍历文件或目录这一功能,该功能的实现需要依赖于`ZwQueryDirectoryFile`这个内核API函数来实现,该函数可返回给定文件句柄指定的目录中文件的各种信息,此类信息会保存在`PFILE_BOTH_DIR_INFORMATION`结构下,通过遍历该目录即可获取到文件的详细参数,如下将具体分析并实现遍历目录功能。
43 0
8.3 Windows驱动开发:内核遍历文件或目录
|
6月前
|
存储 UED Windows
Windows操作系统磁盘碎片整理程序的作用
Windows操作系统磁盘碎片整理程序的作用
164 0
|
7月前
|
C++
40.【C++最全文件操作,少一个你打我】(一)
40.【C++最全文件操作,少一个你打我】
57 0
|
7月前
|
C++
40.【C++最全文件操作,少一个你打我】(二)
40.【C++最全文件操作,少一个你打我】
25 0
|
存储 缓存 编译器
细谈文件操作
在写代码的时候,数据都是放在内存中的,而程序一关闭,数据就没有了,这就让人很难受,我们想把数据存下来,这就涉及到要将数据持久化,而一般让数据持久化的方法有,把数据存放在磁盘文件,存放到数据库等方式。
43 0
|
存储 安全 Unix
Linux基本命令-02(文件操作)
Linux基本命令-02(文件操作)
Delphi文件操作【1】- 记录文件
Delphi文件操作【1】- 记录文件
Delphi文件操作【1】- 记录文件
|
Linux
Linux系统中利用open函数多次打开同一个文件操作方法
大家好。 今天的话主要和大家聊一聊,在Linux系统中如果一个文件被打开多次会出现什么情况。
535 0
Linux系统中利用open函数多次打开同一个文件操作方法
C#编程-111:文件操作之获取基本信息
C#编程-111:文件操作之获取基本信息
C#编程-111:文件操作之获取基本信息