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。
相关推荐
lili-felicity35 分钟前
React Native for OpenHarmony 实战:加载效果的实现详解
javascript·react native·react.js·harmonyos
哈哈你是真的厉害36 分钟前
React Native 鸿蒙跨平台开发:BaseConverter 进制转换
react native·react.js·harmonyos
奋斗的小青年!!1 小时前
Flutter跨平台开发:笔记分享功能适配OpenHarmony
flutter·harmonyos·鸿蒙
时光慢煮1 小时前
从踩坑到跑通:uni-app 项目落地 HarmonyOS 的完整实录(含模拟器 / 真机)
华为·uni-app·harmonyos
小雨青年1 小时前
我开发的鸿蒙原生应用【会议随记Pro】上架了
华为·harmonyos
威哥爱编程2 小时前
你的手势冲突解决了吗?鸿蒙事件拦截机制全解析
harmonyos·arkts·arkui
威哥爱编程2 小时前
鸿蒙异步并发 async/await 最佳实践,代码瞬间优雅
harmonyos·arkts·arkui
2501_948122632 小时前
React Native for OpenHarmony 实战:Steam 资讯 App 服务条款实现
javascript·react native·react.js·游戏·ecmascript·harmonyos
鸣弦artha3 小时前
Flutter 框架跨平台鸿蒙开发 —— Image Widget 占位符技术
flutter·华为·harmonyos
世人万千丶4 小时前
鸿蒙跨端框架Flutter学习day 2、常用UI组件-层叠布局 Stack & Positioned
学习·flutter·ui·实时互动·harmonyos·鸿蒙