0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看威廉希尔官方网站 视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

鸿蒙语言基础类库:ohos.process 获取进程相关的信息

jf_46214456 来源:jf_46214456 作者:jf_46214456 2024-07-08 17:13 次阅读

获取进程相关的信息

icon-note.gif说明: 本模块首批接口从API version 7开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。 开发前请熟悉鸿蒙开发指导文档 :[gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md]

导入模块

import process from '@ohos.process';

属性

系统能力: 以下各项对应的系统能力均为SystemCapability.Utils.Lang。

名称类型可读可写说明
egidnumber进程的有效组标识。该接口为系统接口,三方应用不支持调用。
euidnumber进程的有效用户身份。该接口为系统接口,三方应用不支持调用。
gidnumber进程的组标识。该接口为系统接口,三方应用不支持调用。
uidnumber进程的用户标识。
groupsnumber[]带有补充组id的数组。该接口为系统接口,三方应用不支持调用。
pidnumber当前进程的pid。
ppidnumber当前进程的父进程的pid。该接口为系统接口,三方应用不支持调用。
tid8+number当前进程的tid。

ChildProcess

主进程可以获取子进程的标准输入输出,以及发送信号和关闭子进程。

属性

系统能力: 以下各项对应的系统能力均为SystemCapability.Utils.Lang。

名称类型可读可写说明
pidnumber子进程的pid。该接口为系统接口,三方应用不支持调用。
ppidnumber子进程的父进程的pid。该接口为系统接口,三方应用不支持调用。
exitCodenumber子进程的退出码。该接口为系统接口,三方应用不支持调用。
killedboolean父进程给子进程发信号是否成功。该接口为系统接口,三方应用不支持调用。

wait

wait(): Promise

等待子进程运行结束,返回promise对象,其值为子进程的退出码。

该接口为系统接口,三方应用不支持调用。

系统能力: SystemCapability.Utils.Lang

返回值:

类型说明
Promise异步返回子进程的退出码。

示例:

var child = process.runCmd('ls');
var result = child.wait();
result.then(val= >{
    console.log("result = " + val);
})

getOutput

getOutput(): Promise

获取子进程的标准输出。

该接口为系统接口,三方应用不支持调用。

系统能力: SystemCapability.Utils.Lang

返回值:

类型说明
Promise异步返回标准输出的字节流。

示例:

var child = process.runCmd('ls');
var result = child.wait();
child.getOutput.then(val= >{
    console.log("child.getOutput = " + val);
})

getErrorOutput

getErrorOutput(): Promise

获取子进程的标准错误输出。

该接口为系统接口,三方应用不支持调用。

系统能力: SystemCapability.Utils.Lang

返回值:

类型说明
Promise异步返回标准错误输出的字节流。

示例:

var child = process.runCmd('madir test.text');
var result = child.wait();
child.getErrorOutput.then(val= >{
    console.log("child.getErrorOutput= " + val);
})

close

close(): void

关闭正在运行的子进程。

该接口为系统接口,三方应用不支持调用。

系统能力: SystemCapability.Utils.Lang

示例:

var child = process.runCmd('sleep 5; ls');
child.close();

kill

kill(signal: number | string): void

用于发送信号给子进程,结束指定进程。

该接口为系统接口,三方应用不支持调用。

系统能力: SystemCapability.Utils.Lang

参数

参数名类型必填说明
signalnumberstring

示例:

var child = process.runCmd('sleep 5; ls');
child.kill(9);

process.isIsolatedProcess8+

isIsolatedProcess(): boolean

判断进程是否被隔离。

系统能力: SystemCapability.Utils.Lang

返回值:

类型说明
boolean返回判断结果,如果返回true表示进程被隔离。

示例:

var result = process.isIsolatedProcess();

process.isAppUid8+

isAppUid(v: number): boolean

判断uid是否属于应用程序。

系统能力: SystemCapability.Utils.Lang

参数:

参数名类型必填说明
vnumber应用程序的uid。

返回值:

类型说明
boolean返回判断结果,如果返回true表示为应用程序的uid。

示例:

var result = process.isAppUid(688);

process.is64Bit8+

is64Bit(): boolean

判断运行环境是否64位。

系统能力: SystemCapability.Utils.Lang

返回值:

类型说明
boolean返回判断结果,如果返回true表示为64位环境。

示例:

var ressult = process.is64Bit();

process.getUidForName8+

getUidForName(v: string): number

通过进程名获取进程uid。

系统能力: SystemCapability.Utils.Lang

参数:

参数名类型必填说明
vstring进程名。

返回值:

类型说明
number返回进程uid。

示例:

var pres = process.getUidForName("tool")

process.getThreadPriority8+

getThreadPriority(v: number): number

根据指定的tid获取线程优先级。

系统能力: SystemCapability.Utils.Lang

参数:

参数名类型必填说明
vnumber指定的线程tid。

返回值:

类型说明
number返回线程的优先级。

示例:

var tid = process.getTid();
var pres = process.getThreadPriority(tid);

process.getStartRealtime8+

getStartRealtime(): number

获取从系统启动到进程启动所经过的实时时间(以毫秒为单位)。

系统能力: SystemCapability.Utils.Lang

返回值:

类型说明
number返回经过的实时时间。

示例:

var realtime = process.getStartRealtime();

process.getPastCpuTime8+

getPastCpuTime(): number

获取进程启动到当前时间的CPU时间(以毫秒为单位)。

系统能力: SystemCapability.Utils.Lang

返回值:

类型说明
number返回经过的CPU时间。

示例:

var result = process.getPastCpuTime() ;

process.getSystemConfig8+

getSystemConfig(name: number): number

获取系统配置信息。

系统能力: SystemCapability.Utils.Lang

参数:

参数名类型必填说明
namenumber指定系统配置参数名。

返回值:

类型说明
number返回系统配置信息。

示例:

var _SC_ARG_MAX = 0
var pres = process.getSystemConfig(_SC_ARG_MAX)

process.getEnvironmentVar8+

getEnvironmentVar(name: string): string

用该方法获取环境变量对应的值。

系统能力: SystemCapability.Utils.Lang

参数:

参数名类型必填说明
namestring环境变量名。

返回值:

类型说明
string返回环境变量名对应的value。

示例:

var pres = process.getEnvironmentVar("PATH")

process.runCmd

runCmd(command: string, options?: { timeout : number, killSignal : number | string, maxBuffer : number }): ChildProcess

通过runcmd可以fork一个新的进程来运行一段shell,并返回ChildProcess对象。

该接口为系统接口,三方应用不支持调用。

系统能力: SystemCapability.Utils.Lang

参数:

参数名类型必填说明
commandstringshell命令。
optionsObject相关选项参数。

表1 options

名称参数类型必填说明
timeoutnumber子进程运行的ms数,当子进程运行时间超出此时间,则父进程发送killSignal信号给子进程。timeout默认为0。
killSignalnumberstring
maxBuffernumber子进程标准输入输出的最大缓冲区大小,当超出此大小时则终止子进程。maxBuffer默认1024*1024。

返回值:

类型说明
[ChildProcess]子进程对象。

示例:

var child = process.runCmd('ls', { maxBuffer : 2 });
var result = child.wait();
child.getOutput.then(val= >{
    console.log("child.getOutput = " + val);
})

process.abort

abort(): void

该方法会导致进程立即退出并生成一个核心文件,谨慎使用。

系统能力: SystemCapability.Utils.Lang

示例:

process.abort();

process.on

on(type: string, listener: EventListener): void

存储用户所触发的事件。

该接口为系统接口,三方应用不支持调用。

系统能力: SystemCapability.Utils.Lang

参数:

参数名类型必填说明
typestring存储事件的type。
listenerEventListener回调的事件。

表2 EventListener

名称说明
EventListener = (evt: Object) => void用户存储的事件。

示例:

process.on("data", (e)= >{
    console.log("data callback");
})

process.off

off(type: string): boolean

删除用户存储的事件。

该接口为系统接口,三方应用不支持调用。

系统能力: SystemCapability.Utils.Lang

参数:

参数名类型必填说明
typestring删除事件的type。

返回值:

类型说明
boolean事件是否删除成功。

示例:

process.on("data", (e)= >{
    console.log("data callback");
})
var result = process.off("data");

process.exit

exit(code: number): void

终止程序。

请谨慎使用此接口。

系统能力: SystemCapability.Utils.Lang

参数:

参数名类型必填说明
codenumber进程的退出码。

示例:

process.exit(0);

process.cwd

cwd(): string

用该方法获取进程的工作目录。

该接口为系统接口,三方应用不支持调用。

系统能力: SystemCapability.Utils.Lang

示例:

var path = process.cwd();

process.chdir

chdir(dir: string): void

更改进程的当前工作目录。

该接口为系统接口,三方应用不支持调用。

系统能力: SystemCapability.Utils.Lang

参数:

参数名类型必填说明
dirstring路径。

示例:

process.chdir('/system');

process.uptime

uptime(): number

获取当前系统已运行的秒数。

系统能力: SystemCapability.Utils.Lang

返回值:

类型说明
number当前系统已运行的秒数。

示例:

var time = process.uptime();

process.kill

kill(signal: number, pid: number): boolean

发送signal到指定的进程,结束指定进程。

系统能力: SystemCapability.Utils.Lang

参数:

参数名类型必填说明
pidnumber进程的id。
signalnumber发送的信号。HarmonyOSOpenHarmony鸿蒙文档籽料:mau123789是v直接拿

QQ截图20240705211104.png

返回值:

类型说明
boolean信号是否发送成功。

示例:

var pres = process.pid
var result = that.kill(28, pres)

审核编辑 黄宇

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 鸿蒙
    +关注

    关注

    57

    文章

    2368

    浏览量

    42897
收藏 人收藏

    评论

    相关推荐

    OpenHarmony语言基础【@ohos.process (获取进程相关信息)】

    本模块首批接口从API version 7开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。
    的头像 发表于 04-24 15:52 739次阅读
    OpenHarmony<b class='flag-5'>语言</b>基础<b class='flag-5'>类</b><b class='flag-5'>库</b>【@<b class='flag-5'>ohos.process</b> (<b class='flag-5'>获取</b><b class='flag-5'>进程</b><b class='flag-5'>相关</b>的<b class='flag-5'>信息</b>)】

    鸿蒙OS跨进程IPC与RPC通信

    Proxy,便可通过Proxy实现与Stub的跨进程通信了。 相关步骤: ● 实现接口:需继承IRemoteBroker,需定义消息码,可声明不在此类实现的方法。 ● 实现服务提供端(Stub):需继承
    发表于 02-17 14:20

    ArkTS语言基础-解析

    ArkTS语言基础是HarmonyOS系统上为应用开发者提供的常用基础能力,主要包含能力如下图所示。 图1 ArkTS语言基础
    发表于 02-20 16:44

    鸿蒙原生应用开发-ArkTS语言基础概述

    ArkTS语言基础是HarmonyOS系统上为应用开发者提供的常用基础能力,主要包含能力如下图所示。 1.提供异步并发和多线程并发的能力。 支持Promise和async/await等标准
    发表于 03-05 15:42

    鸿蒙Flutter实战:14-现有Flutter 项目支持鸿蒙 II

    文件 .fvm/, vscode/settings.json 文件 ohos_app/pubsec.yaml 中的 dependency_overrides, 仅添加需要鸿蒙化的三方
    发表于 12-26 14:59

    HarmonyOS API Version 7版本特性说明

    2所示,包括Parcel、URL、编解码的能力。图2 基础新增接口@ohos.process提供进程信息查询能力以及对
    发表于 11-30 15:19

    HarmonyOS API Version 7版本特性说明

    2所示,包括Parcel、URL、编解码的能力。图2 基础新增接口@ohos.process提供进程信息查询能力以及对
    发表于 12-01 10:35

    OpenHarmony C++公共基础应用案例:Thread

    ; } 注意: OHOS::Thread会不断地调用Run()函数,所以该函数只需要写成单循环即可。 3.4.3、主程序 主程序每1秒打印子进程相关
    发表于 11-22 11:50

    HarmonyOS语言基础开发指南上线啦!

    语言基础提供哪些功能?多线程并发如何实现?TaskPool(任务池)和Worker在实现和使用场景上有何不同? 针对开发者关注的并发等语言基础
    的头像 发表于 10-18 16:20 592次阅读
    HarmonyOS<b class='flag-5'>语言</b>基础<b class='flag-5'>类</b><b class='flag-5'>库</b>开发指南上线啦!

    SDCardUtils封装应用:设备信息获取实现方法

    硬件名、SDK版本、android版本 、语言支持、默认语言 六、 获取 SD 卡存储信息 七、 获取手机 RAM、ROM存储
    的头像 发表于 11-13 09:40 789次阅读
    SDCardUtils封装<b class='flag-5'>类</b>应用:设备<b class='flag-5'>信息</b><b class='flag-5'>获取</b>实现方法

    鸿蒙OpenHarmony大合集:【语言基础

    本示例集合语言基础的各个子模块,展示了各个模块的基础功能
    的头像 发表于 04-29 16:38 594次阅读
    <b class='flag-5'>鸿蒙</b>OpenHarmony大合集:【<b class='flag-5'>语言</b>基础<b class='flag-5'>类</b><b class='flag-5'>库</b>】

    鸿蒙语言基础ohos.uitest UiTest测试

    UiTest提供模拟UI操作的能力,供开发者在测试场景使用,主要支持如点击、双击、长按、滑动等UI操作能力。
    的头像 发表于 07-12 17:38 535次阅读

    鸿蒙语言基础ohos.bytrace 性能打点

    用来标记一个预追踪的数值变量,该变量的数值会不断变化。
    的头像 发表于 07-18 15:41 272次阅读

    鸿蒙语言基础:system.configuration 应用配置

    获取应用当前的语言和地区。默认与系统的语言和地区同步。
    的头像 发表于 07-16 09:34 339次阅读

    鸿蒙语言基础:system.network 网络状态

    获取当前设备的网络类型。
    的头像 发表于 07-18 09:37 281次阅读