js-apis-process.md 10.6 KB
Newer Older
Z
zengyawen 已提交
1
# 获取进程相关的信息
Z
zengyawen 已提交
2

Z
zengyawen 已提交
3 4
> ![icon-note.gif](public_sys-resources/icon-note.gif) **说明:**
> 本模块首批接口从API version 7开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。
Z
zengyawen 已提交
5

Z
zengyawen 已提交
6 7

## 导入模块
Z
zengyawen 已提交
8 9 10 11 12

```
import process from '@ohos.process';
```

Z
zengyawen 已提交
13 14 15 16 17

## 属性

| 名称 | 类型 | 可读 | 可写 | 说明 |
| -------- | -------- | -------- | -------- | -------- |
Z
zengyawen 已提交
18 19 20 21 22 23 24 25
| egid | number | 是 | 否 | 进程的有效组标识。 |
| euid | number | 是 | 否 | 进程的有效用户身份。 |
| gid | number | 是 | 否 | 进程的组标识。 |
| uid | number | 是 | 否 | 进程的用户标识。 |
| groups | number[] | 是 | 否 | 带有补充组id的数组。 |
| pid | number | 是 | 否 | 当前进程的pid。 |
| ppid | number | 是 | 否 | 当前进程的父进程的pid。 |
| tid<sup>8+</sup> | number | 是 | 否 | 当前进程的tid。 |
Z
zengyawen 已提交
26 27 28


## ChildProcess
Z
zengyawen 已提交
29 30 31 32

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


Z
zengyawen 已提交
33
### 属性
Z
zengyawen 已提交
34

Z
zengyawen 已提交
35 36 37 38 39 40
| 名称 | 类型 | 可读 | 可写 | 说明 |
| -------- | -------- | -------- | -------- | -------- |
| pid | number | 是 | 否 | 子进程的pid。 |
| ppid | number | 是 | 否 | 子进程的父进程的pid。 |
| exitCode | number | 是 | 否 | 子进程的退出码。 |
| killed | boolean | 是 | 否 | 父进程给子进程发信号是否成功。 |
Z
zengyawen 已提交
41 42


Z
zengyawen 已提交
43
### wait
Z
zengyawen 已提交
44

Z
zengyawen 已提交
45
wait(): Promise&lt;number&gt;
Z
zengyawen 已提交
46

Z
zengyawen 已提交
47
等待子进程运行结束,返回promise对象,其值为子进程的退出码。
Z
zengyawen 已提交
48

Z
zengyawen 已提交
49 50 51 52
- 返回值:
  | 类型 | 说明 |
  | -------- | -------- |
  | Promise&lt;number&gt; | 异步返回子进程的退出码。 |
Z
zengyawen 已提交
53

Z
zengyawen 已提交
54 55 56 57 58 59 60 61
- 示例:
  ```
  var child = process.runCmd('ls');
  var result = child.wait();
  result.then(val=>{
      console.log("result = " + val);
  })
  ```
Z
zengyawen 已提交
62 63


Z
zengyawen 已提交
64
### getOutput
Z
zengyawen 已提交
65

Z
zengyawen 已提交
66 67 68
getOutput(): Promise&lt;Uint8Array&gt;

获取子进程的标准输出。
Z
zengyawen 已提交
69

Z
zengyawen 已提交
70 71 72 73
- 返回值:
  | 类型 | 说明 |
  | -------- | -------- |
  | Promise&lt;Uint8Array&gt; | 异步返回标准输出的字节流。 |
Z
zengyawen 已提交
74

Z
zengyawen 已提交
75 76 77 78 79 80 81 82
- 示例:
  ```
  var child = process.runCmd('ls');
  var result = child.wait();
  child.getOutput.then(val=>{
      console.log("child.getOutput = " + val);
  })
  ```
Z
zengyawen 已提交
83 84


Z
zengyawen 已提交
85
### getErrorOutput
Z
zengyawen 已提交
86

Z
zengyawen 已提交
87
getErrorOutput(): Promise&lt;Uint8Array&gt;
Z
zengyawen 已提交
88 89 90

getErrorOutput函数用来获取子进程的标准错误输出。

Z
zengyawen 已提交
91 92 93 94
- 返回值:
  | 类型 | 说明 |
  | -------- | -------- |
  | Promise&lt;Uint8Array&gt; | 异步返回标准错误输出的字节流。 |
Z
zengyawen 已提交
95

Z
zengyawen 已提交
96 97 98 99 100 101 102 103
- 示例:
  ```
  var child = process.runCmd('madir test.text');
  var result = child.wait();
  child.getErrorOutput.then(val=>{
      console.log("child.getErrorOutput= " + val);
  })
  ```
Z
zengyawen 已提交
104 105


Z
zengyawen 已提交
106
### close
Z
zengyawen 已提交
107

Z
zengyawen 已提交
108
close():  void
Z
zengyawen 已提交
109

Z
zengyawen 已提交
110
关闭正在运行的子进程。
Z
zengyawen 已提交
111

Z
zengyawen 已提交
112 113 114 115 116
- 示例:
  ```
  var child = process.runCmd('sleep 5; ls');
  child.close();
  ```
Z
zengyawen 已提交
117 118


Z
zengyawen 已提交
119
### kill
Z
zengyawen 已提交
120

Z
zengyawen 已提交
121
kill(signal: number | string): void
Z
zengyawen 已提交
122

Z
zengyawen 已提交
123
kill函数用来发送信号给子进程,结束指定进程。
Z
zengyawen 已提交
124

Z
zengyawen 已提交
125 126 127 128
- 参数:
  | 参数名 | 类型 | 必填 | 说明 |
  | -------- | -------- | -------- | -------- |
  | signal | number&nbsp;\|&nbsp;string | 是 | 数字或字符串。 |
Z
zengyawen 已提交
129

Z
zengyawen 已提交
130 131 132 133 134
- 示例:
  ```
  var child = process.runCmd('sleep 5; ls');
  child.kill(9);
  ```
Z
zengyawen 已提交
135 136


Z
zengyawen 已提交
137 138 139 140
## process.isIsolatedProcess<sup>8+</sup>

isIsolatedProcess(): boolean

141
判断进程是否被隔离。
Z
zengyawen 已提交
142 143 144 145

- 返回值:
  | 类型 | 说明 |
  | -------- | -------- |
146
  | boolean | 返回判断结果,如果返回true表示进程被隔离。 |
Z
zengyawen 已提交
147 148 149 150 151 152 153 154 155 156 157

- 示例:
  ```
  var result = process.isIsolatedProcess();
  ```


## process.isAppUid<sup>8+</sup>

isAppUid(v:number): boolean

158
判断uid是否属于应用程序。
Z
zengyawen 已提交
159 160 161 162

- 参数:
  | 参数名 | 类型 | 必填 | 说明 |
  | -------- | -------- | -------- | -------- |
163
  | v | number | 是 | 应用程序的uid。 |
Z
zengyawen 已提交
164 165 166 167

- 返回值:
  | 类型 | 说明 |
  | -------- | -------- |
168
  | boolean | 返回判断结果,如果返回true表示为应用程序的uid。|
Z
zengyawen 已提交
169 170 171 172 173 174 175 176 177 178 179

- 示例:
  ```
  var result = process.isAppUid(688);
  ```


## process.is64Bit<sup>8+</sup>

is64Bit(): boolean

180
判断运行环境是否64位。
Z
zengyawen 已提交
181 182 183 184

- 返回值:
  | 类型 | 说明 |
  | -------- | -------- |
185
  | boolean | 返回判断结果,如果返回true表示为64位环境。 |
Z
zengyawen 已提交
186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201

- 示例:
  ```
  var ressult = process.is64Bit();
  ```


## process.getUidForName<sup>8+</sup>

getUidForName(v:string): number

通过进程名获取进程uid。

- 参数:
  | 参数名 | 类型 | 必填 | 说明 |
  | -------- | -------- | -------- | -------- |
202
  | v | string | 是 | 进程名。 |
Z
zengyawen 已提交
203 204 205 206

- 返回值:
  | 类型 | 说明 |
  | -------- | -------- |
207
  | number | 返回进程uid。|
Z
zengyawen 已提交
208 209 210 211 212 213 214 215 216 217 218

- 示例:
  ```
  var pres = process.getUidForName("tool")
  ```


## process.getThreadPriority<sup>8+</sup>

getThreadPriority(v:number): number

219
根据指定的tid获取线程优先级。
Z
zengyawen 已提交
220 221 222 223

- 参数:
  | 参数名 | 类型 | 必填 | 说明 |
  | -------- | -------- | -------- | -------- |
224
  | v | number | 是 | 指定的线程tid。 |
Z
zengyawen 已提交
225 226 227 228

- 返回值:
  | 类型 | 说明 |
  | -------- | -------- |
229
  | number | 返回线程的优先级。 |
Z
zengyawen 已提交
230 231 232

- 示例:
  ```
Z
zengyawen 已提交
233
  var tid = process.getTid();
Z
zengyawen 已提交
234 235 236 237 238 239 240 241 242 243 244 245 246
  var pres = process.getThreadPriority(tid);
  ```


## process.getStartRealtime<sup>8+</sup>

getStartRealtime() :number

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

- 返回值:
  | 类型 | 说明 |
  | -------- | -------- |
247
  | number | 返回经过的实时时间。|
Z
zengyawen 已提交
248 249 250 251 252 253 254 255 256 257 258 259 260 261 262

- 示例:
  ```
  var realtime = process.getStartRealtime();
  ```

## process.getPastCputime<sup>8+</sup>

getPastCputime() :number

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

- 返回值:
  | 类型 | 说明 |
  | -------- | -------- |
263
  | number | 返回经过的CPU时间。 |
Z
zengyawen 已提交
264 265 266 267 268 269 270 271 272 273 274

- 示例:
  ```
  var result = process.getPastCputime() ;
  ```


## process.getSystemConfig<sup>8+</sup>

getSystemConfig(name:number): number

Z
zengyawen 已提交
275
获取系统配置信息。
Z
zengyawen 已提交
276 277 278 279

- 参数:
  | 参数名 | 类型 | 必填 | 说明 |
  | -------- | -------- | -------- | -------- |
280
  | name | number | 是 | 指定系统配置参数名。 |
Z
zengyawen 已提交
281 282 283 284

- 返回值:
  | 类型 | 说明 |
  | -------- | -------- |
285
  | number | 返回系统配置信息。 |
Z
zengyawen 已提交
286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302

- 示例:
  ```
  var _SC_ARG_MAX = 0
  var pres = process.getSystemConfig(_SC_ARG_MAX)
  ```


## process.getEnvironmentVar<sup>8+</sup>

getEnvironmentVar(name:string): string

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

- 参数:
  | 参数名 | 类型 | 必填 | 说明 |
  | -------- | -------- | -------- | -------- |
303
  | name | string | 是 | 环境变量名。 |
Z
zengyawen 已提交
304 305 306 307

- 返回值:
  | 类型 | 说明 |
  | -------- | -------- |
308
  | string | 返回环境变量名对应的value。 |
Z
zengyawen 已提交
309 310 311 312 313 314 315

- 示例:
  ```
  var pres = process.getEnvironmentVar("PATH")
  ```


Z
zengyawen 已提交
316 317 318
## process.runCmd

runCmd(command: string, options?: { timeout : number, killSignal :number | string, maxBuffer : number }) : ChildProcess
Z
zengyawen 已提交
319 320 321

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

Z
zengyawen 已提交
322 323 324 325 326
- 参数:
  | 参数名 | 类型 | 必填 | 说明 |
  | -------- | -------- | -------- | -------- |
  | command | string | 是 | shell命令。 |
  | options | Object | 否 | 相关选项参数。 |
Z
zengyawen 已提交
327

Z
zengyawen 已提交
328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346
  **表1** options
  
  | 名称 | 参数类型 | 必填 | 说明 |
  | -------- | -------- | -------- | -------- |
  | timeout | number | 否 | 子进程运行的ms数,当子进程运行时间超出此时间,则父进程发送killSignal信号给子进程。timeout默认为0。 |
  | killSignal | number&nbsp;&nbsp;\|&nbsp;string | 否 | 子进程运行时间超出timeout时,父进程发送killSignal&nbsp;信号给子进程。killSignal&nbsp;默认为'SIGTERM'。 |
  | maxBuffer | number | 否 | 子进程标准输入输出的最大缓冲区大小,当超出此大小时则终止子进程。maxBuffer默认1024\*1024。 |

- 返回值:
  | 类型 | 说明 |
  | -------- | -------- |
  | [ChildProcess](#childprocess) | 子进程对象。 |

- 示例:
  ```
  var child = process.runCmd('ls', { maxBuffer : 2 });
  var result = child.wait();
  child.getOutput.then(val=>{
      console.log("child.getOutput = " + val);
347
  })
Z
zengyawen 已提交
348 349 350 351
  ```


## process.abort
Z
zengyawen 已提交
352

Z
zengyawen 已提交
353
abort(): void
Z
zengyawen 已提交
354

Z
zengyawen 已提交
355 356 357 358 359 360
该方法会导致进程立即退出并生成一个核心文件,谨慎使用。

- 示例:
  ```
  process.abort();
  ```
Z
zengyawen 已提交
361 362


Z
zengyawen 已提交
363
## process.on
Z
zengyawen 已提交
364

Z
zengyawen 已提交
365
on(type: string, listener: EventListener): void
Z
zengyawen 已提交
366 367 368

用该方法来存储用户所触发的事件。

Z
zengyawen 已提交
369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391
- 参数:
  | 参数名 | 类型 | 必填 | 说明 |
  | -------- | -------- | -------- | -------- |
  | type | string | 是 | 存储事件的type。 |
  | listener | EventListener | 是 | 回调的事件。 |

  **表2** EventListener
  
  | 名称 | 说明 |
  | -------- | -------- |
  | EventListener&nbsp;=&nbsp;(evt:&nbsp;Object)&nbsp;=&gt;&nbsp;void | 用户存储的事件。 |

- 示例:
  ```
  process.on("data", (e)=>{
      console.log("data callback");
  })
  ```


## process.off

off(type: string): boolean
Z
zengyawen 已提交
392 393 394

用该方法来删除用户存储的事件。

Z
zengyawen 已提交
395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416
- 参数:
  | 参数名 | 类型 | 必填 | 说明 |
  | -------- | -------- | -------- | -------- |
  | type | string | 是 | 删除事件的type。 |

- 返回值:
  | 类型 | 说明 |
  | -------- | -------- |
  | boolean | 事件是否删除成功。 |

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


## process.exit

exit(code: number): void
Z
zengyawen 已提交
417 418 419

用该方法终止程序,谨慎使用。

Z
zengyawen 已提交
420 421 422 423
- 参数:
  | 参数名 | 类型 | 必填 | 说明 |
  | -------- | -------- | -------- | -------- |
  | code | number | 是 | 进程的退出码。 |
Z
zengyawen 已提交
424

Z
zengyawen 已提交
425 426 427 428 429 430 431 432 433
- 示例:
  ```
  process.exit(0);
  ```


## process.cwd

cwd(): string
Z
zengyawen 已提交
434

Z
zengyawen 已提交
435
用该方法获取进程的工作目录。
Z
zengyawen 已提交
436

Z
zengyawen 已提交
437 438 439 440
- 示例:
  ```
  var path = process.cwd();
  ```
Z
zengyawen 已提交
441 442


Z
zengyawen 已提交
443
## process.chdir
Z
zengyawen 已提交
444

Z
zengyawen 已提交
445
chdir(dir: string): void
Z
zengyawen 已提交
446 447 448

用该方法更改进程的当前工作目录。

Z
zengyawen 已提交
449 450 451 452
- 参数:
  | 参数名 | 类型 | 必填 | 说明 |
  | -------- | -------- | -------- | -------- |
  | dir | string | 是 | 路径。 |
Z
zengyawen 已提交
453

Z
zengyawen 已提交
454 455 456 457
- 示例:
  ```
  process.chdir('/system');
  ```
Z
zengyawen 已提交
458 459


Z
zengyawen 已提交
460
## process.uptime
Z
zengyawen 已提交
461

Z
zengyawen 已提交
462
uptime(): number
Z
zengyawen 已提交
463

Z
zengyawen 已提交
464
获取当前系统已运行的秒数。
Z
zengyawen 已提交
465

Z
zengyawen 已提交
466 467 468 469
- 返回值:
  | 类型 | 说明 |
  | -------- | -------- |
  | number | 当前系统已运行的秒数。 |
Z
zengyawen 已提交
470

Z
zengyawen 已提交
471 472 473 474
- 示例:
  ```
  var time = process.uptime();
  ```
Z
zengyawen 已提交
475 476


Z
zengyawen 已提交
477
## process.kill
Z
zengyawen 已提交
478

Z
zengyawen 已提交
479
kill(pid: number,signal: number ): boolean
Z
zengyawen 已提交
480

Z
zengyawen 已提交
481
用该方法发送signal到指定的进程,结束指定进程。
Z
zengyawen 已提交
482

Z
zengyawen 已提交
483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498
- 参数:
  | 参数名 | 类型 | 必填 | 说明 |
  | -------- | -------- | -------- | -------- |
  | pid | number | 是 | 进程的id。 |
  | signal | number | 是 | 发送的信号。 |

- 返回值:
  | 类型 | 说明 |
  | -------- | -------- |
  | boolean | 信号是否发送成功。 |

- 示例:
  ```
  var pres = process.pid
  var result = that.kill(pres, 28)
  ```