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

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

【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.lryc.cn/news/520262.html

相关文章:

  • redis的学习(四)
  • C# winform 多线程 UI更新数据 报错:无法访问已释放的对象。
  • error: linker `link.exe` not found
  • Vue.js组件开发-如何使用moment.js
  • Linux第二课:LinuxC高级 学习记录day01
  • 《DOM NodeList》
  • Nginx代理同域名前后端分离项目的完整步骤
  • uniapp页面高度设置(铺满可视区域、顶部状态栏高度、底部导航栏高度)
  • 解锁 RAG 技术:从原理、论文研读走向实战应用RAG
  • HTML5实现好看的中秋节网页源码
  • 数字孪生笔记 1 工业数字孪生的意义
  • 013:深度学习之神经网络
  • 计算机网络(四)网络层
  • 【ArcGIS微课1000例】0138:ArcGIS栅格数据每个像元值转为Excel文本进行统计分析、做图表
  • Linux 中统计进程的线程数 | 查看进程的线程
  • 【深度学习 】训练过程中loss出现nan
  • Linux - 什么是线程和线程的操作
  • windows及linux 安装 Yarn 4.x 版本
  • 如何设计一个 RPC 框架?需要考虑哪些点?
  • 初学stm32 --- DAC输出三角波和正弦波
  • 开源cJson用法
  • 【学习笔记】理解深度学习和机器学习的数学基础:数值计算
  • 如何使用CSS让页面文本两行显示,超出省略号表示
  • likeshop同城跑腿系统likeshop回收租赁系统likeshop多商户商城安装及小程序对接方法
  • C# 与 Windows API 交互的“秘密武器”:结构体和联合体
  • PHP 使用 Redis
  • 嵌入式系统Linux实时化(四)Xenomai应用开发测试
  • 26个开源Agent开发框架调研总结(2)
  • Element UI与Element Plus:深度剖析
  • 二、BIO、NIO编程与直接内存、零拷贝