# bootstrap服务启动组件
- [接口说明](#section1633115419401)
- [开发实例](#section2055311316228)
bootstrap服务启动组件实现了服务的自动初始化,即服务的初始化函数无需显式调用,而是将其使用宏定义的方式申明,就会在系统启动时自动被执行。实现原理是将服务启动的函数通过宏申明之后,放在预定义好的zInit代码段中,系统启动的时候调用OHOS\_SystemInit接口,遍历该代码段并调用其中的函数。因此,需要在链接脚本中添加zInit段,并且在main函数里调用OHOS\_SystemInit接口。
zInit段的添加可参考已有的Hi3861平台的链接脚本,文件路径为vendor/hisi/hi3861/hi3861/build/link/link.ld.S。
用于实现服务的自动初始化的宏定义接口请参见启动恢复子系统的[API接口文档](https://device.harmonyos.com/cn/docs/develop/apiref/init-0000001054598113)。
## 接口说明
bootstrap服务启动:
**表 1** 主要的服务自动初始化宏
接口名
|
描述
|
SYS_SERVICE_INIT(func)
|
标识核心系统服务的初始化启动入口。
|
SYS_FEATURE_INIT(func)
|
标识核心系统功能的初始化启动入口。
|
APP_SERVICE_INIT(func)
|
标识应用层服务的初始化启动入口。
|
APP_FEATURE_INIT(func)
|
标识应用层功能的初始化启动入口。
|
## 开发实例
服务自动初始化宏使用实例:
```
void SystemServiceInit(void) {
printf("Init System Service\n");
}
SYS_SERVICE_INIT(SystemServiceInit);
void SystemFeatureInit(void) {
printf("Init System Feature\n");
}
SYS_FEATURE_INIT(SystemFeatureInit);
void AppServiceInit(void) {
printf("Init App Service\n");
}
APP_SERVICE_INIT(AppServiceInit);
void AppFeatureInit(void) {
printf("Init App Feature\n");
}
APP_FEATURE_INIT(AppFeatureInit);
// 日志的打印顺序为:
// Init System Service
// Init System Feature
// Init App Service
// Init App Feature
```