HarmonyOS应用开发 - strip编译配置优先级

概述

文档环境

DevEco Studio 版本:DevEco Studio 6.0.0 Release(6.0.0.858)

SDK 版本:6.0.0 (API20)

功能简介

  • strip配置作用:是否移除 .so 文件中的符号表和调试信息,默认配置为true。
  • 在编译发布包时,应采用默认配置或设置为true,去除 so 库中的调试信息和符号表,显著减小 so 文件体积。
  • 在性能分析(如内存分析或耗时分析)场景中,必须将 strip 字段显式设置为 false。采集函数栈解析符号需要附带符号表信息,无符号表信息可能采集不到函数名称。
  • 本文中的配置以DevEco Studio 6.0.0 Release新建工程为例,帮助大家了解strip配置在不同位置的优先级。

strip编译配置优先级

基础配置

不区分Debug包和Release包,不区分Hap包和Har包,默认配置均为true。

javascript 复制代码
{
  "nativeLib": {
    "debugSymbol": {
      "strip": true
    }
  }
}

配置位置

  1. 工程级build-profile.json5中product的buildOption。
  1. 工程级build-profile.json5中buildModeSet的buildOption。
  1. 模块级build-profile.json5中公共buildOption。
  1. 模块级build-profile.json5中buildOptionSet。
  1. 模块级build-profile.json5中target的config中buildOption。

配置优先级

使用file命令查看so文件是否被stripped

strip: true

strip: false

测试不同位置的配置对最终配置的影响

|---------------|--------------------|-------------------|----------------------|--------------|------------|
| 工程级 product配置 | 工程级 buildModeSet配置 | 模块级 buildOption配置 | 模块级 buildOptionSet配置 | 模块级 target配置 | strip 最终配置 |
| 不配置 | 不配置 | 不配置 | 不配置 | 不配置 | true |
| false | 不配置 | 不配置 | 不配置 | 不配置 | false |
| true | false | 不配置 | 不配置 | 不配置 | true |
| false | true | 不配置 | 不配置 | 不配置 | false |
| 不配置 | false | true | 不配置 | 不配置 | true |
| 不配置 | true | false | 不配置 | 不配置 | false |
| 不配置 | 不配置 | false | 不配置 | 不配置 | false |
| 不配置 | 不配置 | false | true | 不配置 | true |
| 不配置 | 不配置 | false | true | false | false |
| 不配置 | true | false | true | false | false |
| 不配置 | true | false | true | 不配置 | true |
| 不配置 | false | false | true | 不配置 | true |
| false | false | false | true | 不配置 | true |
| true | true | true | false | 不配置 | false |
| true | true | true | true | false | false |

优先级

  1. 模块级target配置 > 模块级buildOptionSet配置> 模块级 buildOption配置 > 工程级product配置 > 工程级buildModeSet配置 。
  2. 构建Hap包时,不受依赖的Har包中的配置影响。
  3. 构建Hap包和Har包时,只读取所在模块级的build-profile.json5和工程级build-profile.json5。
相关推荐
lqj_本人1 小时前
鸿蒙PC:鸿蒙版本 Electron 框架环境搭建并且实现 XH 笔记应用
笔记·electron·harmonyos
不爱吃糖的程序媛1 小时前
特色软件 | 补齐 鸿蒙 PC 开发短板,Harmonybrew 的环境适配方案
华为·harmonyos
Python私教1 小时前
端侧 AIGC 进 App:HarmonyOS Data Augmentation Kit 实测复盘
华为·aigc·harmonyos
前端不太难2 小时前
如何优化鸿蒙 App 的启动速度?
华为·状态模式·harmonyos
想你依然心痛2 小时前
HarmonyOS 6(API 23)实战:基于悬浮导航、沉浸光感与HMAF的“译界智脑“——PC端AI智能体沉浸式智能翻译与跨语言协作工作台
人工智能·华为·ar·harmonyos
Python私教2 小时前
鸿蒙智能体框架 HMAF 上手:从 Agent 注册到 ArkTS 联调
华为·harmonyos
nashane2 小时前
HarmonyOS 6学习:外接键盘CapsLock键“失灵”?一招解锁大写输入
学习·华为·计算机外设·harmonyos
花先锋队长3 小时前
华为Pura X Max:细节制胜,3D互动空间引爆折叠屏市场
华为
cd_949217213 小时前
鸿蒙系统给抖音开启相机权限的操作指南(2026)
数码相机·华为·harmonyos