国产亚洲精品福利在线无卡一,国产精久久一区二区三区,亚洲精品无码国模,精品久久久久久无码专区不卡

當(dāng)前位置: 首頁 > news >正文

廣州短視頻制作公司seo網(wǎng)頁優(yōu)化服務(wù)

廣州短視頻制作公司,seo網(wǎng)頁優(yōu)化服務(wù),青島建設(shè)項目環(huán)評公示網(wǎng)站,多渠道營銷系統(tǒng)以double-conversion庫為例,其移植過程如下文所示。 源碼獲取 從倉庫獲取double-conversion源碼,其目錄結(jié)構(gòu)如下表: 表1 源碼目錄結(jié)構(gòu) 名稱描述double-conversion/cmake/CMake組織編譯使用到的模板double-conversion/double-conversion/源…

以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.txtCMake方式頂層編譯組織文件
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í)行文件,步驟如下:

  1. 設(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})
  2. 執(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的絕對路徑。上述目錄會在全量編譯后生成,因此移植前先完成一次全量編譯。

  3. 查看結(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.txtCMake構(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/-

測試

  1. 搭建OpenHarmony環(huán)境 以Hi3516DV300為例,編譯出OpenHarmony鏡像,燒寫到開發(fā)板,相關(guān)操作可參考快速入門小型系統(tǒng)部分。

    進(jìn)入系統(tǒng)如下所示:

    圖1?OpenHarmony啟動成功界面

    zh-cn_image_0000001218806027

  2. 掛載nfs目錄,將表2中test目錄下cctest可執(zhí)行文件放入nfs目錄

  3. 執(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工程中

  1. 復(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.pyGN調(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/要移植的三方庫目錄
  2. 添加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}
  3. 編譯構(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í)和提升自己,他們才能在這個變革的時代中立于不敗之地。?

http://aloenet.com.cn/news/28492.html

相關(guān)文章:

  • 網(wǎng)站ui設(shè)計要點百度平臺營銷
  • 上海市建設(shè)安裝協(xié)會網(wǎng)站如何在百度發(fā)布廣告信息
  • logo智能設(shè)計一鍵生成器無憂seo博客
  • 西安電腦網(wǎng)站建設(shè)aso推廣平臺
  • 對網(wǎng)站設(shè)計的建議網(wǎng)絡(luò)推廣渠道和方式
  • 懷化做網(wǎng)站的公司怎么做關(guān)鍵詞排名靠前
  • 模擬網(wǎng)站建設(shè)對網(wǎng)絡(luò)營銷的認(rèn)識
  • 網(wǎng)站url改版線下營銷方式主要有哪些
  • 做那種網(wǎng)站賺錢廣州代運營公司有哪些
  • 做視頻網(wǎng)站 視頻放在哪里西安網(wǎng)頁設(shè)計
  • 不準(zhǔn)別人網(wǎng)站做反鏈好網(wǎng)站制作公司
  • 織夢網(wǎng)站如何做地區(qū)分站青島seo整站優(yōu)化招商電話
  • 重慶網(wǎng)站建設(shè)哪個公司好百度關(guān)鍵詞搜索量
  • wordpress模板用法深圳百度網(wǎng)站排名優(yōu)化
  • h5如何做多頁面網(wǎng)站愛站查詢
  • 網(wǎng)頁設(shè)計技能證書怎么考寧波如何做抖音seo搜索優(yōu)化
  • 做網(wǎng)站需要學(xué)那幾個軟件whois查詢 站長工具
  • 蘭溪做網(wǎng)站seo優(yōu)化工作內(nèi)容做什么
  • 品牌宣傳型網(wǎng)站構(gòu)成營銷策劃與運營公司
  • 網(wǎng)站開發(fā)有沒有前途12345微信公眾號
  • 站長統(tǒng)計向日葵app下載百度推廣投訴熱線
  • 東莞網(wǎng)站建設(shè)公司中國企業(yè)500強
  • 購物網(wǎng)站制作流程關(guān)鍵詞查找
  • 打開網(wǎng)頁時網(wǎng)站頂部顯示廣告隨后消失的廣告怎么做seo專員崗位要求
  • 整站優(yōu)化方案網(wǎng)站優(yōu)化技巧
  • 園區(qū)門戶網(wǎng)站建設(shè)方案大型網(wǎng)站seo課程
  • app那個網(wǎng)站開發(fā)比較好內(nèi)部搜索引擎優(yōu)化
  • 網(wǎng)站可以叫做系統(tǒng)嗎企業(yè)培訓(xùn)課程
  • 蘇州公司網(wǎng)站seo外鏈推廣員
  • 空間鏈接制作網(wǎng)站百度推廣中心