这取决于 Linux 内核特性:一个进程有两个不同的名称。
- 其中一个名称是可执行文件路径的最后一个组成部分,例如,
native_executable
如果您的应用程序位于/data/apps/com.example.hello/native_executable
. 这是出现在 的Name
字段中的名称/proc/PID/status
。内核将其截断为 15 个字符,因此在本例中它包含native_executab
.
- 另一个名称由调用应用程序的程序作为其命令行参数 #0 (
argv[0]
在 C 中,args[0]
在 Java 中)传递。这是出现在开头/proc/PID/cmdline
并ps
显示的名称。
- 可执行文件的路径也是符号链接的目标
/proc/PID/exe
。
按照惯例,当一个程序启动另一个程序时,它应该使用可执行文件的名称作为命令行参数 0,但它可以选择不这样做。Name
字段/proc/PID/status
始终由内核设置为可执行文件的(截断的)名称。
这是一个通用的 Linux 功能 — 另请参阅我可以使用标准工具来获取进程的全名,当它的名称嵌入空格时?在问 Ubuntu上。
应用程序本身可以在之后更改这两个名称(尽管有长度限制)。Dalvik 使用这种能力来区分应用程序:所有应用程序都源自同一个本机可执行文件/sytem/bin/app_process
;VM没有让它们都被调用,而是将app_process
两个名称都更改为应用程序包名称。中的名称/proc/PID/status
限制为 15 个字符,这就是它被截断的原因。您可以从中获取更长的名称/proc/PID/cmdline
(读取到第一个空字节)。