# 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 ```