廣州短視頻制作公司seo網(wǎng)頁優(yōu)化服務(wù)
以double-conversion庫為例,其移植過程如下文所示。
源碼獲取
從倉庫獲取double-conversion源碼,其目錄結(jié)構(gòu)如下表:
表1?源碼目錄結(jié)構(gòu)
名稱 | 描述 |
---|---|
double-conversion/cmake/ | CMake組織編譯使用到的模板 |
double-conversion/double-conversion/ | 源文件目錄 |
double-conversion/msvc/ | - |
double-conversion/test/ | 測試用例源文件 |
double-conversion/.gitignore | - |
double-conversion/AUTHORS | - |
double-conversion/BUILD | - |
double-conversion/CMakeLists.txt | CMake方式頂層編譯組織文件 |
double-conversion/COPYING | - |
double-conversion/Changelog | - |
double-conversion/LICENSE | - |
double-conversion/Makefile | - |
double-conversion/README.md | - |
double-conversion/SConstruct | - |
double-conversion/WORKSPACE | - |
移植思路
移植思路:通過修改工具鏈,交叉編譯該三方庫,生成OpenHarmony平臺的可執(zhí)行文件,最后再通過GN調(diào)用CMake的方式添加到OpenHarmony工程中。
交叉編譯
編譯參考
代碼倉庫的README.md中詳細(xì)介紹了使用CMake編譯double-conversion庫的步驟,以及測試方法。本文參考該指導(dǎo)設(shè)置該庫的編譯配置,并完成測試。若開發(fā)人員在移植過程中對該庫的編譯選項配置有疑惑的地方,可參考該指導(dǎo)。對于其他使用CMake可獨立編譯的三方庫,在移植時可以參考其自帶的編譯指導(dǎo)。
設(shè)置執(zhí)行交叉編譯
CMake方式可通過指定工具鏈進(jìn)行交叉編譯,修改并編譯該庫,生成OpenHarmony平臺的可執(zhí)行文件,步驟如下:
-
設(shè)置工具鏈 將下列clang工具鏈配置添加到該工程的頂層CMakeLists.txt(即表1中的該文件)中即可。
set(CMAKE_CROSSCOMPILING TRUE) set(CMAKE_SYSTEM_NAME Generic) set(CMAKE_CXX_COMPILER_ID Clang) set(CMAKE_TOOLCHAIN_PREFIX llvm-) #指定c編譯工具(確保工具鏈所在路徑已經(jīng)添加到了PATH環(huán)境變量中)和編譯標(biāo)志,使用clang編譯時標(biāo)志中必須指定--target,否則無法交叉編譯。 set(CMAKE_C_COMPILER clang) set(CMAKE_C_FLAGS "--target=arm-liteos -D__clang__ -march=armv7-a -w -mfloat-abi=softfp -mcpu=cortex-a7 -mfpu=neon-vfpv4") #指定c++編譯工具(確保工具鏈所在路徑已經(jīng)添加到了PATH環(huán)境變量中)和編譯標(biāo)志,必須指定--target,否則無法交叉編譯。 set(CMAKE_CXX_COMPILER clang++) set(CMAKE_CXX_FLAGS "--target=arm-liteos -D__clang__ -march=armv7-a -w -mfloat-abi=softfp -mcpu=cortex-a7 -mfpu=neon-vfpv4") #指定鏈接工具和鏈接標(biāo)志,必須指定--target和--sysroot,其中OHOS_ROOT_PATH可通過cmake命令后綴參數(shù)來指定。 set(MY_LINK_FLAGS "--target=arm-liteos --sysroot=${OHOS_SYSROOT_PATH}") set(CMAKE_LINKER clang) set(CMAKE_CXX_LINKER clang++) set(CMAKE_C_LINKER clang) set(CMAKE_C_LINK_EXECUTABLE"${CMAKE_C_LINKER} ${MY_LINK_FLAGS} <FLAGS> <LINK_FLAGS> <OBJECTS> -o <TARGET> <LINK_LIBRARIES>") set(CMAKE_CXX_LINK_EXECUTABLE"${CMAKE_CXX_LINKER} ${MY_LINK_FLAGS} <FLAGS> <LINK_FLAGS> <OBJECTS> -o <TARGET> <LINK_LIBRARIES>") #指定鏈接庫的查找路徑。 set(CMAKE_SYSROOT ${OHOS_SYSROOT_PATH})
-
執(zhí)行編譯 linux命令行中進(jìn)入double-conversion的源文件目錄(即標(biāo)1所示目錄),執(zhí)行下列命令:
mkdir build && cd build cmake .. -DBUILD_TESTING=ON -DOHOS_SYSROOT_PATH="..." make -j
其中OHOS_SYSROOT_PATH需用絕對路徑指定出sysroot目錄的位置,以O(shè)penHarmony為例即目錄out/hispark_xxx/ipcamera_hispark_xxx/sysroot的絕對路徑。上述目錄會在全量編譯后生成,因此移植前先完成一次全量編譯。
-
查看結(jié)果 步驟2操作完成后,build目錄下會生成靜態(tài)庫文件和測試用例:
表2?編譯生成文件目錄結(jié)構(gòu)
名稱 描述 double-conversion/build/libdouble-conversion.a 生成的靜態(tài)庫文件 double-conversion/build/test/ 目錄下存放生成的測試用例和相關(guān)CMake緩存文件 double-conversion/build/CMakeCache.txt CMake構(gòu)建過程中的緩存文件 double-conversion/build/CMakeFiles/ - double-conversion/build/cmake_install.cmake - double-conversion/build/CTestTestfile.cmake - double-conversion/build/DartConfiguration.tcl - double-conversion/build/generated/ - double-conversion/build/Makefile - double-conversion/build/Testing/ -
測試
-
搭建OpenHarmony環(huán)境 以Hi3516DV300為例,編譯出OpenHarmony鏡像,燒寫到開發(fā)板,相關(guān)操作可參考快速入門小型系統(tǒng)部分。
進(jìn)入系統(tǒng)如下所示:
圖1?OpenHarmony啟動成功界面
-
掛載nfs目錄,將表2中test目錄下cctest可執(zhí)行文件放入nfs目錄
-
執(zhí)行用例 該庫采用非交叉編譯時用例是通過make test執(zhí)行,CMake會有相關(guān)的執(zhí)行結(jié)果統(tǒng)計;交叉編譯時無法使用該方法,因此可直接執(zhí)行生成的測試文件完成測試。
-
掛載成功后執(zhí)行下列命令可列出用例所有條目:
cd nfs ./cctest --list
上述命令執(zhí)行結(jié)果部分展示:
test-bignum/Assign< test-bignum/ShiftLeft< test-bignum/AddUInt64< test-bignum/AddBignum< test-bignum/SubtractBignum< test-bignum/MultiplyUInt32< test-bignum/MultiplyUInt64< test-bignum/MultiplyPowerOfTen< test-bignum/DivideModuloIntBignum< test-bignum/Compare< test-bignum/PlusCompare< test-bignum/Square< test-bignum/AssignPowerUInt16< test-bignum-dtoa/BignumDtoaVariousDoubles< test-bignum-dtoa/BignumDtoaShortestVariousFloats< test-bignum-dtoa/BignumDtoaGayShortest< test-bignum-dtoa/BignumDtoaGayShortestSingle< test-bignum-dtoa/BignumDtoaGayFixed< test-bignum-dtoa/BignumDtoaGayPrecision< test-conversions/DoubleToShortest< test-conversions/DoubleToShortestSingle< ...
-
以test-bignum條目為例,執(zhí)行下列命令開始測試:
./cctest test-bignum
測試結(jié)果如下則表示通過:
Ran 13 tests.
-
將該庫編譯添加到OpenHarmony工程中
-
復(fù)制庫到OpenHarmony工程中 拷貝已經(jīng)能夠成功交叉編譯的庫到OpenHarmony的third_party目錄,為了不修改要移植的三方庫目錄下的BUILD.gn文件,再添加一層目錄放置新增的gn轉(zhuǎn)CMake編譯適配文件,新增的文件有BUILD.gn、build_thirdparty.py、 config.gni,新增后的目錄結(jié)構(gòu)如下所示。
表3?添加到工程后的目錄結(jié)構(gòu)
名稱 描述 OpenHarmony/third_party/double-conversion/BUILD.gn 將三方庫加入工程的gn適配文件 OpenHarmony/third_party/double-conversion/build_thirdparty.py GN調(diào)用shell命令腳本文件,由上面GN文件將相關(guān)命令傳入,實現(xiàn)GN轉(zhuǎn)CMake OpenHarmony/third_party/double-conversion/config.gni 三方庫編譯配置文件,可修改該文件來配置用例是否參與構(gòu)建等 OpenHarmony/third_party/double-conversion/double-conversion/ 要移植的三方庫目錄 -
添加gn到CMake適配文件
-
新增的BUILD.gn文件實現(xiàn)如下,其他采用CMake方式可獨立編譯的三方庫移植到OpenHarmony平臺時只需修改路徑即可。
import("config.gni") group("double-conversion") {if (ohos_build_thirdparty_migrated_from_fuchisa == true) {deps = [":make"]} } if (ohos_build_thirdparty_migrated_from_fuchisa == true) {action("make") {script = "//third_party/double-conversion/build_thirdparty.py"outputs = ["$root_out_dir/log_dc.txt"]exec_path = rebase_path(rebase_path("./build", ohos_third_party_dir))command = "rm * .* -rf && $CMAKE_TOOLS_PATH/cmake .. $CMAKE_FLAG $CMAKE_TOOLCHAIN_FLAG && make -j"args = ["--path=$exec_path","--command=${command}"]} }
-
新增的config.gni用于配置該庫,實現(xiàn)如下,其他采用CMake方式可獨立編譯的三方庫移植到OpenHarmony時只需修改CMAKE_FLAG的配置即可。
#CMAKE_FLAG: config compile feature CMAKE_FLAG = "-DBUILD_TESTING=ON -DCMAKE_CXX_STANDARD=11"#toolchain:follow up-layer,depend on $ohos_build_compiler if (ohos_build_compiler == "clang") {CMAKE_TOOLCHAIN_FLAG = "-DOHOS_SYSROOT_PATH=${root_out_dir}sysroot" } else {CMAKE_TOOLCHAIN_FLAG = "" }#CMake tools path,no need setting if this path already joined to $PATH. CMAKE_TOOLS_PATH = "setting CMake tools path..."
-
新增的build_thirdparty.py實現(xiàn)如下,其他采用CMake方式可獨立編譯的三方庫移植到OpenHarmony時無需修改即可使用。
import os import sys from subprocess import Popen import argparse import shlexdef cmd_exec(command):cmd = shlex.split(command)proc = Popen(cmd)proc.wait()ret_code = proc.returncodeif ret_code != 0:raise Exception("{} failed, return code is {}".format(cmd, ret_code))def main():parser = argparse.ArgumentParser()parser.add_argument('--path', help='Build path.')parser.add_argument('--command', help='Build command.')parser.add_argument('--enable', help='enable python.', nargs='*')args = parser.parse_args()if args.enable:if args.enable[0] == 'false':returnif args.path:curr_dir = os.getcwd()os.chdir(args.path)if args.command:if '&&' in args.command:command = args.command.split('&&')for data in command:cmd_exec(data)else:cmd_exec(args.command)os.chdir(curr_dir)if __name__ == '__main__':sys.exit(main())
-
在配置文件中添加開關(guān)控制該庫編譯,默認(rèn)設(shè)為關(guān)閉
在//build/lite/ohos_var.gni文件中添加下列配置:
declare_args() {ohos_build_thirdparty_migrated_from_fuchisa = true}
-
-
編譯構(gòu)建 手動單獨構(gòu)建:
執(zhí)行下列命令
hb build -T //third_party/double-conversion:double-conversion
編譯成功則build目錄下會生成靜態(tài)庫文件和測試用例
最后
有很多小伙伴不知道學(xué)習(xí)哪些鴻蒙開發(fā)技術(shù)?不知道需要重點掌握哪些鴻蒙應(yīng)用開發(fā)知識點?而且學(xué)習(xí)時頻繁踩坑,最終浪費大量時間。所以有一份實用的鴻蒙(HarmonyOS NEXT)資料用來跟著學(xué)習(xí)是非常有必要的。?
這份鴻蒙(HarmonyOS NEXT)資料包含了鴻蒙開發(fā)必掌握的核心知識要點,內(nèi)容包含了(ArkTS、ArkUI開發(fā)組件、Stage模型、多端部署、分布式應(yīng)用開發(fā)、音頻、視頻、WebGL、OpenHarmony多媒體技術(shù)、Napi組件、OpenHarmony內(nèi)核、Harmony南向開發(fā)、鴻蒙項目實戰(zhàn)等等)鴻蒙(HarmonyOS NEXT)技術(shù)知識點。
希望這一份鴻蒙學(xué)習(xí)資料能夠給大家?guī)韼椭?#xff0c;有需要的小伙伴自行領(lǐng)取,限時開源,先到先得~無套路領(lǐng)取!!
獲取這份完整版高清學(xué)習(xí)路線,請點擊→純血版全套鴻蒙HarmonyOS學(xué)習(xí)資料
鴻蒙(HarmonyOS NEXT)最新學(xué)習(xí)路線
-
?HarmonOS基礎(chǔ)技能
- HarmonOS就業(yè)必備技能?
- ?HarmonOS多媒體技術(shù)
- 鴻蒙NaPi組件進(jìn)階
- HarmonOS高級技能
- 初識HarmonOS內(nèi)核?
- 實戰(zhàn)就業(yè)級設(shè)備開發(fā)
有了路線圖,怎么能沒有學(xué)習(xí)資料呢,小編也準(zhǔn)備了一份聯(lián)合鴻蒙官方發(fā)布筆記整理收納的一套系統(tǒng)性的鴻蒙(OpenHarmony )學(xué)習(xí)手冊(共計1236頁)與鴻蒙(OpenHarmony )開發(fā)入門教學(xué)視頻,內(nèi)容包含:ArkTS、ArkUI、Web開發(fā)、應(yīng)用模型、資源分類…等知識點。
獲取以上完整版高清學(xué)習(xí)路線,請點擊→純血版全套鴻蒙HarmonyOS學(xué)習(xí)資料
《鴻蒙 (OpenHarmony)開發(fā)入門教學(xué)視頻》
《鴻蒙生態(tài)應(yīng)用開發(fā)V2.0白皮書》
《鴻蒙 (OpenHarmony)開發(fā)基礎(chǔ)到實戰(zhàn)手冊》
OpenHarmony北向、南向開發(fā)環(huán)境搭建
?《鴻蒙開發(fā)基礎(chǔ)》
- ArkTS語言
- 安裝DevEco Studio
- 運用你的第一個ArkTS應(yīng)用
- ArkUI聲明式UI開發(fā)
- .……
?《鴻蒙開發(fā)進(jìn)階》
- Stage模型入門
- 網(wǎng)絡(luò)管理
- 數(shù)據(jù)管理
- 電話服務(wù)
- 分布式應(yīng)用開發(fā)
- 通知與窗口管理
- 多媒體技術(shù)
- 安全技能
- 任務(wù)管理
- WebGL
- 國際化開發(fā)
- 應(yīng)用測試
- DFX面向未來設(shè)計
- 鴻蒙系統(tǒng)移植和裁剪定制
- ……
《鴻蒙進(jìn)階實戰(zhàn)》
- ArkTS實踐
- UIAbility應(yīng)用
- 網(wǎng)絡(luò)案例
- ……
?獲取以上完整鴻蒙HarmonyOS學(xué)習(xí)資料,請點擊→純血版全套鴻蒙HarmonyOS學(xué)習(xí)資料
總結(jié)
總的來說,華為鴻蒙不再兼容安卓,對中年程序員來說是一個挑戰(zhàn),也是一個機會。只有積極應(yīng)對變化,不斷學(xué)習(xí)和提升自己,他們才能在這個變革的時代中立于不敗之地。?