【HarmonyOS Next NAPI 深度探索1】Node.js 和 CC++ 原生扩展简介

server/2025/1/12 7:48:53/

【HarmonyOS Next NAPI 深度探索1】Node.js 和 CC++ 原生扩展简介

如果你用过 Node.js,应该知道它强大的地方在于能处理各种场景,速度还很快。但你有没有想过,Node.js 的速度秘密是什么?今天我们来聊聊其中一个幕后英雄——原生扩展,特别是如何通过 C/C++ 把 JavaScript 的能力进一步放大。

原生扩展是什么

简单来说,原生扩展就是用 C/C++ 写的模块,能直接跟 Node.js 一起工作。它的核心作用是:

  1. 提升性能:当 JavaScript 在处理计算密集型任务(比如图像处理、音频编解码)时效率不高,就可以用原生扩展来加速。
  2. 调用底层系统功能:JavaScript 本身无法直接访问操作系统底层,但 C/C++ 可以。所以,通过扩展,我们能让 JavaScript 调用底层 API。
  3. 复用现有 C/C++ 库:很多高性能库是用 C/C++ 写的,比如 OpenCV(图像处理)或 FFmpeg(多媒体处理)。通过扩展,Node.js 开发者也能用上这些工具。

一句话,原生扩展就是给 JavaScript 装上了“超能力”。

为什么需要原生扩展

虽然 Node.js 非常高效,但它本质上是单线程的,处理大量计算时会比较吃力。举个例子:
场景 1:音频处理
假设你需要开发一个实时音频编辑器,纯用 JavaScript 写的话可能会卡顿,因为大量计算会占满主线程。用 C/C++ 写一个音频处理扩展,不仅速度更快,还能释放主线程去处理别的事情。

场景 2:设备驱动
想控制一些硬件,比如传感器或摄像头?JavaScript 可直接支持不了这些。但通过 C/C++ 写个驱动扩展,Node.js 也能轻松控制硬件。

这些都是原生扩展的用武之地。

Node.js 如何支持 C/C++ 原生扩展

Node.js 能支持原生扩展,主要靠两个工具:

  1. V8 引擎
    Node.js 使用了 Google 的 V8 引擎,它把 JavaScript 转成了机器码,同时提供了一套 C++ 接口(叫 V8 API),让开发者能用 C++ 操作 JavaScript 对象。
  2. N-API
    写原生扩展并不简单,直接用 V8 API 太麻烦。所以 Node.js 提供了一个更易用的接口——N-API,让我们可以更方便地用 C/C++ 开发扩展。

通过 N-API,你可以:

  • 用 C++ 写模块的核心逻辑
  • 把模块暴露给 JavaScript,让 JavaScript 调用你的扩展功能
原生扩展的应用场景

以下是几个常见场景,看看是不是跟你有关:

  • 高性能需求:如图片压缩、视频编码、数据加密
  • 硬件交互:如机器人控制、传感器数据采集
  • 跨语言桥接:用原生扩展把其他语言的功能带到 JavaScript,比如 Python 或 Rust
如何开始开发原生扩展

开发原生扩展需要几个前提:

  1. 安装 Node.js 和 C++ 编译器(比如 Windows 上用 MSVC,Linux 和 MacOS 用 GCC/Clang)
  2. 安装 node-gyp,它是编译扩展模块的工具
  3. 写一个简单的 C++ 文件,用 N-API 提供的接口暴露一个功能,比如打印 “Hello World”

代码看起来像这样:

#include <napi.h>Napi::String HelloWorld(const Napi::CallbackInfo& info) {Napi::Env env = info.Env();return Napi::String::New(env, "Hello World from C++!");
}Napi::Object Init(Napi::Env env, Napi::Object exports) {exports.Set(Napi::String::New(env, "helloWorld"), Napi::Function::New(env, HelloWorld));return exports;
}NODE_API_MODULE(hello, Init)

然后,通过 node-gyp 编译后,在 JavaScript 中可以这样调用:

const hello = require('./build/Release/hello');
console.log(hello.helloWorld()); // 输出: Hello World from C++!
总结

Node.js 和 C/C++ 原生扩展的结合,让我们可以突破 JavaScript 的性能瓶颈,甚至操作底层硬件。虽然开发过程稍微复杂些,但带来的性能提升和功能扩展绝对值得一试。如果你对高性能开发感兴趣,这是个很棒的领域。接下来,我们会讲解如何搭建开发环境,以及用 N-API 创建第一个模块,敬请期待!


http://www.ppmy.cn/server/157702.html

相关文章

CSS语言的网络编程

CSS语言的网络编程 引言 CSS&#xff08;Cascading Style Sheets&#xff0c;层叠样式表&#xff09;是一种用于描述HTML或XML文档外观样式的样式表语言。虽然CSS本身并不是一种编程语言&#xff0c;但它在网页设计和开发中发挥着至关重要的作用。随着互联网的发展&#xff0…

Postman接口测试04|批量运行测试用例、参数化、Mock Server、Cookie鉴权、Newman生成测试报告

目录 十一、Postman批量运行测试用例 十二、实现数据驱动&#xff08;也称参数化&#xff09; 1、csv文件 1️⃣编辑csv文件 2️⃣更新参数的值 3️⃣修改测试脚本和断言 5️⃣批量运行测试用例 2、Json文件 1️⃣编辑Json文件 2️⃣其他操作和处理csv文件相同 十三、…

Hypium UIViewer 让 MacOS 与鸿蒙NEXT手机实现多屏协同

鸿蒙工具之Hypium 一、前言二、认识 Hypium三、活用 Hypium 的 UIViewer 一、前言 上图呢&#xff0c;是我用华为平板和华为手机进行多屏协同时的界面。多屏协同的好处有很多&#xff0c;其中一个就是可以对手机上的显示页面&#xff0c;在电脑上直接进行截图&#xff0c;而不是…

后端技术选型 sa-token校验学习 下 结合项目学习 后端鉴权

目录 后端注册拦截器 实现对 WebMvcConfigurer 接口的类实现 静态变量 方法重写 注册 Spring Framework拦截器 Sa-Token中SaServletFilter拦截器 思考 为什么使用两个拦截器 1. Spring Framework 拦截器 2. SaServletFilter 为什么要注册两个拦截器&#xff1f; 总结 …

嵌入式系统Linux实时化(二)Xenomai技术框架分析

Xenomai 是 Linux 内核的一个实时开发框架。它希望通过无缝地集成到Linux 环境中来给用户空间应用程序提供全面的、与接口无关的硬实时性能。Xenomai 项目始于2001年8月&#xff0c;作为一个自由软件项目&#xff0c;完全遵守GNU/Linux自由软件协议。2003 年它和RTAI项目合并推…

Mybatis中 Dao接口和XML文件的SQL如何建立关联

建立连接工作&#xff08;准备&#xff09;: 首先会加载Myatis的配置文件&#xff0c;因为这些配置文件里面包括了数据源的各种配置&#xff0c;然后通过SqlSessionFactory创建一个SqlSession&#xff0c;然后可以通过SqlSession操作数据库。 一、解析XML: 首先&#xff0c;…

Android车机DIY开发之学习篇(二)编译Kernel以正点原子为例

Android车机DIY开发之学习篇(二)编译Kernel以正点原子为例 1.代码在/kernel-5.10文件夹下 2.在kernel-5.10目录下执行如下命令编译 &#xff1a; 编译之前&#xff0c;需要将 clang 导出到 PATH 环境变量&#xff1a; 如果是 Android12 执行下面这条命令 export PATH../pr…

doris:手动分区

分区列​ 分区列可以指定一列或多列&#xff0c;分区列必须为 KEY 列。PARTITION 列默认必须为 NOT NULL 列&#xff0c;如果需要使用 NULL 列&#xff0c;应设置 session variable allow_partition_column_nullable true。对于 LIST PARTITION&#xff0c;支持真正的 NULL 分…