news 2026/6/10 1:36:44

搭建鸿蒙PC命令行适配环境测试hello程序

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
搭建鸿蒙PC命令行适配环境测试hello程序

搭建鸿蒙PC命令行适配环境

    • 前言
    • 系统环境
      • windows系统搭建好hdc工具
      • wsl系统环境为Ubuntu 22.04
    • 配置鸿蒙sdk
      • 下载
      • 配置
      • 验证
    • 命令行hello工具
      • 编译
    • 运行hello程序
    • 其它

前言

鸿蒙PC命令行环境搭建,通常借助Ubuntu系统搭建交叉编译环境。这里借助windows系统的wsl完成。

系统环境

这里假定windows系统下的hdc工具已经可以使用,wsl的Ubuntu22.04已经配置成功。如果没有配置,搜索搭建一下。

windows系统搭建好hdc工具

wsl系统环境为Ubuntu 22.04

配置鸿蒙sdk

开源鸿蒙sdk的版本可以通过如下链接下载:
https://repo.huaweicloud.com/openharmony/os/
这里面有很多版本,最新的是6.0.0.1版本。也有根据自己需要下载里面的ohos-sdk-windows_linux-public.tar.gz
当然,也可以使用华为官网发布的command-line-tools for Linux。网址为:最新版本 - 下载中心 - 华为开发者联盟。

下载

这里以下载command-line-tools for Linux为例。

配置

搭建交叉编译环境,需要配置好环境变量,方便编译时使用。
wsl里面,打开~/.bashrc,配置如下环境变量,追加在文件最后面。

exportOHOS_SDK_HOME=$HOME/command-line-tools/sdk/default/openharmony# Native 编译器 (clang/cmake等)exportPATH=$OHOS_SDK_HOME/native/build-tools/cmake/bin:$PATHexportPATH=$OHOS_SDK_HOME/native/llvm/bin:$PATH

验证

重新导入一下.bashrc,使新增加的环境变量生效。

$source~/.bashrc

如果查看clang命令的版本,已经显示OHOS相关的信息,则表示环境变量已经生效。

$ clang --version OHOS(dev)clang version15.0.4(llvm-project 115b628d33dda4da4b17e14ed69dd8b74c058b48)Target: x86_64-unknown-linux-gnu Thread model: posix InstalledDir: /home/yan/command-line-tools/sdk/default/openharmony/native/llvm/bin

命令行hello工具

编译

简单代码如下:

#include <stdio.h> int main() { printf("Hello HarmonyOS from WSL Ubuntu 22.04!\n"); return 0; }

需要明确指定目标架构(Target)和系统根路径(Sysroot):

  • target:虽然常见的鸿蒙设备可能基于aarch64架构,但目标平台是鸿蒙 PC 模拟器,则应设置targetx86_64-linux-ohos,以匹配其x86_64架构和 OpenHarmony 操作系统环境。
  • sysroot:该参数用于告知编译器使用鸿蒙系统提供的头文件和库,而非主机(如 Ubuntu)自带的标准库。通过指定正确的 sysroot 路径,可确保编译出的程序与鸿蒙系统的运行时环境兼容。
$ clang --target=x86_64-linux-ohos --sysroot=$OHOS_SDK_HOME/native/sysroot -D_MUSL_ hello.c -o hello-x86

运行hello程序

模拟器环境是在windows系统上,通过搭建好的hdc工具,发送编译好的hello-x86程序到/data/local/tmp/目录。添加可执行权限,程序就可以运行了。

其它

在鸿蒙系统中,/data/local/tmp目录虽然可以临时存放可执行程序(例如一个简单的hello程序),且运行基本不受限制,但其权限非常受限。若程序功能较为复杂(如涉及系统调用、文件访问或网络通信等),这种方式往往无法满足需求。

此外,大多数为 Linux 重新适配的工具即使成功编译为 HNP(HarmonyOS Native Package)格式,也无法直接安装运行,必须进一步封装为 HAP(HarmonyOS Ability Package)并通过系统标准流程部署,才能获得必要的权限和运行环境

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 14:00:08

Lua 的 Coroutine(协程)模块

基本概念 Lua 的 Coroutine&#xff08;协程&#xff09;是一种轻量级的线程&#xff0c;它允许程序在单个线程中实现多个执行流的协作式调度。与操作系统线程不同&#xff0c;协程是完全由用户控制的&#xff0c;在用户态进行切换&#xff0c;不需要内核参与。 核心功能 创…

作者头像 李华
网站建设 2026/6/10 17:12:04

Flutter+DevEco Studio实战:简易天气查询工具开发指南

跨平台开发与HarmonyOS生态融合的趋势下&#xff0c;利用Flutter快速构建UI、DevEco Studio适配HarmonyOS设备的开发模式&#xff0c;能有效提升应用开发效率。本文将以“简易天气查询工具”为案例&#xff0c;详细讲解Flutter与DevEco Studio结合开发的全流程&#xff0c;涵盖…

作者头像 李华
网站建设 2026/6/10 16:50:00

基于Springboot一站式家装服务平台【附源码+文档】

&#x1f495;&#x1f495;作者&#xff1a; 米罗学长 &#x1f495;&#x1f495;个人简介&#xff1a;混迹java圈十余年&#xff0c;精通Java、小程序、数据库等。 &#x1f495;&#x1f495;各类成品Java毕设 。javaweb&#xff0c;ssm&#xff0c;springboot等项目&#…

作者头像 李华
网站建设 2026/6/10 17:26:09

基于Springboot养老保险管理系统【附源码+文档】

&#x1f495;&#x1f495;作者&#xff1a; 米罗学长 &#x1f495;&#x1f495;个人简介&#xff1a;混迹java圈十余年&#xff0c;精通Java、小程序、数据库等。 &#x1f495;&#x1f495;各类成品Java毕设 。javaweb&#xff0c;ssm&#xff0c;springboot等项目&#…

作者头像 李华
网站建设 2026/6/10 17:39:36

Windows游戏控制器虚拟化配置全攻略

Windows游戏控制器虚拟化配置全攻略 【免费下载链接】ViGEmBus 项目地址: https://gitcode.com/gh_mirrors/vig/ViGEmBus 在当今多元化的游戏环境中&#xff0c;玩家们常常面临一个令人困扰的技术难题&#xff1a;如何在Windows系统上实现不同品牌游戏控制器的完美兼容…

作者头像 李华