# @ohos.process (获取进程相关的信息) > **说明:** > > 本模块首批接口从API version 7开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。 ## 导入模块 ``` import process from '@ohos.process'; ``` ## 属性 **系统能力:** SystemCapability.Utils.Lang | 名称 | 类型 | 可读 | 可写 | 说明 | | -------- | -------- | -------- | -------- | -------- | | egid | number | 是 | 否 | 进程的有效组标识。
**系统接口:** 此接口为系统接口。
此接口仅用于对应用的测试。| | euid | number | 是 | 否 | 进程的有效用户身份。
**系统接口:** 此接口为系统接口。
此接口仅用于对应用的测试。 | | gid | number | 是 | 否 | 进程的组标识。
**系统接口:** 此接口为系统接口。
此接口仅用于对应用的测试。| | uid | number | 是 | 否 | 进程的用户标识。 | | groups | number[] | 是 | 否 | 带有补充组id的数组。
**系统接口:** 此接口为系统接口。
此接口仅用于对应用的测试。 | | pid | number | 是 | 否 | 当前进程的pid。 | | ppid | number | 是 | 否 | 当前进程的父进程的pid。
**系统接口:** 此接口为系统接口。
此接口仅用于对应用的测试。 | | tid8+ | number | 是 | 否 | 当前线程的tid。 | ## EventListener 系统能力: SystemCapability.Utils.Lang | 名称 | 说明 | | -------- | -------- | | EventListener = (evt:  Object) => void | 用户存储的事件。 | ## process.isIsolatedProcess8+ isIsolatedProcess(): boolean 判断进程是否被隔离。 **系统能力:** SystemCapability.Utils.Lang **返回值:** | 类型 | 说明 | | -------- | -------- | | boolean | 返回判断结果,true表示进程被隔离,false表示未被隔离。| **示例:** ```js let result = process.isIsolatedProcess(); ``` ## process.is64Bit8+ is64Bit(): boolean 判断运行环境是否64位。 **系统能力:** SystemCapability.Utils.Lang **返回值:** | 类型 | 说明 | | -------- | -------- | | boolean | 返回判断结果,如果为64位环境返回true,否则返回false。| **示例:** ```js let result = process.is64Bit(); ``` ## process.getStartRealtime8+ getStartRealtime(): number 获取从系统启动到进程启动所经过的实时时间(以毫秒为单位)。 **系统能力:** SystemCapability.Utils.Lang **返回值:** | 类型 | 说明 | | -------- | -------- | | number | 返回经过的实时时间。单位:毫秒| **示例:** ```js let realtime = process.getStartRealtime(); ``` ## process.getPastCpuTime8+ getPastCpuTime(): number 获取进程启动到当前时间的CPU时间(以毫秒为单位)。 **系统能力:** SystemCapability.Utils.Lang **返回值:** | 类型 | 说明 | | -------- | -------- | | number | 返回经过的CPU时间。单位:毫秒| **示例:** ```js let result = process.getPastCpuTime() ; ``` ## process.runCmd runCmd(command: string, options?: { timeout?: number, killSignal?: number | string, maxBuffer?: number }): ChildProcess 通过runcmd可以fork一个新的进程来运行一段shell,并返回ChildProcess对象。 **系统接口:** 此接口为系统接口。 此接口仅用于对应用的测试。 **系统能力:** SystemCapability.Utils.Lang **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | command | string | 是 | shell命令。 | | options | Object | 否 | 相关选项参数。 | **表1** options | 名称 | 参数类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | timeout | number | 否 | 子进程运行的毫秒数,当子进程运行时间超出此时间,则父进程发送killSignal信号给子进程。timeout默认为0。 | | killSignal | number \| string | 否 | 子进程运行时间超出timeout时,父进程发送killSignal 信号给子进程。killSignal 默认为'SIGTERM'。 | | maxBuffer | number | 否 | 子进程标准输入输出的最大缓冲区大小,当超出此大小时则终止子进程。maxBuffer默认1024\*1024。 | **返回值:** | 类型 | 说明 | | -------- | -------- | | [ChildProcess](#childprocess) | 子进程对象。 | **示例:** ```js let child = process.runCmd('ls', { maxBuffer : 2 }); let result = child.wait(); child.getOutput.then(val=>{ console.log("child.getOutput = " + val); }) ``` ## process.abort abort(): void 该方法会导致进程立即退出并生成一个核心文件,谨慎使用。 **系统能力:** SystemCapability.Utils.Lang **示例:** ```js process.abort(); ``` ## process.on on(type: string, listener: EventListener): void 存储用户所触发的事件。 **系统接口:** 此接口为系统接口。 此接口仅用于对应用的测试。 **系统能力:** SystemCapability.Utils.Lang **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | type | string | 是 | 存储事件的type。 | | listener | [EventListener](#eventlistener) | 是 | 回调的事件。 | **示例:** ```js process.on("data", (e)=>{ console.log("data callback"); }) ``` ## process.off off(type: string): boolean 删除用户存储的事件。 **系统接口:** 此接口为系统接口。 此接口仅用于对应用的测试。 **系统能力:** SystemCapability.Utils.Lang **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | type | string | 是 | 删除事件的type。 | **返回值:** | 类型 | 说明 | | -------- | -------- | | boolean | 事件删除成功则返回true,没有成功则为false。| **示例:** ```js process.on("data", (e)=>{ console.log("data callback"); }) let result = process.off("data"); ``` ## process.cwd cwd(): string 获取进程的工作目录。 **系统接口:** 此接口为系统接口。 此接口仅用于对应用的测试。 **系统能力:** SystemCapability.Utils.Lang **返回值:** | 类型 | 说明 | | -------- | -------- | | string| 返回当前进程的工作目录。 | **示例:** ```js let path = process.cwd(); ``` ## process.chdir chdir(dir: string): void 更改进程的当前工作目录。 **系统接口:** 此接口为系统接口。 此接口仅用于对应用的测试。 **系统能力:** SystemCapability.Utils.Lang **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | dir | string | 是 | 路径。 | **示例:** ```js process.chdir('/system'); ``` ## process.uptime uptime(): number 获取当前系统已运行的秒数。 **系统能力:** SystemCapability.Utils.Lang **返回值:** | 类型 | 说明 | | -------- | -------- | | number | 当前系统已运行的秒数。 | **示例:** ```js let time = process.uptime(); ``` ## process.kill(deprecated) kill(signal: number, pid: number): boolean 发送signal到指定的进程,结束指定进程。 > **说明:** > > 从API version 7开始支持,从API version 9开始废弃,建议使用[kill9+](#kill9)替代。 **系统能力:** SystemCapability.Utils.Lang **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | pid | number | 是 | 进程的id。 | | signal | number | 是 | 发送的信号。 | **返回值:** | 类型 | 说明 | | -------- | -------- | | boolean | 信号是否发送成功。 | **示例:** ```js let pres = process.pid let result = process.kill(28, pres) ``` ## process.exit(deprecated) exit(code: number): void 终止程序。 请谨慎使用此接口,此接口调用后应用会退出,如果入参非0会产生数据丢失或者异常情况。 > **说明:** > > 从API version 7开始支持,从API version 9开始废弃,建议使用[exit9+](#exit9)替代。 **系统能力:** SystemCapability.Utils.Lang **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | code | number | 是 | 进程的退出码。 | **示例:** ```js process.exit(0); ``` ## process.getUidForName(deprecated) getUidForName(v: string): number 通过进程名获取进程uid。 > **说明:** > > 从API version 8开始支持,从API version 9开始废弃,建议使用[getUidForName9+](#getuidforname9)替代。 **系统能力:** SystemCapability.Utils.Lang **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | v | string | 是 | 进程名。 | **返回值:** | 类型 | 说明 | | -------- | -------- | | number | 返回进程uid。| **示例:** ```js let pres = process.getUidForName("tool") ``` ## process.getThreadPriority(deprecated) getThreadPriority(v: number): number 根据指定的tid获取线程优先级。 > **说明:** > > 从API version 8开始支持,从API version 9开始废弃,建议使用[getThreadPriority9+](#getthreadpriority9)替代。 **系统能力:** SystemCapability.Utils.Lang **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | v | number | 是 | 指定的线程tid。 | **返回值:** | 类型 | 说明 | | -------- | -------- | | number | 返回线程的优先级。 | **示例:** ```js let tid = process.tid; let pres = process.getThreadPriority(tid); ``` ## process.isAppUid(deprecated) isAppUid(v: number): boolean 判断uid是否属于应用程序。 > **说明:** > > 从API version 8开始支持,从API version 9开始废弃,建议使用[isAppUid9+](#isappuid9)替代。 **系统能力:** SystemCapability.Utils.Lang **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | v | number | 是 | 应用程序的uid。 | **返回值:** | 类型 | 说明 | | -------- | -------- | | boolean | 返回判断结果,如果为应用程序的uid返回true,否则返回false。| **示例:** ```js let result = process.isAppUid(688); ``` ## process.getSystemConfig(deprecated) getSystemConfig(name: number): number 获取系统配置信息。 > **说明:** > > 从API version 8开始支持,从API version 9开始废弃,建议使用[getSystemConfig9+](#getsystemconfig9)替代。 **系统能力:** SystemCapability.Utils.Lang **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | name | number | 是 | 指定系统配置参数名。 | **返回值:** | 类型 | 说明 | | -------- | -------- | | number | 返回系统配置信息。 | **示例:** ```js let _SC_ARG_MAX = 0 let pres = process.getSystemConfig(_SC_ARG_MAX) ``` ## process.getEnvironmentVar(deprecated) getEnvironmentVar(name: string): string 获取环境变量对应的值。 > **说明:** > > 从API version 8开始支持,从API version 9开始废弃,建议使用[getEnvironmentVar9+](#getenvironmentvar9)替代。 **系统能力:** SystemCapability.Utils.Lang **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | name | string | 是 | 环境变量名。 | **返回值:** | 类型 | 说明 | | -------- | -------- | | string | 返回环境变量名对应的value。 | **示例:** ```js let pres = process.getEnvironmentVar("PATH") ``` ## ProcessManager9+ 提供用于新增进程的抛异常接口。 通过自身的构造来获取ProcessManager对象。 ### isAppUid9+ isAppUid(v: number): boolean 判断uid是否属于当前应用程序。 **系统能力:** SystemCapability.Utils.Lang **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | v | number | 是 | 应用程序的uid。 | **返回值:** | 类型 | 说明 | | -------- | -------- | | boolean | 返回判断结果,如果为应用程序的uid返回true,否则返回false。| **示例:** ```js let pro = new process.ProcessManager(); let result = pro.isAppUid(688); ``` ### getUidForName9+ getUidForName(v: string): number 通过进程名获取进程uid。 **系统能力:** SystemCapability.Utils.Lang **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | v | string | 是 | 进程名。 | **返回值:** | 类型 | 说明 | | -------- | -------- | | number | 返回进程uid。| **示例:** ```js let pro = new process.ProcessManager(); let pres = pro .getUidForName("tool"); ``` ### getThreadPriority9+ getThreadPriority(v: number): number 根据指定的tid获取线程优先级。 **系统能力:** SystemCapability.Utils.Lang **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | v | number | 是 | 指定的线程tid。 | **返回值:** | 类型 | 说明 | | -------- | -------- | | number | 返回线程的优先级。 | **示例:** ```js let pro = new process.ProcessManager(); let tid = process.tid; let pres = pro.getThreadPriority(tid); ``` ### getSystemConfig9+ getSystemConfig(name: number): number 获取系统配置信息。 **系统能力:** SystemCapability.Utils.Lang **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | name | number | 是 | 指定系统配置参数名。 | **返回值:** | 类型 | 说明 | | -------- | -------- | | number | 返回系统配置信息。 | **示例:** ```js let pro = new process.ProcessManager(); let _SC_ARG_MAX = 0; let pres = pro.getSystemConfig(_SC_ARG_MAX); ``` ### getEnvironmentVar9+ getEnvironmentVar(name: string): string 获取环境变量对应的值。 **系统能力:** SystemCapability.Utils.Lang **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | name | string | 是 | 环境变量名。 | **返回值:** | 类型 | 说明 | | -------- | -------- | | string | 返回环境变量名对应的值。 | **示例:** ```js let pro = new process.ProcessManager(); let pres = pro.getEnvironmentVar("PATH"); ``` ### exit9+ exit(code: number): void 终止程序。 请谨慎使用此接口,此接口调用后应用会退出,如果入参非0会产生数据丢失或者异常情况。 **系统能力:** SystemCapability.Utils.Lang **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | code | number | 是 | 进程的退出码。 | **示例:** ```js let pro = new process.ProcessManager(); pro.exit(0); ``` ### kill9+ kill(signal: number, pid: number): boolean 发送signal到指定的进程,结束指定进程。 **系统能力:** SystemCapability.Utils.Lang **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | pid | number | 是 | 进程的id。 | | signal | number | 是 | 发送的信号。 | **返回值:** | 类型 | 说明 | | -------- | -------- | | boolean | 信号是否发送成功。 | **示例:** ```js let pro = new process.ProcessManager(); let pres = process.pid; let result = pro.kill(28, pres); ``` ## ChildProcess ChildProcess对象为创建的新的子进程,主进程可以获取子进程的标准输入输出,以及发送信号和关闭子进程,可以通过[process.runCmd](#processruncmd)获取ChildProcess对象。 **系统接口:** 此接口为系统接口。 ### 属性 **系统接口:** 此接口为系统接口。 **系统能力:** SystemCapability.Utils.Lang | 名称 | 类型 | 可读 | 可写 | 说明 | | -------- | -------- | -------- | -------- | -------- | | pid | number | 是 | 否 | 子进程的pid。
**系统接口:** 此接口为系统接口。
此接口仅用于对应用的测试。 | | ppid | number | 是 | 否 | 子进程的父进程的pid。
**系统接口:** 此接口为系统接口。
此接口仅用于对应用的测试。 | | exitCode | number | 是 | 否 | 子进程的退出码。
**系统接口:** 此接口为系统接口。
此接口仅用于对应用的测试。| | killed | boolean | 是 | 否 | 父进程给子进程发信号是否成功。
**系统接口:** 此接口为系统接口。
此接口仅用于对应用的测试。 | ### wait wait(): Promise<number> 等待子进程运行结束,返回promise对象,其值为子进程的退出码。 **系统接口:** 此接口为系统接口。 此接口仅用于对应用的测试。 **系统能力:** SystemCapability.Utils.Lang **返回值:** | 类型 | 说明 | | -------- | -------- | | Promise<number> | 异步返回子进程的退出码。 | **示例:** ```js let child = process.runCmd('ls'); let result = child.wait(); result.then(val=>{ console.log("result = " + val); }) ``` ### getOutput getOutput(): Promise<Uint8Array> 获取子进程的标准输出。 **系统接口:** 此接口为系统接口。 此接口仅用于对应用的测试。 **系统能力:** SystemCapability.Utils.Lang **返回值:** | 类型 | 说明 | | -------- | -------- | | Promise<Uint8Array> | 异步返回标准输出的字节流。 | **示例:** ```js let child = process.runCmd('ls'); let result = child.wait(); child.getOutput().then(val=>{ console.log("child.getOutput = " + val); }) ``` ### getErrorOutput getErrorOutput(): Promise<Uint8Array> 获取子进程的标准错误输出。 **系统接口:** 此接口为系统接口。 此接口仅用于对应用的测试。 **系统能力:** SystemCapability.Utils.Lang **返回值:** | 类型 | 说明 | | -------- | -------- | | Promise<Uint8Array> | 异步返回标准错误输出的字节流。 | **示例:** ```js let child = process.runCmd('madir test.text'); let result = child.wait(); child.getErrorOutput().then(val=>{ console.log("child.getErrorOutput= " + val); }) ``` ### close close(): void 关闭正在运行的子进程。 **系统接口:** 此接口为系统接口。 此接口仅用于对应用的测试。 **系统能力:** SystemCapability.Utils.Lang **示例:** ```js let child = process.runCmd('sleep 5; ls'); child.close(); ``` ### kill kill(signal: number | string): void 用于发送信号给子进程,结束指定进程。 **系统接口:** 此接口为系统接口。 此接口仅用于对应用的测试。 **系统能力:** SystemCapability.Utils.Lang **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | signal | number \| string | 是 | 数字或字符串。 | **示例:** ```js let child = process.runCmd('sleep 5; ls'); child.kill(9); ```