当前位置: 首页 > news >正文

【HarmonyOS NAPI 深度探索6】使用 N-API 创建第一个 Hello World 原生模块

【HarmonyOS NAPI 深度探索6】使用 N-API 创建第一个 Hello World 原生模块

开发一个 N-API 模块听起来可能有点技术感十足,但实际上入门并不复杂。今天,我们就来一步步实现一个简单的 Hello World 原生模块,感受一下 N-API 开发的魅力。

环境准备

在开始之前,请确保你已经安装了以下工具:

  1. Node.js:运行时环境,建议安装 LTS 版本。
  2. C++ 编译器:根据你的操作系统安装合适的编译器(如 Visual Studio Build Tools、Xcode 或 GCC)。
  3. node-gyp:通过 npm 安装,运行 npm install -g node-gyp 即可。

确保这些工具都已配置完成,你就可以着手开发了。

创建项目
  1. 创建一个新的项目文件夹:
    mkdir napi-hello-world
    cd napi-hello-world
    
  2. 初始化 Node.js 项目:
    npm init -y
    
    这会生成一个默认的 package.json 文件。
  3. 安装必要的依赖:
    npm install --save nan
    
配置构建工具

N-API 使用 node-gyp 来编译原生代码,因此需要创建一个 binding.gyp 文件。

  1. 在项目根目录下创建 binding.gyp 文件:
    {"targets": [{"target_name": "hello","sources": ["hello.cc"]}]
    }
    
    这里的 target_name 是模块的名字,sources 指定了 C++ 源文件。
编写 C++ 源代码

接下来,我们需要创建一个简单的 C++ 文件 hello.cc,实现 Hello World 功能。

  1. 创建 hello.cc 文件:

    #include <napi.h>Napi::String HelloWorld(const Napi::CallbackInfo& info) {return Napi::String::New(info.Env(), "Hello, HarmonyOS N-API!");
    }Napi::Object Init(Napi::Env env, Napi::Object exports) {exports.Set("hello", Napi::Function::New(env, HelloWorld));return exports;
    }NODE_API_MODULE(hello, Init)
    

    这段代码的核心逻辑是定义了一个返回字符串的函数 HelloWorld,并将其暴露给 Node.js 使用。

编译模块

使用 node-gyp 将上述代码编译成可运行的模块:

  1. 运行以下命令生成构建文件:
    node-gyp configure
    
  2. 执行编译:
    node-gyp build
    
    如果一切正常,你将在项目目录下看到一个 build/Release 文件夹,里面包含了编译生成的模块文件(如 hello.node)。
测试模块

我们可以通过一个简单的 JavaScript 文件测试刚刚创建的模块。

  1. 在项目根目录下创建 test.js 文件:

    const hello = require('./build/Release/hello');
    console.log(hello.hello());
    
  2. 运行测试文件:

    node test.js
    

    如果输出 Hello, HarmonyOS N-API!,恭喜你,原生模块开发成功了!

解析代码

让我们简单回顾一下代码的关键部分:

  1. Napi::String::New
    这是 N-API 提供的 API,用于创建一个 JavaScript 字符串对象。
  2. Napi::Object::Set
    用来将函数绑定到模块的导出对象中,以便在 JavaScript 中调用。
  3. NODE_API_MODULE
    宏定义模块的入口函数,告诉 Node.js 这个模块应该如何初始化。
扩展与提升

这个 Hello World 模块只是 N-API 的基础入门,接下来你可以尝试添加更多功能,比如:

  1. 接受参数并进行简单计算。
  2. 与操作系统进行交互(如文件系统、网络请求)。
  3. 集成现有的 C++ 库,扩展模块的功能。
    通过这些实践,你会更深入地理解 N-API 的强大之处,也为后续的 HarmonyOS 开发打下坚实基础。
http://www.lryc.cn/news/522101.html

相关文章:

  • Java语言的软件工程
  • 【Mysql进阶知识】Mysql 程序的介绍、选项在命令行配置文件的使用、选项在配置文件中的语法
  • wireshark抓路由器上的包 抓包路由器数据
  • 玩转大语言模型——使用graphRAG+Ollama构建知识图谱
  • python flask简单实践
  • JAVA实现五子棋小游戏(附源码)
  • kotlin的dagger hilt依赖注入
  • 速通Docker === 常用命令
  • 【redis】键的全局命令
  • 深度学习-卷积神经网络实战文档注释
  • GR2103高压半桥栅极驱动芯片
  • 学习threejs,使用OrbitControls相机控制器
  • 说说Babylon.js中scene.deltaTime的大坑
  • 【React】win系统环境搭建
  • ThinkPHP 8的一对一关联
  • Linux 下配置 Golang 环境
  • 爬虫后的数据处理与使用(使用篇--实现分类预测)
  • arcgis提取不规则栅格数据的矢量边界
  • python milvus 如何检查有多少个collection 以及多少个index,多少个database
  • 2006-2020年各省工业增加值数据
  • 【MySQL】使用C语言链接
  • Vue篇-07
  • 使用 LLaMA-Factory 微调大模型
  • 数据仓库的复用性:模型层面通用指标体系、参数化模型、版本化管理
  • Web APP 阶段性综述
  • 某国际大型超市电商销售数据分析和可视化
  • 电子杂志制作平台哪个好
  • Django Admin 实战:实现 ECS 集群批量同步功能
  • 虚拟拨号技术(GOIP|VOIP)【基于IP的语音传输转换给不法分子的境外来电披上一层外衣】: Voice over Internet Protocol
  • 迅为RK3576开发板Android 多屏显示