【Linux进阶命令 04】lsof (看看是谁动了我的文件?)
文章目录
- 一、简介
- 二、lsof语法
- 2.1 基本格式
- 2.2 选项
- 2.3 输出字段解释
- 三、常用 lsof 操作
- 3.1 查看某文件的相关进程
- 3.2 网络相关:-i
- 3.3 指定进程号打开的文件:-p
- 3.4 指定用户打开的文件:-u
- 3.5 某进程打开的文件:-c
- 3.6 复合查询
- 四、进阶用法
- 4.1用文本处理命令(grep\awk\sed)结合使用
- 4.2 更多实用选项
一、简介
lsof(list open files
)是一个列出当前系统打开文件的工具。
它主要用来获取被进程打开文件的信息。
在 Linux 中,一切皆文件,lsof 命令可以查看所有已经打开了的文件,比如:普通文件,目录,特殊的块文件,管道,socket 套接字,设备,Unix 域套接字等等。同时,它还可以结合 grep 以及 ps 命令进行更多的高级搜索
打开的文件:
在Linux中,一切都是文件,当进程打开现有文件或创建新文件时,内核向进程返回一个文件描述符,文件描述符就是内核为了高效管理已被打开的文件所创建的索引,用来指向被打开的文件,所有执行 I/O 操作的系统调用都会通过文件描述符。因此,打开的文件指的是进程打开并使用的文件。
二、lsof语法
2.1 基本格式
lsof [OPTIONS] [--] [NAMES]
在没有任何选项的情况下,lsof 列出所有属于活动进程的打开文件(一般会很多、很多、很多)。
2.2 选项
lsof
命令有很多选项,下面是一些常用的选项(完整的字节看手册):
-a
:表示 AND,用于指定多个条件。-c <command>
:列出指定命令所打开的文件。-d <fd>
:列出指定文件描述符所打开的文件。-g <gid>
:列出指定组 ID 所属的进程所打开的文件。-i
:列出所有打开了网络套接字(TCP 和 UDP)的进程。-n
:禁止解析 IP 地址和端口号。-p <pid>
:列出指定进程 ID 所打开的文件。-u <username>
:列出指定用户所属的进程所打开的文件。
2.3 输出字段解释
使用lsof命令后输出一般有9个字段(9列):
COMMAND:进程的名称
PID:进程标识符
USER:进程所有者
FD:文件描述符。主要有:cwd:应用程序当前工作目录,这是该应用程序启动的目录,除非它本身对这个目录进行更改txt:该类型的文件是程序代码,如应用程序二进制文件本身或共享库,如上列表中显示的 /sbin/init 程序lnn:库引用(AIX)err:FD 信息错误jld:监狱目录(FreeBSD)ltx:共享库文本(代码和数据)mxx:十六进制内存映射类型号 xxm86:DOS合并映射文件mem:内存映射文件mmap:内存映射设备pd:父目录rtd:根目录tr:内核跟踪文件(OpenBSD)v86:VP/ix 映射文件0:标准输出1:标准输入2:标准错误文件描述符后一般还跟着文件状态模式:r:只读模式w:写入模式u:读写模式空格:文件的状态模式为 unknow,且没有锁定-:文件的状态模式为 unknow,且被锁定同时在文件状态模式后面,还跟着相关的锁:N:对于未知类型的 Solaris NFS 锁r:文件部分的读锁R:整个文件的读锁w:文件的部分写锁W:整个文件的写锁u:任何长度的读写锁U:用于未知类型的锁x:用于部分文件上的 SCO OpenServer Xenix 锁X:用于整个文件上的 SCO OpenServer Xenix 锁space:无锁TYPE:文件类型。常见的文件类型有:REG:普通文件DIR:表示目录CHR:表示字符类型BLK:块设备类型UNIX:UNIX 域套接字FIFO:先进先出队列IPv4(6):IPv4(6) 套接字
DEVICE:磁盘名称
SIZE:文件的大小或文件偏移量(以字节为单位)
NODE:索引节点
NAME:打开文件的确切名称
例如:
root@CQUPTLEI:~# lsof -i udp
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
systemd 1 root 37u IPv4 1001 0t0 UDP *:sunrpc
systemd 1 root 39u IPv6 1007 0t0 UDP *:sunrpc
rpcbind 696 _rpc 5u IPv4 1001 0t0 UDP *:sunrpc
rpcbind 696 _rpc 7u IPv6 1007 0t0 UDP *:sunrpc
systemd-n 801 systemd-network 19u IPv4 22416 0t0 UDP CQUPTLEI:bootpc
systemd-r 803 systemd-resolve 12u IPv4 21343 0t0 UDP localhost:domain
avahi-dae 820 avahi 12u IPv4 24274 0t0 UDP *:mdns
avahi-dae 820 avahi 13u IPv6 24275 0t0 UDP *:mdns
三、常用 lsof 操作
3.1 查看某文件的相关进程
root@CQUPTLEI:~# lsof /bin/bash
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
mysqld_sa 1188 root txt REG 252,2 1183448 132810 /usr/bin/bash
sh 3495 root txt REG 252,2 1183448 132810 /usr/bin/bash
bash 1520268 root txt REG 252,2 1183448 132810 /usr/bin/bash
bash 1520271 root txt REG 252,2 1183448 132810 /usr/bin/bash
bash 1666912 root txt REG 252,2 1183448 132810 /usr/bin/bash
3.2 网络相关:-i
-i
选项用于列出所有打开了网络套接字(TCP 和 UDP)的进程。
常用的用法:
-i
:列出所有打开了网络套接字(TCP 和 UDP)的进程。-i tcp
:列出所有打开了 TCP 网络连接的进程。-i :<port>
:列出某个端口被哪些进程打开了。-i @<ip_address>
:列出某个 IP 地址被哪些进程打开了。-u <username> -i
:列出某个用户打开了哪些网络连接。
例:
root@CQUPTLEI:~# lsof -i :443
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
nginx 978 root 10u IPv4 26143 0t0 TCP *:https (LISTEN)
nginx 983 www 10u IPv4 26143 0t0 TCP *:https (LISTEN)
nginx 984 www 10u IPv4 26143 0t0 TCP *:https (LISTEN)
3.3 指定进程号打开的文件:-p
-p
选项用于列出指定进程 ID 所打开的文件。
root@CQUPTLEI:~# lsof -p 1
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
systemd 1 root cwd DIR 252,2 4096 2 /
systemd 1 root rtd DIR 252,2 4096 2 /
systemd 1 root txt REG 252,2 1620224 136385 /usr/lib/systemd/systemd
systemd 1 root mem REG 252,2 1369384 134892 /usr/lib/x86_64-linux-gnu/libm-2.31.so
systemd 1 root mem REG 252,2 178528 136839 /usr/lib/x86_64-linux-gnu/libudev.so.1.6.17
systemd 1 root mem REG 252,2 1575112 138611 /usr/lib/x86_64-linux-gnu/libunistring.so.2.1.0
3.4 指定用户打开的文件:-u
-u
选项用于列出指定用户所属的进程所打开的文件。
root@CQUPTLEI:~# ls /home
lighthouse ubuntu www
root@CQUPTLEI:~# lsof -u www
lsof: WARNING: can't stat() fuse.gvfsd-fuse file system /run/user/134/gvfsOutput information may be incomplete.
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
nginx 983 www cwd DIR 252,2 4096 2 /
nginx 983 www rtd DIR 252,2 4096 2 /
nginx 983 www txt REG 252,2 5060432 912450 /www/server/nginx/sbin/nginx
nginx 983 www mem REG 252,2 239896 131210 /usr/lib/x86_64-linux-gnu/libnss_systemd.so.2
nginx 983 www DEL REG 0,1 26134 /dev/zero
nginx 983 www DEL REG 0,1 26133 /dev/zero
nginx 983 www DEL REG 0,1 26132 /dev/zero
nginx 983 www DEL REG 0,1 26131 /dev/zero
3.5 某进程打开的文件:-c
-c 选项用于列出指定命令所打开的文件,不需要进程的完整名称,可以使用进程名的一部分。
root@CQUPTLEI:~# lsof -c alist
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
alist 941 root cwd DIR 252,2 4096 1041395 /opt/alist
alist 941 root rtd DIR 252,2 4096 2 /
alist 941 root txt REG 252,2 43084616 1041396 /opt/alist/alist
alist 941 root mem-r REG 252,2 32768 1041407 /opt/alist/data/data.db-shm
alist 941 root 0r CHR 1,3 0t0 6 /dev/null
alist 941 root 1u unix 0xffffa05a31b67000 0t0 26720 type=STREAM
alist 941 root 2u unix 0xffffa05a31b67000 0t0 26720 type=STREAM
3.6 复合查询
(1)同时满足多个条件:-a
用户www打开的tcp 443端口,逻辑与(and)
root@CQUPTLEI:~# lsof -a -u www -i tcp:443
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
nginx 983 www 10u IPv4 26143 0t0 TCP *:https (LISTEN)
nginx 984 www 10u IPv4 26143 0t0 TCP *:https (LISTEN)
(2)满足每个条件
不使用-a时,多个选项之间的关系是或(or)
root@CQUPTLEI:~# lsof -c ssh -c alist
输出所有名称含有ssh、alist的进程打开的文件。
四、进阶用法
4.1用文本处理命令(grep\awk\sed)结合使用
例: 与grep命令结合使用
打印服务器所有tcp连接中,文件描述符为10的连接:
root@CQUPTLEI:~# lsof -i tcp | grep "10u"
alist 941 root 10u IPv6 31063 0t0 TCP *:5244 (LISTEN)
nginx 978 root 10u IPv4 26143 0t0 TCP *:https (LISTEN)
nginx 983 www 10u IPv4 26143 0t0 TCP *:https (LISTEN)
nginx 984 www 10u IPv4 26143 0t0 TCP *:https (LISTEN)
BT-Panel 2638 root 10u IPv4 23149843 0t0 TCP CQUPTLEI:8888->internettl.org:52156 (ESTABLISHED)
|
为管道符,表示将左边的输出作为右边的输入
例: 与awk命令结合使用
对Linux的dns服务器(named)打开的tcp连接,按照描述符升序打印
lsof -i tcp -n| awk '/named/{print $1,$2,$3,$4,$5,$6,$6,$8,$9}' | sort -n -k 4
root@CQUPTLEI:~# lsof -i tcp -n| awk '/named/{print $1,$2,$3,$4,$5,$6,$6,$8,$9}' | sort -n -k 4
named 945 bind 22u IPv4 29095 29095 TCP 127.0.0.1:953
named 945 bind 26u IPv4 26405 26405 TCP 127.0.0.1:domain
named 945 bind 27u IPv4 26405 26405 TCP 127.0.0.1:domain
named 945 bind 28u IPv4 26405 26405 TCP 127.0.0.1:domain
named 945 bind 32u IPv4 28479 28479 TCP 10.0.8.5:domain
named 945 bind 33u IPv4 28479 28479 TCP 10.0.8.5:domain
named 945 bind 34u IPv4 28479 28479 TCP 10.0.8.5:domain
named 945 bind 37u IPv6 26406 26406 TCP [::1]:domain
named 945 bind 38u IPv6 26406 26406 TCP [::1]:domain
named 945 bind 39u IPv6 26406 26406 TCP [::1]:domain
named 945 bind 42u IPv6 28513 28513 TCP [fe80::5054:ff:fe4b:ad85]:domain
named 945 bind 43u IPv6 28513 28513 TCP [fe80::5054:ff:fe4b:ad85]:domain
named 945 bind 44u IPv6 28513 28513 TCP [fe80::5054:ff:fe4b:ad85]:domain
named 945 bind 45u IPv6 29096 29096 TCP [::1]:953
named 945 bind 48u IPv4 36766 36766 TCP 172.17.0.1:domain
named 945 bind 49u IPv4 36766 36766 TCP 172.17.0.1:domain
named 945 bind 50u IPv4 36766 36766 TCP 172.17.0.1:domain
sort -n -k 4:
对结果排序,按照第四列数字升序
4.2 更多实用选项
lsof还有很多选项,比如:对文件夹递归搜索
-?, -h 显示帮助信息
-a
参数被视为逻辑与 AND,会影响全部的参数
-A A在配置了 AFS 分布式网络文件系统的系统上可用,其 AFS 内核代码是通过动态模块实现的。通过 A 指定备用名称列表文件,在该文件中可以找到动态模块的内核地址
-b避免 lsof 因调用可能阻塞的内核函数而产生阻塞,比如 lstat(2)、readlink(2) 和 stat(2) 等内核函数
-c C显示出以字符或字符串 C 开头的命令程序开启的文件,如 lsof -c init。如果 C 以斜杠 / 开头和结尾,则斜杠之间的字符被解释为正则表达式。该选项可多次指定
+c W指定 COMMAND 列的宽度,单位字符。默认为 9
-C禁用从内核的名称缓存中报告任何路径名
-D D指导 lsof 使用设备缓存文件。该选项的使用有时受到限制。-D 必须后面跟着一个函数字母,函数字母后面可以有一个路径名称。lsof 识别以下功能字母:? 报告设备缓存文件路径b 构建设备缓存文件i 忽略设备缓存文件r 读取设备缓存文件u 读取并更新设备缓存文件
+D D递归搜索目录 D。如显示在 /usr/local 及其子目录下被程序开启的文件:lsof +D /usr/local
+d D非递归搜索目录 D。如显示在 /usr/local 下被程序开启的文件:lsof +d /usr/local
-d FD指定文件描述符列表,可以采用逗号分隔,也可以指定范围。比如 1,2,3 或 1-3。如果前面包含尖号,表示排除。如显示 FD 为 4 的进程:lsof -d 4
+|-e S豁免(exempt)路径名称为 S 的文件系统不受可能阻塞的内核函数调用的影响。+e 选项豁免 stat(2)、lstat(2) 和大多数 readlink(2) 内核函数调用。-e 选项只能豁免 stat(2) 和 lstat(2) 内核函数调用
+|-E+E 指定使用端点信息显示 Linux 管道、Linux UNIX 套接字和 Linux 伪终端文件,并显示端点的文件。-E 则不显示端点的文件
-F LIST指定字符列表 LIST,选择输出给另一程序处理的字段,各字段对应的字符见下文
+|-f [cfgGn]f 本身澄清了路径名参数的解释方式。当后面跟着 c、f、g、G 或 n 时,它指定要启用(+)或抑制(-)内核文件结构信息。c 文件结构使用计数(not Linux)f 文件结构地址(not Linux)g 文件标志缩写(Linux 2.6.22 及更高版本)G 十六进制文件标志(Linux 2.6.22 及更高版本)n 文件结构节点地址(not Linux)
-g [PGID]选择或排除属于指定进程组的进程打开的文件。 进程组 ID 使用逗号分隔,如果 PGID 前面包含尖号,表示排除。若没有指定 PGID,则显示全部。如显示 PGID 为 6 和 7 的进程:lsof -g6,7
-i [I]选择其 Internet 地址与 -i 中指定的地址匹配的文件,若没有相关地址被指定,则监听全部。用法: lsof -i [46][protocol][@hostname|hostaddr][:serivce|port]说明:4 6 分别表示 IPv4 和 IPv6 protocol: TCP or UDP hostname:主机名hostaddr:IPv4 或 IPv6 地址service:主机提供的服务的名称,即 /etc/services 中的 service nameport:端口号
-K在支持任务(线程)报告方式的系统上输出进程的任务(线程)列表
-k K指定内核名称列表文件,代替 /vmunix、/mach 等
-l禁止将 user ID 转换为登录的名称,默认是登录名称
+|-L [L]+ 或 - 表示开启或关闭显示文件连接数,如果只有单纯的 +L,后面没有任何数字,则表示显示全部,如果后面有数字,只有文件连接数少于该数字的会被列出
+|-m M-m 指定一个内核内存文件 M ,代替 /dev/kmem 或 /dev/mem。+m 将装载补充文件写入标准输出文件
+|-M启用或禁用报告本地 TCP、UDP 和 UDPLITE 端口的端口映射器注册
-n不将 IP 地址转换为主机名
-N显示 NFS 文件
-o始终显示文件偏移量。它导致 SIZE/OFF 输出列标题更改为 OFFSET
-o O指定在文件偏移量的 0t 之后要打印的小数位数
-O指示 lsof 避免被某些内核操作阻塞。即在分叉的子进程中执行它们。虽然使用此选项将减少 lsof 启动开销,但也可能导致 lsof 在内核不响应函数时挂起。谨慎使用此选项
-P禁止将网络文件的端口号转换为端口名
-p S排除或选择进程的文件列表,进程 ID 列表使用逗号分隔,如 123 或 123,^456。尖号表示排除指定 PID
-R使用列 PPID 列出父进程的 PID
+|-r [T[mFMT]]控制 lsof 不断重复执行,间隔 T 秒,默认为 15s。-r 永远不断地执行,直到收到中断讯号(ctrl+ c),+r 一直执行,直到没有文件被显示。可选的 mFMT 参数指定标记线的格式,格式 FMT 遵循 C 语言标准库函数 strftime(3) 的规范
-S [T]指定内核函数 lstat(2)、readlink(2) 和 stat(2) 的可选超时秒值,否则可能会死锁。t 的最小值是 2;默认值是 15
-s [P:S]列出文件的大小,若该文件没有大小,则留下空白。它导致 SIZE/OFF 输出列标题更改为 SIZE。P 表示协议名称 TCP or UDP,S 表示逗号分隔的协议状态
-T [T]-T 没有参数则禁用 TCP/TPI 信息报告。跟如下参数,则显示指定 TCP/TPI 信息:f 选择报告套接字选项,状态和值,以及 TCP标志和值q 选择队列长度s 选择连接状态w 选择窗口大小
-t生成只有进程标识符而没有标题的简洁输出,这样输出可以通过管道传递给 kill(1) 杀死
-U选择 UNIX 域套接字文件的列表
-u USERS选择登录名或用户 ID 位于逗号分隔集 USERS 中的用户的文件列表。如 root 或 548,root”,如果用户名或用户 ID 前有尖号 ^,表示排除
-V指示被要求列出但找不到的项
-v显示版本信息
+|-w启用(+)或禁用(-)警告消息
-XLinux 下跳过所有打开的 TCP、UDP 和 UDPLITE IPv4 和 IPv6 文件的信息报告
-x [fl]一般与选项 +d 和 +D 选项,指示搜索时是否跨文件系统和符号链接。-x 不跟任何参数时,表示跨文件系统和符号链接
-Z [Z]指定如何处理 SELinux 安全上下文。当在运行的 Linux 内核中禁用SELinux时,Z 字段将被抑制输出。-Z 选项不跟参数,如 -Z -,安全上下文将列在 SECURITY-CONTEXT 列中输出
--双减号表示选项结束
NAMES列出指定文件,符号链接在使用前将被解析
相关文章:
【Linux进阶命令 04】lsof (看看是谁动了我的文件?)
文章目录 一、简介二、lsof语法2.1 基本格式2.2 选项2.3 输出字段解释 三、常用 lsof 操作3.1 查看某文件的相关进程3.2 网络相关:-i3.3 指定进程号打开的文件:-p3.4 指定用户打开的文件:-u3.5 某进程打开的文件:-c3.6 复合查询 四…...

华为OD机试真题 Java 实现【数字加减游戏】【2023Q1 200分】
一、题目描述 小明在玩一个数字加减游戏,只使用加法或者减法,将一个数字s变成数字t。 每个回合,小明可以用当前的数字加上或减去一个数字。 现在有两种数字可以用来加减,分别为a,其中b没有使用次数限制。 请问小明…...

Python: 结合多进程和 Asyncio 以提高性能
动动发财的小手,点个赞吧! 简介 多亏了 GIL,使用多个线程来执行 CPU 密集型任务从来都不是一种选择。随着多核 CPU 的普及,Python 提供了一种多处理解决方案来执行 CPU 密集型任务。但是直到现在,直接使用多进程相关的…...

只需要两步就能快速接入GPT
缘起 最近一个朋友提出,让我出个关于如何快速接入GPT的教程,今天就给大家安排上。 需要的工具 经过实测,这是迄今为止最便捷的接入方式,而且亲测有效。 首先,第一步你需要下载最新版的微软Edge浏览器,去…...

使用Git-lfs上传超过100m的大文件到GitHub
文章目录 1. 安装 git-lfs2. 在Git中安装git-ifs3. 找到工程中的所有大文件4.执行完这行命令,项目目录下会生成文件 .gitattributes,此时Git push将 .gitattributes 提交到远程仓库。 5. 需要注意的事 1. 安装 git-lfs Git Large File Storage | Git La…...

【网络】计算机中的网络
目录 🍁计算机网络 🍁计算机网络模型 🍁布线工程 🍁布线系统 🦐博客主页:大虾好吃吗的博客 🦐专栏地址:网络专栏 计算机网络 计算机网络的功能 数据通信、资源共享、增加可靠性、提…...

什么是语音识别的语音助手?
前言 语音助手已经成为现代生活中不可或缺的一部分。人们可以通过语音助手进行各种操作,如查询天气、播放音乐、发送短信等。语音助手的核心技术是语音识别。本文将详细介绍语音识别的语音助手。 语音识别的基本原理 语音识别是将语音信号转换为文本的技术。语音识…...

自己动手写一个加载器
前言 当在 linux 命令行中 ./ 运行一个程序时,实际上操作系统会调用加载器将这个程序加载到内存中去执行。为了探究加载器的行为,今天我们就自己动手写一个简单的加载器。 工作原理 加载器的工作原理: 从磁盘读取 bin 文件到内存…...
C# 性能优化和Unity性能优化
C# 性能优化 C# 性能优化是一个非常广泛的话题,需要从各个方面来考虑,包括算法和数据结构、编译器优化、代码优化等等。下面是一些常见的 C# 性能优化技巧: 选择正确的数据结构:C# 提供了各种不同的数据结构,例如数组、…...

面试题背麻了,花3个月面过华为测开岗,拿个26K不过分吧?
计算机专业,代码能力一般,之前有过两段实习以及一个学校项目经历。第一份实习是大二暑期在深圳的一家互联网公司做前端开发,第二份实习由于大三暑假回国的时间比较短(小于两个月),于是找的实习是在一家初创…...

跟着我学 AI丨教育 + AI = 一对一教学
随着人工智能(AI)技术的迅速发展,它已经开始了改变教育的方式。本文将介绍AI在教育行业中的应用场景,当前从事AI 教育的公司有哪些以及这些公司所提供的教育产品的特点,和未来AI 教育的潜在实现方式。 AI在教育行业的…...
1-动态规划算法理论基础
目录 1.什么是动态规划? PS:动态规划 VS 贪心 2.动态规划的解题步骤 ①确定dp数组(dp table)以及下标的含义。 ②确定递推公式/状态转移公式。 ③dp数组如何初始化。 ④确定遍历顺序。 ⑤举例推导dp数组。 3.动态规划应该如何debug…...

kafka延时队列内部应用简介
kafka延时队列_悠然予夏的博客-CSDN博客 两个follower副本都已经拉取到了leader副本的最新位置,此时又向leader副本发送拉取请求,而leader副本并没有新的消息写入,那么此时leader副本该如何处理呢?可以直接返回空的拉取结…...

【网络】HTTPHTTPS协议
文章目录 HTTP协议认识URLurlencode和urldecodeHTTP协议格式HTTP请求协议格式简单的小实验 HTTP响应协议格式关于封装解包分用 HTTP的方法关于GET和POST方法概念GET&POST对比(代码测试)测试POST和GET方法的区别 HTTP的状态码关于重定向的状态码临时重定向的代码演示: HTTP的…...

因子图优化
最大后验概率估计问题 我们常将状态估计问题建模为最大后验估计(MAP)。之所以命名为最大后验估计,是因为它在给定了观测 Z \bm Z Z的情况下,最大化状态 X \bm X X的后验概率密度 p ( X ∣ Z ) p(\bm X|\bm Z) p(X∣Z) X M A P …...

JVM 垃圾回收相关算法
垃圾标记阶段 对象存活判断: 在堆里存放着几乎所有的 Java 对象实例,在GC 执行垃圾回收之前,首先需要区分出内存中哪些是存活对象,哪些是已经死亡的对象。只有被标记为已经死亡的对象,GC 才会在执行垃圾回收时,释放掉…...
[Bing Chat] 以某某这个数据结构 编一个故事 要求不能说出某某这个数据结构
以二叉搜索树这个数据结构 编一个故事 要求不能说出二叉搜索树这个数据结构 好的,我试试。这是我编的一个故事,希望你喜欢: 有一天,小明要去参加一个数学竞赛,他需要在有限的时间内回答很多问题。他发现,有…...
【算法】【算法杂谈】一种字符串和数字的对应关系
目录 前言问题介绍解决方案代码编写java语言版本c语言版本c语言版本 思考感悟写在最后 前言 当前所有算法都使用测试用例运行过,但是不保证100%的测试用例,如果存在问题务必联系批评指正~ 在此感谢左大神让我对算法有了新的感悟认识! 问题介…...
Java并发基础理论
Java并发基础理论 进程与线程 进程 进程是程序的一次执行过程,是系统运行程序的基本单位,因为进程是动态的。系统运行一个程序就是一个进程从创建运行到消亡的过程。 我们启动main方法其实就是启动了一个JVM进程,而main方法所在的线…...

ubuntu22.04静态ip设置(桥接模式、only-host+NAT模式)
在创建一台虚拟机后,默认的方式往往是通过DHCP动态的进行分配,DHCP服务器会告知创建的虚拟机分配到的ip地址,网关地址等信息。所以在创建好虚拟机之后,这些信息都不需要我们来配置,我们直接用就好了。 但是࿰…...

7.4.分块查找
一.分块查找的算法思想: 1.实例: 以上述图片的顺序表为例, 该顺序表的数据元素从整体来看是乱序的,但如果把这些数据元素分成一块一块的小区间, 第一个区间[0,1]索引上的数据元素都是小于等于10的, 第二…...

Spark 之 入门讲解详细版(1)
1、简介 1.1 Spark简介 Spark是加州大学伯克利分校AMP实验室(Algorithms, Machines, and People Lab)开发通用内存并行计算框架。Spark在2013年6月进入Apache成为孵化项目,8个月后成为Apache顶级项目,速度之快足见过人之处&…...
Admin.Net中的消息通信SignalR解释
定义集线器接口 IOnlineUserHub public interface IOnlineUserHub {/// 在线用户列表Task OnlineUserList(OnlineUserList context);/// 强制下线Task ForceOffline(object context);/// 发布站内消息Task PublicNotice(SysNotice context);/// 接收消息Task ReceiveMessage(…...

论文浅尝 | 基于判别指令微调生成式大语言模型的知识图谱补全方法(ISWC2024)
笔记整理:刘治强,浙江大学硕士生,研究方向为知识图谱表示学习,大语言模型 论文链接:http://arxiv.org/abs/2407.16127 发表会议:ISWC 2024 1. 动机 传统的知识图谱补全(KGC)模型通过…...

零基础设计模式——行为型模式 - 责任链模式
第四部分:行为型模式 - 责任链模式 (Chain of Responsibility Pattern) 欢迎来到行为型模式的学习!行为型模式关注对象之间的职责分配、算法封装和对象间的交互。我们将学习的第一个行为型模式是责任链模式。 核心思想:使多个对象都有机会处…...
代理篇12|深入理解 Vite中的Proxy接口代理配置
在前端开发中,常常会遇到 跨域请求接口 的情况。为了解决这个问题,Vite 和 Webpack 都提供了 proxy 代理功能,用于将本地开发请求转发到后端服务器。 什么是代理(proxy)? 代理是在开发过程中,前端项目通过开发服务器,将指定的请求“转发”到真实的后端服务器,从而绕…...

springboot整合VUE之在线教育管理系统简介
可以学习到的技能 学会常用技术栈的使用 独立开发项目 学会前端的开发流程 学会后端的开发流程 学会数据库的设计 学会前后端接口调用方式 学会多模块之间的关联 学会数据的处理 适用人群 在校学生,小白用户,想学习知识的 有点基础,想要通过项…...
A2A JS SDK 完整教程:快速入门指南
目录 什么是 A2A JS SDK?A2A JS 安装与设置A2A JS 核心概念创建你的第一个 A2A JS 代理A2A JS 服务端开发A2A JS 客户端使用A2A JS 高级特性A2A JS 最佳实践A2A JS 故障排除 什么是 A2A JS SDK? A2A JS SDK 是一个专为 JavaScript/TypeScript 开发者设计的强大库ÿ…...
Go语言多线程问题
打印零与奇偶数(leetcode 1116) 方法1:使用互斥锁和条件变量 package mainimport ("fmt""sync" )type ZeroEvenOdd struct {n intzeroMutex sync.MutexevenMutex sync.MutexoddMutex sync.Mutexcurrent int…...
Vite中定义@软链接
在webpack中可以直接通过符号表示src路径,但是vite中默认不可以。 如何实现: vite中提供了resolve.alias:通过别名在指向一个具体的路径 在vite.config.js中 import { join } from pathexport default defineConfig({plugins: [vue()],//…...