js-apis-process.md 16.4 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

## 属性

Z
zengyawen 已提交
16 17
**系统能力:** 以下各项对应的系统能力均为SystemCapability.Utils.Lang。

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


李_文强 已提交
30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229
## ProcessManager<sup>9+</sup>	

提供用于新增进程的抛异常接口。

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

isAppUid(v: number): boolean

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

**系统能力:** SystemCapability.Utils.Lang

**参数:**

| 参数名 | 类型 | 必填 | 说明 |
| -------- | -------- | -------- | -------- |
| v | number | 是 | 应用程序的uid。 |

**返回值:**

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

**示例:**

```js
let pro = new process.ProcessManager();
let result = pro.isAppUid(688);
```


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

getUidForName(v: string): number

通过进程名获取进程uid。

**系统能力:** SystemCapability.Utils.Lang

**参数:**

| 参数名 | 类型 | 必填 | 说明 |
| -------- | -------- | -------- | -------- |
| v | string | 是 | 进程名。 |

**返回值:**

| 类型 | 说明 |
| -------- | -------- |
| number | 返回进程uid。|

**示例:**

```js
let pro = new process.ProcessManager();
let pres = pro .getUidForName("tool");
```


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

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);
```


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

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);
```


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

getEnvironmentVar(name: string): string

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

**系统能力:** SystemCapability.Utils.Lang

**参数:**

| 参数名 | 类型 | 必填 | 说明 |
| -------- | -------- | -------- | -------- |
| name | string | 是 | 环境变量名。 |

**返回值:**

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

**示例:**

```js
let pro = new process.ProcessManager();
let pres = pro.getEnvironmentVar("PATH");
```


### process.exit<sup>9+</sup>

exit(code: number): void

终止程序。

请谨慎使用此接口。

**系统能力:** SystemCapability.Utils.Lang

**参数:**

| 参数名 | 类型 | 必填 | 说明 |
| -------- | -------- | -------- | -------- |
| code | number | 是 | 进程的退出码。 |

**示例:**

```js
let pro = new process.ProcessManager();
pro.exit(0);
```


### process.kill<sup>9+</sup>

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);
```


Z
zengyawen 已提交
230
## ChildProcess
Z
zengyawen 已提交
231 232 233

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

Z
zengyawen 已提交
234
### 属性
Z
zengyawen 已提交
235

Z
zengyawen 已提交
236 237
**系统能力:** 以下各项对应的系统能力均为SystemCapability.Utils.Lang。

Z
zengyawen 已提交
238 239
| 名称 | 类型 | 可读 | 可写 | 说明 |
| -------- | -------- | -------- | -------- | -------- |
240 241 242 243
| pid | number | 是 | 否 | 子进程的pid。该接口为系统接口,三方应用不支持调用。 |
| ppid | number | 是 | 否 | 子进程的父进程的pid。该接口为系统接口,三方应用不支持调用。 |
| exitCode | number | 是 | 否 | 子进程的退出码。该接口为系统接口,三方应用不支持调用。 |
| killed | boolean | 是 | 否 | 父进程给子进程发信号是否成功。该接口为系统接口,三方应用不支持调用。 |
Z
zengyawen 已提交
244 245


Z
zengyawen 已提交
246
### wait
Z
zengyawen 已提交
247

Z
zengyawen 已提交
248
wait(): Promise&lt;number&gt;
Z
zengyawen 已提交
249

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

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

Z
zengyawen 已提交
254 255
**系统能力:** SystemCapability.Utils.Lang

Z
zengyawen 已提交
256 257 258 259 260
**返回值:**

| 类型 | 说明 |
| -------- | -------- |
| Promise&lt;number&gt; | 异步返回子进程的退出码。 |
Z
zengyawen 已提交
261

Z
zengyawen 已提交
262 263
**示例:**

264
```js
265 266
let child = process.runCmd('ls');
let result = child.wait();
Z
zengyawen 已提交
267 268 269 270
result.then(val=>{
    console.log("result = " + val);
})
```
Z
zengyawen 已提交
271 272


Z
zengyawen 已提交
273
### getOutput
Z
zengyawen 已提交
274

Z
zengyawen 已提交
275 276 277
getOutput(): Promise&lt;Uint8Array&gt;

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

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

Z
zengyawen 已提交
281 282
**系统能力:** SystemCapability.Utils.Lang

Z
zengyawen 已提交
283
**返回值:**
Z
zengyawen 已提交
284

Z
zengyawen 已提交
285 286 287 288 289 290
| 类型 | 说明 |
| -------- | -------- |
| Promise&lt;Uint8Array&gt; | 异步返回标准输出的字节流。 |

**示例:**

291
```js
292 293
let child = process.runCmd('ls');
let result = child.wait();
S
shikai-123 已提交
294
child.getOutput().then(val=>{
Z
zengyawen 已提交
295 296 297
    console.log("child.getOutput = " + val);
})
```
Z
zengyawen 已提交
298 299


Z
zengyawen 已提交
300
### getErrorOutput
Z
zengyawen 已提交
301

Z
zengyawen 已提交
302
getErrorOutput(): Promise&lt;Uint8Array&gt;
Z
zengyawen 已提交
303

Z
zengyawen 已提交
304 305
获取子进程的标准错误输出。

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

Z
zengyawen 已提交
308
**系统能力:** SystemCapability.Utils.Lang
Z
zengyawen 已提交
309

Z
zengyawen 已提交
310 311 312 313 314
**返回值:**

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

Z
zengyawen 已提交
316 317
**示例:**

318
```js
319 320
let child = process.runCmd('madir test.text');
let result = child.wait();
S
shikai-123 已提交
321
child.getErrorOutput().then(val=>{
Z
zengyawen 已提交
322 323 324
    console.log("child.getErrorOutput= " + val);
})
```
Z
zengyawen 已提交
325 326


Z
zengyawen 已提交
327
### close
Z
zengyawen 已提交
328

X
xdmal 已提交
329
close(): void
Z
zengyawen 已提交
330

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

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

Z
zengyawen 已提交
335 336
**系统能力:** SystemCapability.Utils.Lang

Z
zengyawen 已提交
337 338
**示例:**

339
```js
340
let child = process.runCmd('sleep 5; ls');
Z
zengyawen 已提交
341 342
child.close();
```
Z
zengyawen 已提交
343 344


Z
zengyawen 已提交
345
### kill
Z
zengyawen 已提交
346

Z
zengyawen 已提交
347
kill(signal: number | string): void
Z
zengyawen 已提交
348

Z
zengyawen 已提交
349 350
用于发送信号给子进程,结束指定进程。

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

Z
zengyawen 已提交
353
**系统能力:** SystemCapability.Utils.Lang
Z
zengyawen 已提交
354

Z
zengyawen 已提交
355 356 357 358 359
**参数:**

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

Z
zengyawen 已提交
361 362
**示例:**

363
```js
364
let child = process.runCmd('sleep 5; ls');
Z
zengyawen 已提交
365 366
child.kill(9);
```
Z
zengyawen 已提交
367 368


Z
zengyawen 已提交
369 370 371 372
## process.isIsolatedProcess<sup>8+</sup>

isIsolatedProcess(): boolean

373
判断进程是否被隔离。
Z
zengyawen 已提交
374

Z
zengyawen 已提交
375 376
**系统能力:** SystemCapability.Utils.Lang

Z
zengyawen 已提交
377
**返回值:**
Z
zengyawen 已提交
378

Z
zengyawen 已提交
379 380 381 382 383 384
| 类型 | 说明 |
| -------- | -------- |
| boolean | 返回判断结果,如果返回true表示进程被隔离。 |

**示例:**

385
```js
386
let result = process.isIsolatedProcess();
Z
zengyawen 已提交
387
```
Z
zengyawen 已提交
388 389 390 391


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

X
xdmal 已提交
392
isAppUid(v: number): boolean
Z
zengyawen 已提交
393

394
判断uid是否属于应用程序。
Z
zengyawen 已提交
395

Z
zengyawen 已提交
396 397
**系统能力:** SystemCapability.Utils.Lang

Z
zengyawen 已提交
398 399 400 401 402 403 404
**参数:**

| 参数名 | 类型 | 必填 | 说明 |
| -------- | -------- | -------- | -------- |
| v | number | 是 | 应用程序的uid。 |

**返回值:**
Z
zengyawen 已提交
405

Z
zengyawen 已提交
406 407 408
| 类型 | 说明 |
| -------- | -------- |
| boolean | 返回判断结果,如果返回true表示为应用程序的uid。|
Z
zengyawen 已提交
409

Z
zengyawen 已提交
410 411
**示例:**

412
```js
413
let result = process.isAppUid(688);
Z
zengyawen 已提交
414
```
Z
zengyawen 已提交
415 416 417 418 419 420


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

is64Bit(): boolean

421
判断运行环境是否64位。
Z
zengyawen 已提交
422

Z
zengyawen 已提交
423 424
**系统能力:** SystemCapability.Utils.Lang

Z
zengyawen 已提交
425 426 427 428 429
**返回值:**

| 类型 | 说明 |
| -------- | -------- |
| boolean | 返回判断结果,如果返回true表示为64位环境。 |
Z
zengyawen 已提交
430

Z
zengyawen 已提交
431 432
**示例:**

433
```js
434
let result = process.is64Bit();
Z
zengyawen 已提交
435
```
Z
zengyawen 已提交
436 437 438 439


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

X
xdmal 已提交
440
getUidForName(v: string): number
Z
zengyawen 已提交
441 442 443

通过进程名获取进程uid。

Z
zengyawen 已提交
444 445
**系统能力:** SystemCapability.Utils.Lang

Z
zengyawen 已提交
446
**参数:**
Z
zengyawen 已提交
447

Z
zengyawen 已提交
448 449 450
| 参数名 | 类型 | 必填 | 说明 |
| -------- | -------- | -------- | -------- |
| v | string | 是 | 进程名。 |
Z
zengyawen 已提交
451

Z
zengyawen 已提交
452 453 454 455 456 457 458 459
**返回值:**

| 类型 | 说明 |
| -------- | -------- |
| number | 返回进程uid。|

**示例:**

460
```js
461
let pres = process.getUidForName("tool")
Z
zengyawen 已提交
462
```
Z
zengyawen 已提交
463 464 465 466


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

X
xdmal 已提交
467
getThreadPriority(v: number): number
Z
zengyawen 已提交
468

469
根据指定的tid获取线程优先级。
Z
zengyawen 已提交
470

Z
zengyawen 已提交
471 472
**系统能力:** SystemCapability.Utils.Lang

Z
zengyawen 已提交
473 474 475 476 477
**参数:**

| 参数名 | 类型 | 必填 | 说明 |
| -------- | -------- | -------- | -------- |
| v | number | 是 | 指定的线程tid。 |
Z
zengyawen 已提交
478

Z
zengyawen 已提交
479
**返回值:**
Z
zengyawen 已提交
480

Z
zengyawen 已提交
481 482 483 484 485 486
| 类型 | 说明 |
| -------- | -------- |
| number | 返回线程的优先级。 |

**示例:**

487
```js
488 489
let tid = process.tid;
let pres = process.getThreadPriority(tid);
Z
zengyawen 已提交
490
```
Z
zengyawen 已提交
491 492 493 494


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

X
xdmal 已提交
495
getStartRealtime(): number
Z
zengyawen 已提交
496 497 498

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

Z
zengyawen 已提交
499 500
**系统能力:** SystemCapability.Utils.Lang

Z
zengyawen 已提交
501
**返回值:**
Z
zengyawen 已提交
502

Z
zengyawen 已提交
503 504 505 506 507 508
| 类型 | 说明 |
| -------- | -------- |
| number | 返回经过的实时时间。|

**示例:**

509
```js
510
let realtime = process.getStartRealtime();
Z
zengyawen 已提交
511
```
Z
zengyawen 已提交
512

Z
zengyawen 已提交
513
## process.getPastCpuTime<sup>8+</sup>
Z
zengyawen 已提交
514

Z
zengyawen 已提交
515
getPastCpuTime(): number
Z
zengyawen 已提交
516 517 518

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

Z
zengyawen 已提交
519 520
**系统能力:** SystemCapability.Utils.Lang

Z
zengyawen 已提交
521 522 523 524 525 526 527
**返回值:**

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

**示例:**
Z
zengyawen 已提交
528

529
```js
530
let result = process.getPastCpuTime() ;
Z
zengyawen 已提交
531
```
Z
zengyawen 已提交
532 533 534 535


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

X
xdmal 已提交
536
getSystemConfig(name: number): number
Z
zengyawen 已提交
537

Z
zengyawen 已提交
538
获取系统配置信息。
Z
zengyawen 已提交
539

Z
zengyawen 已提交
540 541
**系统能力:** SystemCapability.Utils.Lang

Z
zengyawen 已提交
542 543 544 545 546
**参数:**

| 参数名 | 类型 | 必填 | 说明 |
| -------- | -------- | -------- | -------- |
| name | number | 是 | 指定系统配置参数名。 |
Z
zengyawen 已提交
547

Z
zengyawen 已提交
548
**返回值:**
Z
zengyawen 已提交
549

Z
zengyawen 已提交
550 551 552 553 554 555
| 类型 | 说明 |
| -------- | -------- |
| number | 返回系统配置信息。 |

**示例:**

556
```js
557 558
let _SC_ARG_MAX = 0
let pres = process.getSystemConfig(_SC_ARG_MAX)
Z
zengyawen 已提交
559
```
Z
zengyawen 已提交
560 561 562 563


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

X
xdmal 已提交
564
getEnvironmentVar(name: string): string
Z
zengyawen 已提交
565 566 567

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

Z
zengyawen 已提交
568 569
**系统能力:** SystemCapability.Utils.Lang

Z
zengyawen 已提交
570
**参数:**
Z
zengyawen 已提交
571

Z
zengyawen 已提交
572 573 574
| 参数名 | 类型 | 必填 | 说明 |
| -------- | -------- | -------- | -------- |
| name | string | 是 | 环境变量名。 |
Z
zengyawen 已提交
575

Z
zengyawen 已提交
576 577 578 579 580 581 582 583
**返回值:**

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

**示例:**

584
```js
585
let pres = process.getEnvironmentVar("PATH")
Z
zengyawen 已提交
586
```
Z
zengyawen 已提交
587 588


Z
zengyawen 已提交
589 590
## process.runCmd

591
runCmd(command: string, options?: { timeout?: number, killSignal?: number | string, maxBuffer?: number }): ChildProcess
Z
zengyawen 已提交
592 593 594

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

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

Z
zengyawen 已提交
597 598
**系统能力:** SystemCapability.Utils.Lang

Z
zengyawen 已提交
599 600 601 602 603 604 605 606 607 608 609 610
**参数:**

| 参数名 | 类型 | 必填 | 说明 |
| -------- | -------- | -------- | -------- |
| command | string | 是 | shell命令。 |
| options | Object | 否 | 相关选项参数。 |

**表1** options

| 名称 | 参数类型 | 必填 | 说明 |
| -------- | -------- | -------- | -------- |
| timeout | number | 否 | 子进程运行的ms数,当子进程运行时间超出此时间,则父进程发送killSignal信号给子进程。timeout默认为0。 |
611
| killSignal | number&nbsp;\|&nbsp;string | 否 | 子进程运行时间超出timeout时,父进程发送killSignal&nbsp;信号给子进程。killSignal&nbsp;默认为'SIGTERM'。 |
Z
zengyawen 已提交
612 613 614 615 616 617 618 619 620 621
| maxBuffer | number | 否 | 子进程标准输入输出的最大缓冲区大小,当超出此大小时则终止子进程。maxBuffer默认1024\*1024。 |

**返回值:**

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

**示例:**

622
```js
623 624
let child = process.runCmd('ls', { maxBuffer : 2 });
let result = child.wait();
Z
zengyawen 已提交
625 626 627 628
child.getOutput.then(val=>{
    console.log("child.getOutput = " + val);
})
```
Z
zengyawen 已提交
629 630 631


## process.abort
Z
zengyawen 已提交
632

Z
zengyawen 已提交
633
abort(): void
Z
zengyawen 已提交
634

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

Z
zengyawen 已提交
637 638
**系统能力:** SystemCapability.Utils.Lang

Z
zengyawen 已提交
639 640
**示例:**

641
```js
Z
zengyawen 已提交
642 643
process.abort();
```
Z
zengyawen 已提交
644 645


Z
zengyawen 已提交
646
## process.on
Z
zengyawen 已提交
647

Z
zengyawen 已提交
648
on(type: string, listener: EventListener): void
Z
zengyawen 已提交
649

Z
zengyawen 已提交
650 651
存储用户所触发的事件。

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

Z
zengyawen 已提交
654
**系统能力:** SystemCapability.Utils.Lang
Z
zengyawen 已提交
655

Z
zengyawen 已提交
656 657 658 659 660 661 662 663
**参数:**

| 参数名 | 类型 | 必填 | 说明 |
| -------- | -------- | -------- | -------- |
| type | string | 是 | 存储事件的type。 |
| listener | EventListener | 是 | 回调的事件。 |

**表2** EventListener
Z
zengyawen 已提交
664

Z
zengyawen 已提交
665 666
| 名称 | 说明 |
| -------- | -------- |
X
xdmal 已提交
667
| EventListener&nbsp;=&nbsp;(evt: &nbsp;Object)&nbsp;=&gt;&nbsp;void | 用户存储的事件。 |
Z
zengyawen 已提交
668

Z
zengyawen 已提交
669 670
**示例:**

671
```js
Z
zengyawen 已提交
672 673 674 675
process.on("data", (e)=>{
    console.log("data callback");
})
```
Z
zengyawen 已提交
676 677 678 679 680


## process.off

off(type: string): boolean
Z
zengyawen 已提交
681

Z
zengyawen 已提交
682 683
删除用户存储的事件。

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

Z
zengyawen 已提交
686
**系统能力:** SystemCapability.Utils.Lang
Z
zengyawen 已提交
687

Z
zengyawen 已提交
688
**参数:**
Z
zengyawen 已提交
689

Z
zengyawen 已提交
690 691 692
| 参数名 | 类型 | 必填 | 说明 |
| -------- | -------- | -------- | -------- |
| type | string | 是 | 删除事件的type。 |
Z
zengyawen 已提交
693

Z
zengyawen 已提交
694 695 696 697 698 699 700 701
**返回值:**

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

**示例:**

702
```js
Z
zengyawen 已提交
703 704 705
process.on("data", (e)=>{
    console.log("data callback");
})
706
let result = process.off("data");
Z
zengyawen 已提交
707
```
Z
zengyawen 已提交
708 709 710 711 712


## process.exit

exit(code: number): void
Z
zengyawen 已提交
713

Z
zengyawen 已提交
714 715 716 717 718
终止程序。

请谨慎使用此接口。

**系统能力:** SystemCapability.Utils.Lang
Z
zengyawen 已提交
719

Z
zengyawen 已提交
720
**参数:**
Z
zengyawen 已提交
721

Z
zengyawen 已提交
722 723 724 725 726 727
| 参数名 | 类型 | 必填 | 说明 |
| -------- | -------- | -------- | -------- |
| code | number | 是 | 进程的退出码。 |

**示例:**

728
```js
Z
zengyawen 已提交
729 730
process.exit(0);
```
Z
zengyawen 已提交
731 732 733 734 735


## process.cwd

cwd(): string
Z
zengyawen 已提交
736

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

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

Z
zengyawen 已提交
741 742
**系统能力:** SystemCapability.Utils.Lang

Z
zengyawen 已提交
743 744
**示例:**

745
```js
746
let path = process.cwd();
Z
zengyawen 已提交
747
```
Z
zengyawen 已提交
748 749


Z
zengyawen 已提交
750
## process.chdir
Z
zengyawen 已提交
751

Z
zengyawen 已提交
752
chdir(dir: string): void
Z
zengyawen 已提交
753

Z
zengyawen 已提交
754 755
更改进程的当前工作目录。

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

Z
zengyawen 已提交
758
**系统能力:** SystemCapability.Utils.Lang
Z
zengyawen 已提交
759

Z
zengyawen 已提交
760 761 762 763 764
**参数:**

| 参数名 | 类型 | 必填 | 说明 |
| -------- | -------- | -------- | -------- |
| dir | string | 是 | 路径。 |
Z
zengyawen 已提交
765

Z
zengyawen 已提交
766 767
**示例:**

768
```js
Z
zengyawen 已提交
769 770
process.chdir('/system');
```
Z
zengyawen 已提交
771 772


Z
zengyawen 已提交
773
## process.uptime
Z
zengyawen 已提交
774

Z
zengyawen 已提交
775
uptime(): number
Z
zengyawen 已提交
776

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

Z
zengyawen 已提交
779 780
**系统能力:** SystemCapability.Utils.Lang

Z
zengyawen 已提交
781 782 783 784 785
**返回值:**

| 类型 | 说明 |
| -------- | -------- |
| number | 当前系统已运行的秒数。 |
Z
zengyawen 已提交
786

Z
zengyawen 已提交
787 788
**示例:**

789
```js
790
let time = process.uptime();
Z
zengyawen 已提交
791
```
Z
zengyawen 已提交
792 793


Z
zengyawen 已提交
794
## process.kill
Z
zengyawen 已提交
795

S
shikai-123 已提交
796
kill(signal: number, pid: number): boolean
Z
zengyawen 已提交
797

Z
zengyawen 已提交
798 799 800
发送signal到指定的进程,结束指定进程。

**系统能力:** SystemCapability.Utils.Lang
Z
zengyawen 已提交
801

Z
zengyawen 已提交
802 803 804 805 806 807 808 809 810 811 812 813 814 815
**参数:**

| 参数名 | 类型 | 必填 | 说明 |
| -------- | -------- | -------- | -------- |
| pid | number | 是 | 进程的id。 |
| signal | number | 是 | 发送的信号。 |

**返回值:**

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

**示例:**
816 817

```js
818 819
let pres = process.pid
let result = process.kill(28, pres)
Z
zengyawen 已提交
820
```