1# @ohos.app.ability.ChildProcessArgs
2
3传递到子进程的参数。[childProcessManager](js-apis-app-ability-childProcessManager.md)启动子进程时,可以通过ChildProcessArgs传递参数到子进程中。
4
5> **说明:**
6>
7> 本模块首批接口从API version 12开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。
8>
9> 本模块接口仅可在Stage模型下使用。
10
11## 导入模块
12
13```ts
14import { ChildProcessArgs } from '@kit.AbilityKit';
15```
16
17## 属性
18
19**系统能力**:SystemCapability.Ability.AbilityRuntime.Core
20
21| 名称        | 类型                    | 必填 | 说明                                                         |
22| ----------- | --------------------   | ---- | ------------------------------------------------------------ |
23| entryParams | string                 |  否  | 开发者自定义参数,透传到子进程中。可以在[ChildProcess.onStart](js-apis-app-ability-childProcess.md#childprocessonstart)方法中通过args.entryParams获取,entryParams支持传输的最大数据量为150KB。|
24| fds         | Record<string, number> |  否  | 文件描述符句柄集合,用于主进程和子进程通信,通过key-value的形式传入到子进程中,其中key为自定义字符串,value为文件描述符句柄。可以在[ChildProcess.onStart](js-apis-app-ability-childProcess.md#childprocessonstart)方法中通过args.fds获取fd句柄。<br/><b>说明:</b> <br>- fds最多支持16组,每组key的最大长度为20字符。<br>- 传递到子进程中句柄数字可能会变,但是指向的文件是一致的。|
25
26**示例:**
27
28示例中的context的获取方式请参见[获取UIAbility的上下文信息](../../application-models/uiability-usage.md#获取uiability的上下文信息)。
29
30```ts
31// 主进程中:
32import { common, ChildProcessArgs, childProcessManager } from '@kit.AbilityKit';
33import fs from '@ohos.file.fs';
34
35let context = getContext(this) as common.UIAbilityContext;
36let path = context.filesDir + "/test.txt";
37let file = fs.openSync(path, fs.OpenMode.READ_ONLY | fs.OpenMode.CREATE);
38let args: ChildProcessArgs = {
39  entryParams: "testParam",
40  fds: {
41    "key1": file.fd
42  }
43};
44childProcessManager.startArkChildProcess("entry/./ets/process/DemoProcess.ets", args);
45```
46
47```ts
48// 子进程中:
49import { ChildProcess, ChildProcessArgs } from '@kit.AbilityKit';
50
51export default class DemoProcess extends ChildProcess {
52
53  onStart(args?: ChildProcessArgs) {
54    let entryParams = args?.entryParams;
55    let fd = args?.fds?.key1;
56    // ..
57  }
58}
59```
60