QuickJS 的核心概念和核心 API

1. JSRuntime

  • 定义JSRuntime 是一个 JavaScript 运行时环境,可以看作是一个 JavaScript 虚拟机实例。它提供了执行 JavaScript 代码所需的基础设施和功能,如内存管理、垃圾收集、事件循环等。

  • 作用

    • 提供全局的内存分配和管理功能。
    • 管理多个 JSContext,每个 JSContext 都属于一个 JSRuntime
    • 不同的 JSRuntime 之间是隔离的,不能相互调用和通信。
  • 创建

    cpp 复制代码
    JSRuntime *rt = JS_NewRuntime();
  • 销毁

    cpp 复制代码
    JS_FreeRuntime(rt);

2. JSContext

  • 定义JSContext 是一个 JavaScript 上下文环境,代表一个执行环境或 Realm。每个 JSContext 有自己的全局对象和系统对象。

  • 作用

    • 持有和管理当前运行的 JavaScript 代码的状态和变量。
    • 不同的 JSContext 可以共享对象,类似于浏览器中同源 iframe 之间共享 JavaScript 对象。
    • 一个 JSRuntime 可以有多个 JSContext,它们可以相互访问和共享对象。
  • 创建

    cpp 复制代码
    JSContext *ctx = JS_NewContext(rt);
  • 销毁

    cpp 复制代码
    JS_FreeContext(ctx);

3. 核心 API

  • JS_Eval

    • 作用:执行 JavaScript 脚本。

    • 示例

      cpp 复制代码
      const char *script = "console.log('hello quickjs')";
      JSValue result = JS_Eval(ctx, script, strlen(script), "main", 0);
    • 参数

      • ctx:执行脚本的上下文。
      • script:要运行的 JavaScript 脚本。
      • input_len:脚本长度。
      • filename:脚本文件名(可选)。
      • eval_flags:执行标志(如 JS_EVAL_TYPE_GLOBALJS_EVAL_TYPE_MODULE)。
  • JS_Call

    • 作用:调用 JavaScript 函数。

    • 示例

      cpp 复制代码
      JSValue fun_obj = JS_GetPropertyStr(ctx, global_obj, "myFunction");
      JSValue args[1] = { JS_NewInt32(ctx, 42) };
      JSValue result = JS_Call(ctx, fun_obj, global_obj, 1, args);
  • JS_NewObject

    • 作用:创建一个新的 JavaScript 对象。

    • 示例

      cpp 复制代码
      JSValue obj = JS_NewObject(ctx);
  • JS_SetPropertyStr

    • 作用:设置对象的属性。

    • 示例

      cpp 复制代码
      JS_SetPropertyStr(ctx, obj, "key", JS_NewString(ctx, "value"));
  • JS_GetPropertyStr

    • 作用:获取对象的属性。

    • 示例

      cpp 复制代码
      JSValue value = JS_GetPropertyStr(ctx, obj, "key");

4. 内存管理

  • JS_SetMemoryLimit

    • 作用:设置运行时的内存分配上限。

    • 示例

      cpp 复制代码
      JS_SetMemoryLimit(rt, 1024 * 1024 * 100); // 设置为 100 MB
  • JS_RunGC

    • 作用:运行垃圾回收器。

    • 示例

      cpp 复制代码
      JS_RunGC(ctx);

5. 异常处理

  • JS_GetException
    • 作用:获取异常对象。

    • 示例

      cpp 复制代码
      JSValue exception = JS_GetException(ctx);

6. 模块加载

  • JS_InitModule
    • 作用:初始化模块。

    • 示例

      cpp 复制代码
      JS_InitModule(ctx, "qjs:std");

示例代码

以下是一个完整的示例,展示如何使用 QuickJS 执行一段 JavaScript 脚本:

cpp 复制代码
#include "quickjs.h"

int main() {
    // 创建运行时
    JSRuntime *rt = JS_NewRuntime();
    // 创建上下文
    JSContext *ctx = JS_NewContext(rt);

    // 添加标准模块
    js_std_add_helpers(ctx, 0, NULL);
    js_init_module_std(ctx, "qjs:std");

    // 执行脚本
    const char *script = "console.log('hello quickjs')";
    JSValue result = JS_Eval(ctx, script, strlen(script), "main", 0);

    // 检查异常
    if (JS_IsException(result)) {
        JSValue exception = JS_GetException(ctx);
        printf("Exception: %s\n", JS_ToCString(ctx, exception));
        JS_FreeValue(ctx, exception);
    }

    // 释放资源
    JS_FreeValue(ctx, result);
    JS_FreeContext(ctx);
    JS_FreeRuntime(rt);

    return 0;
}

总结

  • JSRuntime 是整个 JavaScript 执行过程的基础,提供内存管理和垃圾回收等功能。
  • JSContext 是 JavaScript 代码执行的具体环境,每个上下文有自己的全局对象和系统对象。
  • 核心 API 提供了执行脚本、调用函数、创建对象、设置和获取属性等功能。
  • 内存管理异常处理 是运行时的重要组成部分,确保代码的稳定运行。
相关推荐
Larry_Yanan9 小时前
Qt多进程(一)进程间通信概括
开发语言·c++·qt·学习
Liu.77410 小时前
vue3使用vue3-print-nb打印
前端·javascript·vue.js
J ..10 小时前
C++ 多线程编程基础与 std::thread 使用
c++
你的冰西瓜10 小时前
C++标准模板库(STL)全面解析
开发语言·c++·stl
松涛和鸣10 小时前
Linux Makefile : From Basic Syntax to Multi-File Project Compilation
linux·运维·服务器·前端·windows·哈希算法
dly_blog11 小时前
Vue 逻辑复用的多种方案对比!
前端·javascript·vue.js
闻缺陷则喜何志丹11 小时前
【计算几何】仿射变换与齐次矩阵
c++·数学·算法·矩阵·计算几何
chen_ever11 小时前
Protobuf详解(从安装到实战)
c++·rpc·信息与通信
万少11 小时前
HarmonyOS6 接入分享,原来也是三分钟的事情
前端·harmonyos
烛阴11 小时前
C# 正则表达式:量词与锚点——从“.*”到精确匹配
前端·正则表达式·c#