一个NApi的Hello World

当然可以,以下是一个简单的N-API示例,它创建了一个名为"hello" 的本地模块,该模块包含一个名为"hello" 的函数,当调用时会返回字符串 "Hello, world!"。

首先,你需要创建一个新的Node.js项目,然后在项目目录中创建一个名为hello.c 的文件,文件内容如下:

c

arduino 复制代码
#include <node_api.h>

// 这是一个简单的N-API函数,它返回一个字符串 "Hello, world!"
napi_value Hello(napi_env env, napi_callback_info info) {
  napi_value greeting;
  napi_status status;

  // 创建一个新的JavaScript字符串值
  status = napi_create_string_utf8(env, "Hello, world!", NAPI_AUTO_LENGTH, &greeting);
  if (status != napi_ok) return NULL;

  return greeting;
}

// 初始化函数,用于设置N-API函数和模块导出
napi_value Init(napi_env env, napi_value exports) {
  napi_status status;
  napi_value fn;

  // 创建一个新的函数对象
  status = napi_create_function(env, NULL, 0, Hello, NULL, &fn);
  if (status != napi_ok) return NULL;

  // 设置导出的属性(即模块返回的函数)
  status = napi_set_named_property(env, exports, "hello", fn);
  if (status != napi_ok) return NULL;

  return exports;
}

// 定义模块,指定初始化函数
NAPI_MODULE(NODE_GYP_MODULE_NAME, Init)

然后,在同一目录下创建一个名为binding.gyp 的文件,文件内容如下:

json

json 复制代码
{
  "targets": [
    {
      "target_name": "hello",
      "sources": [ "hello.c" ]
    }
  ]
}

接着,你需要编译这个模块。在终端中执行以下命令:

sh

复制代码
npm install -g node-gyp
node-gyp configure
node-gyp build

最后,在项目目录中创建一个名为index.js 的文件,文件内容如下:

javascript

ini 复制代码
const hello = require('./build/Release/hello.node');

console.log(hello.hello()); // 应该输出 "Hello, world!"

现在,你可以通过运行 node index.js 来测试你的N-API模块,如果一切正常,你应该会在控制台看到输出 "Hello, world!"。

请注意,这个示例假设你已经安装了Node.js和node-gyp。如果你遇到任何问题,请确保你的开发环境已经正确配置,包括安装了所有必要的编译器和工具链。

相关推荐
独行soc10 小时前
2026年渗透测试面试题总结-20(题目+回答)
android·网络·安全·web安全·渗透测试·安全狮
Lionel68910 小时前
鸿蒙Flutter跨平台开发:首页特惠推荐模块的实现
华为·harmonyos
盐焗西兰花10 小时前
鸿蒙学习实战之路-Reader Kit自定义页面背景最佳实践
学习·华为·harmonyos
果粒蹬i10 小时前
【HarmonyOS】DAY10:React Native开发应用品质升级:响应式布局与用户体验优化实践
华为·harmonyos·ux
常利兵10 小时前
2026年,Android开发已死?不,它正迎来黄金时代!
android
Risehuxyc10 小时前
备份三个PHP程序
android·开发语言·php
早點睡39010 小时前
基础入门 React Native 鸿蒙跨平台开发:react-native-flash-message 消息提示三方库适配
react native·react.js·harmonyos
早點睡39011 小时前
高级进阶 ReactNative for Harmony项目鸿蒙化三方库集成实战:react-native-image-picker(打开手机相册)
react native·react.js·harmonyos
早點睡39011 小时前
基础入门 React Native 鸿蒙跨平台开发:react-native-easy-toast三方库适配
react native·react.js·harmonyos
前端不太难11 小时前
在 HarmonyOS 上,游戏状态该怎么“死而复生”
游戏·状态模式·harmonyos