单页网站seo优化/seo自动点击排名
本文所有描述均参考鸿蒙官方文档:传送门
1.对C库的支持
C标准函数库在C语言程序设计中,提供符合标准的头文件,以及常用的库函数实现(如I/O输入输出和字符串控制)。
HarmonyOS采用musl作为C标准库,musl库是一个轻量,快速,简单,免费的开源libc库,详细介绍参考musl官方参考手册。
musl与glibc的差异点请参考musl与glibc功能对比。
标准C库组件介绍
libc、libm、libdl组合实现C11标准C库。
libc:包含线程相关接口,以及大部分标准接口。
libm:数学库函数接口,当前在HarmonyOS中是一个链接,实际都在libc中定义。
libdl:dlopen等动态链接器接口,当前在HarmonyOS中是一个链接,实际都在libc中定义。
musl版本号
1.2.0
从HarmonyOS4.0开始,版本升级到1.2.3
从HarmonyOS5.0开始,版本升级到1.2.5
支持的能力
提供兼容C99,C11,POSIX标准的头文件,以及库函数接口,但不是完全兼容;支持armv7a,arm64, x86_64三种架构的支持;
为了更好的适配HarmonyOS设备的高性能,低内存,高安全,轻量化,支持多种形态设备的基本特征;在musl开源库的基础上进行了优化,增强,对不适用嵌入式设备的接口进行了裁剪。
2.对C++库的支持
HarmonyOS使用llvm开源项目的C++标准库libc++作为C++运行时库。
libc++版本
从HarmonyOS 4.0开始,libc++升级到clang/llvm 15.0.4版本
从HarmonyOS 3.2开始,libc++升级到clang/llvm 12.0.1版本
从HarmonyOS 3.0开始,libc++使用clang/llvm 10.0.1版本
C++语言支持能力
C++11、C++14标准已完全支持,C++17和C++20标准正在完善。具体语言特性支持标准可以参考“libc++” C++ Standard Library — libc++ documentation网站对应的Release Notes。
如何在CMake中选择C++
在NDK的{ndk_root}/build/cmake/ohos.toolchain.cmake文件中,定义了OHOS_STL变量,可以通过设置"c++_shared"或者"c++_static"来控制应用工程中原生库链接C++运行库的方式。
- c++_shared,原生库动态链接libc++_shared.so
- c++_static,原生库静态链接libc++_static.a
3.对NAPI支持
已从Node-API组件标准库中导出的符号列表
从Node-API标准库导出的接口,其使用方法及行为基于Node.js,并进行了部分能力拓展。
符号类型 | 符号名 | 说明 | 起始支持API版本 |
FUNC | napi_module_register | napi native模块注册接口。 | 10 |
FUNC | napi_get_last_error_info | 获取napi_extended_error_info结构体,其中包含最近一次出现的error信息。 | 10 |
FUNC | napi_throw | 抛出一个js value。 | 10 |
FUNC | napi_throw_error | 抛出一个带文本信息的js Error。 | 10 |
FUNC | napi_throw_type_error | 抛出一个带文本信息的js TypeError。 | 10 |
FUNC | napi_throw_range_error | 抛出一个带文本信息的js RangeError。 | 10 |
FUNC | napi_is_error | 判断napi_value是否表示为一个error对象。 | 10 |
FUNC | napi_create_error | 创建并获取一个带文本信息的js Error。 | 10 |
FUNC | napi_create_type_error | 创建并获取一个带文本信息的js TypeError。 | 10 |
FUNC | napi_create_range_error | 创建并获取一个带文本信息的js RangeError。 | 10 |
FUNC | napi_get_and_clear_last_exception | 获取并清除最近一次出现的异常。 | 10 |
FUNC | napi_is_exception_pending | 判断是否出现了异常。 | 10 |
FUNC | napi_fatal_error | 引发致命错误以立即终止进程。 | 10 |
FUNC | napi_open_handle_scope | 创建一个上下文环境使用。 | 10 |
FUNC | napi_close_handle_scope | 关闭传入的上下文环境,关闭后,全部在其中声明的引用都将被关闭。 | 10 |
FUNC | napi_open_escapable_handle_scope | 创建出一个可逃逸的handel scope,可将范围内声明的值返回到父作用域。 | 10 |
FUNC | napi_close_escapable_handle_scope | 关闭传入的可逃逸的handel scope。 | 10 |
FUNC | napi_escape_handle | 提升传入的js object的生命周期到其父作用域。 | 10 |
FUNC | napi_create_reference | 为Object创建一个reference,以延长其生命周期。调用者需要自己管理reference生命周期。 | 10 |
FUNC | napi_delete_reference | 删除传入的reference。 | 10 |
FUNC | napi_reference_ref | 增加传入的reference的引用计数,并获取该计数。 | 10 |
FUNC | napi_reference_unref | 减少传入的reference的引用计数,并获取该计数。 | 10 |
FUNC | napi_get_reference_value | 获取与reference相关联的js Object。 | 10 |
FUNC | napi_create_array | 创建并获取一个js Array。 | 10 |
FUNC | napi_create_array_with_length | 创建并获取一个指定长度的js Array。 | 10 |
FUNC | napi_create_arraybuffer | 创建并获取一个指定大小的js ArrayBuffer。 | 10 |
FUNC | napi_create_external | 分配一个附加有外部数据的js value。 | 10 |
FUNC | napi_create_external_arraybuffer | 分配一个附加有外部数据的js ArrayBuffer。 | 10 |
FUNC | napi_create_object | 创建一个默认的js Object。 | 10 |
FUNC | napi_create_symbol | 创建一个js Symbol。 | 10 |
FUNC | napi_create_typedarray | 通过现有的ArrayBuffer创建一个js TypeArray。 | 10 |
FUNC | napi_create_dataview | 通过现有的ArrayBuffer创建一个js DataView。 | 10 |
FUNC | napi_create_int32 | 通过一个C的int32_t数据创建js Number。 | 10 |
FUNC | napi_create_uint32 | 通过一个C的uint32_t数据创建js Number。 | 10 |
FUNC | napi_create_int64 | 通过一个C的int64_t数据创建js Number。 | 10 |
FUNC | napi_create_double | 通过一个C的double数据创建js Number。 | 10 |
FUNC | napi_create_string_latin1 | 通过ISO-8859-1编码的C字符串数据创建js String。 | 10 |
FUNC | napi_create_string_utf8 | 通过UTF8编码的C字符串数据创建js String。 | 10 |
FUNC | napi_create_string_utf16 | 通过UTF16编码的C字符串数据创建js String。 | 10 |
FUNC | napi_get_array_length | 获取array的length。 | 10 |
FUNC | napi_get_arraybuffer_info | 获取ArrayBuffer的底层data buffer及其长度。 | 10 |
FUNC | napi_get_prototype | 获取给定js Object的prototype。 | 10 |
FUNC | napi_get_typedarray_info | 获取给定TypedArray的各种属性。 | 10 |
FUNC | napi_get_dataview_info | 获取给定DataView的各种属性。 | 10 |
FUNC | napi_get_value_bool | 获取给定js Boolean对应的C bool值。 | 10 |
FUNC | napi_get_value_double | 获取给定js Number对应的C double值。 | 10 |
FUNC | napi_get_value_external | 获取先前通过napi_create_external()传递的外部数据指针。 | 10 |
FUNC | napi_get_value_int32 | 获取给定js Number对应的C int32值。 | 10 |
FUNC | napi_get_value_int64 | 获取给定js Number对应的C int64值。 | 10 |
FUNC | napi_get_value_string_latin1 | 获取给定js vaule对应的ISO-8859-1编码的字符串。 | 10 |
FUNC | napi_get_value_string_utf8 | 获取给定js vaule对应的UTF8编码的字符串。 | 10 |
FUNC | napi_get_value_string_utf16 | 获取给定js vaule对应的UTF16编码的字符串。 | 10 |
FUNC | napi_get_value_uint32 | 获取给定js Number对应的C uint32值。 | 10 |
FUNC | napi_get_boolean | 根据给定的C boolean值,获取js bool对象。 | 10 |
FUNC | napi_get_global | 获取global对象。 | 10 |
FUNC | napi_get_null | 获取null对象。 | 10 |
FUNC | napi_get_undefined | 获取undefined对象。 | 10 |
FUNC | napi_coerce_to_bool | 将给定的js value强转成js Boolean。 | 10 |
FUNC | napi_coerce_to_number | 将给定的js value强转成js Number。 | 10 |
FUNC | napi_coerce_to_object | 将给定的js value强转成js Object。 | 10 |
FUNC | napi_coerce_to_string | 将给定的js value强转成js String。 | 10 |
FUNC | napi_typeof | 获取给定js value的js type。 | 10 |
FUNC | napi_instanceof | 判断给定object是否为给定constructor的实例。 | 10 |
FUNC | napi_is_array | 判断给定js value是否为array。 | 10 |
FUNC | napi_is_arraybuffer | 判断给定js value是否为ArrayBuffer。 | 10 |
FUNC | napi_is_typedarray | 判断给定js value是否表示一个TypedArray。 | 10 |
FUNC | napi_is_dataview | 判断给定js value是否表示一个DataView。 | 10 |
FUNC | napi_is_date | 判断给定js value是否为js Date对象。 | 10 |
FUNC | napi_strict_equals | 判断给定的两个js value是否严格相等。 | 10 |
FUNC | napi_get_property_names | 以字符串数组的形式获取对象的可枚举属性的名称。 | 10 |
FUNC | napi_set_property | 对给定Object设置属性。 | 10 |
FUNC | napi_get_property | 获取给定Object的给定属性。 | 10 |
FUNC | napi_has_property | 判断给定对象中是否存在给定属性。 | 10 |
FUNC | napi_delete_property | 尝试从给定Object中删除给定key属性。 | 10 |
FUNC | napi_has_own_property | 判断给定Object中是否有名为key的own property。 | 10 |
FUNC | napi_set_named_property | 对给定Object设置一个给定名称的属性。 | 10 |
FUNC | napi_get_named_property | 获取给定Object中指定名称的属性。 | 10 |
FUNC | napi_has_named_property | 判断给定Object中是否有给定名称的属性。 | 10 |
FUNC | napi_set_element | 在给定Object的指定索引处,设置元素。 | 10 |
FUNC | napi_get_element | 获取给定Object指定索引处的元素。 | 10 |
FUNC | napi_has_element | 若给定Object的指定索引处拥有属性,获取该元素。 | 10 |
FUNC | napi_delete_element | 尝试删除给定Object的指定索引处的元素。 | 10 |
FUNC | napi_define_properties | 批量的向给定Object中定义属性。 | 10 |
FUNC | napi_type_tag_object | 将tag指针的值与Object关联。 | 10 |
FUNC | napi_check_object_type_tag | 判断给定的tag指针是否被关联到了js Object上。 | 10 |
FUNC | napi_call_function | 在Native方法中调用js function,即native call js。 | 10 |
FUNC | napi_create_function | 创建native方法给js使用,以便于js call native。 | 10 |
FUNC | napi_get_cb_info | 从给定的callback info中获取有关调用的详细信息,如参数和this指针。 | 10 |
FUNC | napi_get_new_target | 获取构造函数调用的new.target。 | 10 |
FUNC | napi_new_instance | 通过给定的构造函数,构建一个实例。 | 10 |
FUNC | napi_define_class | 定义与C++类相对应的JavaScript类。 | 10 |
FUNC | napi_wrap | 在js object上绑定一个native对象实例。 | 10 |
FUNC | napi_unwrap | 从js object上获取先前绑定的native对象实例。 | 10 |
FUNC | napi_remove_wrap | 从js object上获取先前绑定的native对象实例,并解除绑定。 | 10 |
FUNC | napi_create_async_work | 创建一个异步工作对象。 | 10 |
FUNC | napi_delete_async_work | 释放先前创建的异步工作对象。 | 10 |
FUNC | napi_queue_async_work | 将异步工作对象加到队列,由底层去调度执行。 | 10 |
FUNC | napi_cancel_async_work | 取消入队的异步任务。 | 10 |
FUNC | napi_async_init | 创建一个异步资源上下文环境(不支持与async_hook相关能力)。 | 11 |
FUNC | napi_make_callback | 在异步资源上下文环境中回调JS函数(不支持与async_hook相关能力)。 | 11 |
FUNC | napi_async_destroy | 销毁先前创建的异步资源上下文环境(不支持与async_hook相关能力)。 | 11 |
FUNC | napi_open_callback_scope | 创建一个回调作用域(不支持与async_hook相关能力)。 | 11 |
FUNC | napi_close_callback_scope | 关闭先前创建的回调作用域(不支持与async_hook相关能力)。 | 11 |
FUNC | napi_get_node_version | 获取node的版本信息。 | 10 |
FUNC | napi_get_version | 获取Node运行时支持的最高 N-API 版本。 | 10 |
FUNC | napi_create_promise | 创建一个延迟对象和js promise。 | 10 |
FUNC | napi_resolve_deferred | resolve与js promise对象关联的延迟函数。 | 10 |
FUNC | napi_reject_deferred | reject与js promise对象关联的延迟函数。 | 10 |
FUNC | napi_is_promise | 判断给定js value是否为promise对象。 | 10 |
FUNC | napi_get_uv_event_loop | 获取当前libuv loop实例。 | 10 |
FUNC | napi_create_threadsafe_function | 创建线程安全函数。 | 10 |
FUNC | napi_get_threadsafe_function_context | 获取线程安全函数中的context。 | 10 |
FUNC | napi_call_threadsafe_function | 调用线程安全函数。 | 10 |
FUNC | napi_acquire_threadsafe_function | 指示线程安全函数可以开始使用。 | 10 |
FUNC | napi_release_threadsafe_function | 指示线程安全函数将停止使用。 | 10 |
FUNC | napi_ref_threadsafe_function | 指示在主线程上运行的事件循环在线程安全函数被销毁之前不应退出。 | 10 |
FUNC | napi_unref_threadsafe_function | 指示在主线程上运行的事件循环可能会在线程安全函数被销毁之前退出。 | 10 |
FUNC | napi_create_date | 通过一个C的double数据创建js Date。 | 10 |
FUNC | napi_get_date_value | 获取给定js Date对应的C double值。 | 10 |
FUNC | napi_create_bigint_int64 | 通过一个C的int64数据创建js BigInt。 | 10 |
FUNC | napi_create_bigint_uint64 | 通过一个C的uint64数据创建js BigInt。 | 10 |
FUNC | napi_create_bigint_words | 通过一个C的uint64数组创建单个js BigInt。 | 10 |
FUNC | napi_get_value_bigint_int64 | 获取给定js BigInt对应的C int64值。 | 10 |
FUNC | napi_get_value_bigint_uint64 | 获取给定js BigInt对应的C uint64值。 | 10 |
FUNC | napi_get_value_bigint_words | 获取给定js BigInt对应的信息,包括符号位、64位小端序数组和数组中的元素个数。 | 10 |
FUNC | napi_create_buffer | 创建并获取一个指定大小的js Buffer。 | 10 |
FUNC | napi_create_buffer_copy | 创建并获取一个指定大小的js Buffer,并以给定数据进行初始化。 | 10 |
FUNC | napi_create_external_buffer | 创建并获取一个指定大小的js Buffer,并以给定数据进行初始化,该接口可为Buffer附带额外数据。 | 10 |
FUNC | napi_get_buffer_info | 获取js Buffer底层data及其长度。 | 10 |
FUNC | napi_is_buffer | 判断给定js value是否为Buffer对象。 | 10 |
FUNC | napi_object_freeze | 冻结给定的对象。 | 10 |
FUNC | napi_object_seal | 密封给定的对象。 | 10 |
FUNC | napi_get_all_property_names | 获取一个数组,其中包含此对象过滤后的属性名称。 | 10 |
FUNC | napi_detach_arraybuffer | 分离给定ArrayBuffer的底层数据。 | 10 |
FUNC | napi_is_detached_arraybuffer | 判断给定的ArrayBuffer是否已被分离过。 | 10 |
FUNC | napi_run_script | 将给定对象作为js代码运行。当前接口实际为空实现,可使用系统拓展接口napi_run_script_path接口,提升安全性。 | 10 |
FUNC | napi_set_instance_data | 绑定与当前运行的环境相关联的数据项。 | 11 |
FUNC | napi_get_instance_data | 检索与当前运行的环境相关联的数据项。 | 11 |
FUNC | napi_add_env_cleanup_hook | 注册环境清理钩子函数。 | 11 |
FUNC | napi_remove_env_cleanup_hook | 取消环境清理钩子函数。 | 11 |
FUNC | napi_add_async_cleanup_hook | 注册清理异步钩子函数。 | 11 |
FUNC | napi_remove_async_cleanup_hook | 取消清理异步钩子函数。 | 11 |
FUNC | node_api_get_module_file_name | 用于获取加载项加载位置的绝对路径。 | 11 |
FUNC | napi_add_finalizer | 当js Object中的对象被垃圾回收时调用注册的napi_finalize回调。 | 11 |
FUNC | napi_fatal_exception | 向js抛出 UncaughtException。 | 12 |
未从Node-API组件标准库中导出的符号列表
符号类型 | 符号名 | 说明 |
FUNC | napi_adjust_external_memory | 调整js Object持有的外部内存。 |
Node-API组件扩展的符号列表
符号类型 | 符号名 | 说明 | 起始支持API版本 |
FUNC | napi_queue_async_work_with_qos | 将异步工作对象加到队列,由底层根据传入的qos优先级去调度执行。 | 10 |
FUNC | napi_run_script_path | 运行abc文件。 | 10 |
FUNC | napi_load_module | 将abc文件作为模块加载,返回模块的命名空间。 | 11 |
FUNC | napi_create_object_with_properties | 使用给定的napi_property_descriptor创建js Object。descriptor的键名必须为 string,且不可转为number。 | 11 |
FUNC | napi_create_object_with_named_properties | 使用给定的napi_value和键名创建js Object。键名必须为 string,且不可转为number。 | 11 |
FUNC | napi_coerce_to_native_binding_object | 强制将js Object和Native对象绑定。 | 11 |
FUNC | napi_create_ark_runtime | 创建基础运行时环境。 | 12 |
FUNC | napi_destroy_ark_runtime | 销毁基础运行时环境。 | 12 |
FUNC | napi_run_event_loop | 触发底层的事件循环。 | 12 |
FUNC | napi_stop_event_loop | 停止底层的事件循环。 | 12 |
FUNC | napi_load_module_with_info | 将abc文件作为模块加载,返回模块的命名空间。可在新创建的ArkTS基础运行时环境中使用。 | 12 |
FUNC | napi_serialize | 将ArkTS对象转换为native数据。 | 12 |
FUNC | napi_deserialize | 将native数据转为ArkTS对象。 | 12 |
FUNC | napi_delete_serialization_data | 删除序列化数据。 | 12 |
FUNC | napi_call_threadsafe_function_with_priority | 将指定优先级和入队方式的任务投递到ArkTS主线程。 | 12 |
FUNC | napi_is_sendable | 判断给定JS value是否是Sendable的。 | 12 |
FUNC | napi_define_sendable_class | 创建一个sendable类。 | 12 |
FUNC | napi_create_sendable_object_with_properties | 使用给定的napi_property_descriptor创建一个sendable对象。 | 12 |
FUNC | napi_create_sendable_array | 创建一个sendable数组。 | 12 |
FUNC | napi_create_sendable_array_with_length | 创建一个指定长度的sendable数组。 | 12 |
FUNC | napi_create_sendable_arraybuffer | 创建一个sendable ArrayBuffer。 | 12 |
FUNC | napi_create_sendable_typedarray | 创建一个sendable TypedArray。 | 12 |
FUNC | napi_wrap_sendable | 包裹一个native实例到ArkTS对象中。 | 12 |
FUNC | napi_wrap_sendable_with_size | 包裹一个native实例到ArkTS对象中并指定大小。 | 12 |
FUNC | napi_unwrap_sendable | 获取ArkTS对象包裹的native实例。 | 12 |
FUNC | napi_remove_wrap_sendable | 移除并获取ArkTS对象包裹的native实例。 | 12 |
napi_qos_t
typedef enum {napi_qos_background = 0, // 低等级,用户不可见任务,例如数据同步、备份。napi_qos_utility = 1, // 中低等级,不需要立即看到响应效果的任务,例如下载或导入数据。napi_qos_default = 2, // 默认napi_qos_user_initiated = 3, // 高等级,用户触发并且可见进展,例如打开文档。
} napi_qos_t;
描述:
表示QoS的枚举值,QoS决定了线程调度的优先级
napi_event_mode
typedef enum {napi_event_mode_default = 0, // 阻塞式的运行底层事件循环,直到循环中没有任何任务时退出事件循环。napi_event_mode_nowait = 1, // 非阻塞式的运行底层事件循环,尝试去处理一个任务,处理完之后退出事件循环;如果事件循环中没有任务,立刻退出事件循环。
} napi_event_mode;
描述:
用于运行事件循环的事件模式。
napi_queue_async_work_with_qos
napi_status napi_queue_async_work_with_qos(napi_env env,napi_async_work work,napi_qos_t qos);
描述:
将异步工作对象加到队列,由底层根据传入的qos优先级去调度执行。
参数:
- [in] env: Node-API的环境对象,表示当前的执行环境。
- [in] work: 一个表示异步工作项的对象。这个对象通常是通过napi_create_async_work函数创建的。
- [in] qos: 决定了线程调度的优先级。
返回:
如果API成功,则返回napi_ok。
napi_run_script_path
napi_status napi_run_script_path(napi_env env,const char* abcPath,napi_value* result);
描述:
运行指定abc文件。
参数:
- [in] env: Node-API的环境对象,表示当前的执行环境。
- [in] abcPath: 要运行的脚本的JavaScript路径。这是一个字符串,指定了要运行的脚本文件的位置。
- [out] result: 一个指向napi_value类型的指针,用于存储运行脚本的结果。
返回:
如果API成功,则返回napi_ok。
napi_load_module
napi_status napi_load_module(napi_env env,const char* path,napi_value* result);
描述:
加载系统模块或开发者自定义的模块,返回模块的命名空间。
参数:
- [in] env: Node-API的环境对象,表示当前的执行环境。
- [in] path: 要加载的系统模块的名称或开发者自定义模块的路径。
- [out] result: 一个指向napi_value类型的指针,用于存储加载模块的结果。
返回:
如果API成功,则返回napi_ok。
napi_create_object_with_properties
napi_status napi_create_object_with_properties(napi_env env,napi_value* result,size_t property_count,const napi_property_descriptor* properties);
描述:
属性描述符napi_property_descriptor用于描述一个属性,它包括属性的名称获取和设置方法、属性特性等信息。通过传入这些描述符,可以在创建对象时就定义属性。
使用给定的napi_property_descriptor创建js Object。descriptor的键名必须为string,且不可转为number。
参数:
- [in] env: Node-API的环境对象,表示当前的执行环境。
- [out] result: 一个指向napi_value类型的指针,用于存储创建的对象。
- [in] property_count: 要添加到对象中的属性的数量。
- [in] properties: 一个指向napi_property_descriptor数组的指针,描述了要添加到对象中的属性的信息。
返回:
如果API成功,则返回napi_ok。
napi_create_object_with_named_properties
napi_status napi_create_object_with_named_properties(napi_env env,napi_value* result,size_t property_count,const char** keys,const napi_value* values);
描述:
使用给定的napi_value和键名创建js Object。键名必须为string,且不可转为number。
参数:
- [in] env: Node-API的环境对象,表示当前的执行环境。
- [out] result: 一个指向napi_value类型的指针,用于存储创建的对象。
- [in] property_count: 要添加到对象中的属性的数量。
- [in] keys: 一个指向const char*数组的指针,表示属性的名称。
- [in] values: 一个指向napi_value数组的指针,表示属性的值,与属性名称一一对应。
返回:
如果API成功,则返回napi_ok。
napi_coerce_to_native_binding_object
napi_status napi_coerce_to_native_binding_object(napi_env env,napi_value js_object,napi_native_binding_detach_callback detach_cb,napi_native_binding_attach_callback attach_cb,void* native_object,void* hint);
描述:
用于给JS Object绑定回调和回调所需的参数,转成携带Native信息的JS Object。
参数:
- [in] env: Node-API的环境对象,表示当前的执行环境。
- [in] js_object: 要转换的JavaScript对象。
- [in] detach_cb: 解绑回调,一般在序列化时调用,可在对象解绑时执行一些清理操作。
- [in] attach_cb: 绑定回调,一般在序列化时调用。
- [in] native_object: 需要传递给回调的参数,不能为空。
- [in] hint: 一个指针,可以用于传递附加的信息给回调函数。
返回:
如果API成功,则返回napi_ok。
napi_create_ark_runtime
napi_status napi_create_ark_runtime(napi_env *env)
描述:
创建基础运行时环境。
参数:
- [in] env: Node-API的环境对象,表示当前的执行环境。
返回:
如果API成功,则返回napi_ok。
napi_destroy_ark_runtime
napi_status napi_destroy_ark_runtime(napi_env *env)
描述:
销毁基础运行时环境。
参数:
- [in] env: Node-API的环境对象,表示当前的执行环境。
返回:
如果API成功,则返回napi_ok。
napi_run_event_loop
napi_status napi_run_event_loop(napi_env env, napi_event_mode mode)
描述:
触发底层的事件循环。
参数:
- [in] env: Node-API的环境对象,表示当前的执行环境。
- [in] mode: 用于运行事件循环的事件模式。
返回:
如果API成功,则返回napi_ok。
napi_stop_event_loop
napi_status napi_stop_event_loop(napi_env env)
描述:
停止底层的事件循环。
参数:
- [in] env: Node-API的环境对象,表示当前的执行环境。
返回:
如果API成功,则返回napi_ok。
napi_load_module_with_info
napi_status napi_load_module_with_info(napi_env env,const char* path,const char* module_info,napi_value* result)
描述:
将abc文件作为模块加载,返回模块的命名空间。可在新创建的ArkTS基础运行时环境中使用。
参数:
- [in] env: Node-API的环境对象,表示当前的执行环境。
- [in] path: 要加载的模块的路径。
- [in] module_info: 模块信息。这是一个包含模块信息字符串。模块信息可以用于指定模块的版本、作者、描述等详细信息。
- [out] result: 指向napi_value的指针,用于接收模块的结果。
返回:
如果API成功,则返回napi_ok。
napi_serialize
napi_status napi_serialize(napi_env env,napi_value object,napi_value transfer_list,napi_value clone_list,void** result)
描述:
将ArkTS对象转换为native数据。
参数:
- [in] env: Node-API的环境对象,表示当前的执行环境。
- [in] object: 要序列化的JavaScript对象。
- [in] transfer_list: 传输列表,包含需要在序列化过程中转移的JavaScript对象。
- [in] clone_list: 克隆列表,包含需要在序列化过程中克隆的JavaScript对象。
- [out] result: 用于接收序列化结果的指针。在调用完成后,指向实际结果的指针会存储在此位置。
返回:
如果API成功,则返回napi_ok。
napi_deserialize
napi_status napi_deserialize(napi_env env, void* buffer, napi_value* object)
描述:
将native数据转为ArkTS对象。
参数:
- [in] env: Node-API的环境对象,表示当前的执行环境。
- [in] buffer: 指向包含二进制数据的指针。这些二进制数据需要被反序列化为JavaScript对象。
- [out] object: 用于接收反序列化后的JavaScript对象。
返回:
如果API成功,则返回napi_ok。
napi_delete_serialization_data
napi_status napi_delete_serialization_data(napi_env env, void* buffer)
描述:
删除序列化数据。
参数:
- [in] env: Node-API的环境对象,表示当前的执行环境。
- [in] buffer: 指向包含序列化数据的内存缓冲区的指针。这些数据在序列化完成后不再需要,并且可以通过调用此函数来释放相应的内存。
返回:
如果API成功,则返回napi_ok。
napi_call_threadsafe_function_with_priority
napi_status napi_call_threadsafe_function_with_priority(napi_threadsafe_function func,void *data,napi_task_priority priority,bool isTail)
描述:
将指定优先级和入队方式的任务投递到ArkTS主线程。
参数:
- [in] func: 线程安全函数对象,在创建线程安全函数时返回。
- [in] data: 传递给 JavaScript 回调函数的参数数据。
- [in] priority: 指定调用 JavaScript 回调函数的任务优先级。
- [in] isTail: 一个布尔值,指示调用是否应该排队等待在事件循环的尾部执行。如果为 true,则调用将在事件循环的尾部执行;如果为 false,则调用将立即执行,不会排队等待。
返回:
如果API成功,则返回napi_ok。
napi_is_sendable
napi_status napi_is_sendable(napi_env env, napi_value value, bool* result)
描述:
判断给定JS value是否是Sendable的。
参数:
- [in] env: Node-API的环境对象,表示当前的执行环境。
- [in] value: 一个napi_value类型的参数,是需要判断的值。
- [out] result: 一个bool类型的指针,用于存储判断结果。
返回:
如果API成功,则返回napi_ok。
napi_define_sendable_class
napi_status napi_define_sendable_class(napi_env env,const char* utf8name,size_t length,napi_callback constructor,void* data,size_t property_count,const napi_property_descriptor* properties,napi_value parent,napi_value* result)
描述:
创建一个sendable类。
参数:
- [in] env: Node-API的环境对象,表示当前的执行环境。
- [in] utf8name:一个const char*类型的参数,表示类的名称。
- [in] length:一个size_t类型的参数,表示类名称的字节数。
- [in] constructor:一个napi_callback类型的参数,表示类的构造函数。
- [in] data:[可选]一个void*类型的参数,表示构造函数的附加数据。
- [in] property_count:一个size_t类型的参数,表示类的属性数量。
- [in] properties:[可选]一个const napi_property_descriptor*类型的参数,表示类的属性描述符数组。
- [in] parent:[可选]一个napi_value类型的参数,表示父类。
- [out] result:一个napi_value类型的指针,用于存储创建的对象。
返回:
如果API成功,则返回napi_ok。
napi_create_sendable_object_with_properties
napi_status napi_create_sendable_object_with_properties(napi_env env,size_t property_count,const napi_property_descriptor* properties,napi_value* result)
描述:
使用给定的napi_property_descriptor创建一个sendable对象。
参数:
- [in] env: Node-API的环境对象,表示当前的执行环境。
- [in] property_count:一个size_t类型的参数,表示属性数量。
- [in] properties:一个const napi_property_descriptor*类型的参数,表示属性描述符数组。
- [out] result:一个napi_value类型的指针,用于存储创建的对象。
返回:
如果API成功,则返回napi_ok。
napi_create_sendable_array
napi_status napi_create_sendable_array(napi_env env, napi_value* result)
描述:
创建一个sendable数组。
参数:
- [in] env: Node-API的环境对象,表示当前的执行环境。
- [out] result:一个napi_value类型的指针,用于存储创建的数组。
返回:
如果API成功,则返回napi_ok。
napi_create_sendable_array_with_length
napi_status napi_create_sendable_array_with_length(napi_env env, size_t length, napi_value* result)
描述:
创建一个指定长度的sendable数组。
参数:
- [in] env: Node-API的环境对象,表示当前的执行环境。
- [in] length:一个size_t类型的参数,表示数组的长度。
- [out] result:一个napi_value类型的指针,用于存储创建的数组。
返回:
如果API成功,则返回napi_ok。
napi_create_sendable_arraybuffer
napi_status napi_create_sendable_arraybuffer(napi_env env, size_t byte_length, void** data, napi_value* result)
描述:
创建一个sendable ArrayBuffer。
参数:
- [in] env: Node-API的环境对象,表示当前的执行环境。
- [in] byte_length:要创建的ArrayBuffer的大小。
- [in] data:指向底层字节缓冲区的指针。
- [out] result:一个napi_value类型的指针,用于存储创建的ArrayBuffer。
返回:
如果API成功,则返回napi_ok。
napi_create_sendable_typedarray
napi_status napi_create_sendable_typedarray(napi_env env,napi_typedarray_type type,size_t length,napi_value arraybuffer,size_t byte_offset,napi_value* result);
描述:
创建一个sendable TypedArray。
参数:
- [in] env: Node-API的环境对象,表示当前的执行环境。
- [in] type:TypedArray 的类型。
- [in] length:TypedArray 的长度。
- [in] arraybuffer:一个 ArrayBuffer 实例。
- [in] byte_offset:ArrayBuffer 的偏移量。
- [out] result:一个napi_value类型的指针,用于存储创建的TypedArray。
返回:
如果API成功,则返回napi_ok。
napi_wrap_sendable
napi_status napi_wrap_sendable(napi_env env,napi_value js_object,void* native_object,napi_finalize finalize_cb,void* finalize_hint);
描述:
包裹一个native实例到ArkTS对象中。
参数:
- [in] env: Node-API的环境对象,表示当前的执行环境。
- [in] js_object:ArkTS对象。
- [in] native_object:将被包裹在ArkTS对象中的native实例。
- [in] napi_finalize:[可选]ArkTS对象被销毁时调用的回调函数。
- [in] finalize_hint:[可选]上下文提示,会传递给回调函数。
返回:
如果API成功,则返回napi_ok。
napi_wrap_sendable_with_size
napi_status napi_wrap_sendable_with_size(napi_env env,napi_value js_object,void* native_object,napi_finalize finalize_cb,void* finalize_hint,size_t native_binding_size);
描述:
包装一个native实例到ArkTS对象中并指定大小。
参数:
- [in] env: Node-API的环境对象,表示当前的执行环境。
- [in] js_object:ArkTS对象。
- [in] native_object:将被包裹在ArkTS对象中的native实例。
- [in] napi_finalize:[可选]ArkTS对象被销毁时调用的回调函数。
- [in] finalize_hint:[可选]上下文提示,会传递给回调函数。
- [in] native_binding_size:[可选]绑定的native实例的大小。
返回:
如果API成功,则返回napi_ok。
napi_unwrap_sendable
napi_status napi_unwrap_sendable(napi_env env, napi_value js_object, void** result)
描述:
获取ArkTS对象包装的native实例。
参数:
- [in] env: Node-API的环境对象,表示当前的执行环境。
- [in] js_object:ArkTS对象。
- [out] result:包裹在ArkTS对象中的native实例。
返回:
如果API成功,则返回napi_ok。
napi_remove_wrap_sendable
napi_status napi_remove_wrap_sendable(napi_env env, napi_value js_object, void** result)
描述:
移除并获取ArkTS对象包装的native实例。
参数:
- [in] env: Node-API的环境对象,表示当前的执行环境。
- [in] js_object:ArkTS对象。
- [out] result:包裹在ArkTS对象中的native实例。
返回:
如果API成功,则返回napi_ok。
相关文章:

纯血鸿蒙Native层支持说明
本文所有描述均参考鸿蒙官方文档:传送门 1.对C库的支持 C标准函数库在C语言程序设计中,提供符合标准的头文件,以及常用的库函数实现(如I/O输入输出和字符串控制)。 HarmonyOS采用musl作为C标准库,musl库…...

learn C++ NO.31——类型转换
C语言中的类型转换 在C语言中,当赋值符号两边的类型不匹配的时候,或者是形参类型和实参类型不匹配时,返回值类型与接受返回值类型不匹配时,都会需要类型转换。C语言的类型转换有两种:显示类型转换和隐式类型转换。 显…...

重学 Android 自定义 View 系列(三):自定义步数进度条
前言 本篇文章主要是实现仿QQ步数View,很老的一个View了,但技术永不落后,开搂! 最终效果如下: 1. 结构分析 QQStepView 主要由三个元素组成: 显示一个圆环进度条,通过外环和内环的角度变化来…...

海南华志亿星电子商务有限公司赋能抖音商家成长
在当今瞬息万变的电商时代,抖音凭借其短视频与直播电商的独特模式,迅速崛起并引领潮流。在这场电商变革中,海南华志亿星电子商务有限公司以其卓越的服务质量和创新的运营模式,在抖音电商领域大放异彩,成为众多商家的首…...

数据结构-并查集专题(1)
一、前言 因为要开始准备年底的校赛和明年年初的ACM、蓝桥杯、天梯赛,于是开始按专题梳理一下对应的知识点,先从简单入门又值得记录的内容开始,并查集首当其冲。 二、我的模板 虽然说是借用了jiangly鸽鸽的板子,但是自己也小做…...

共享汽车管理新纪元:SpringBoot框架应用
4系统概要设计 4.1概述 本系统采用B/S结构(Browser/Server,浏览器/服务器结构)和基于Web服务两种模式,是一个适用于Internet环境下的模型结构。只要用户能连上Internet,便可以在任何时间、任何地点使用。系统工作原理图如图4-1所示: 图4-1系统工作原理…...

道可云人工智能元宇宙每日资讯|《中国生成式人工智能应用与实践展望》白皮书发布
道可云元宇宙每日简报(2024年11月6日)讯,今日元宇宙新鲜事有: 《重庆市“机器人”应用行动计划(2024—2027年)》发布 近日,重庆市经济和信息化委员会、重庆市教育委员会等八部门印发《重庆市“…...

kaggle学习 eloData项目(1)-数据校验
文章目录 kaggle学习 eloData项目(1)-数据校验(1) 数据基本情况查看(2) 数据校验(3) 数据探究 小结 kaggle学习 eloData项目(1)-数据校验 不能懈怠࿰…...

ORACLE RAC用DNS服务器的配置
一、搭建本地YUM源 二、安装DNS全部组建 yum -y install bind* 三、规划您RAC集群所有IP #public 192.168.16.111 rac1.ntt.com rac1 192.168.16.112 rac2.ntt.com rac2 192.168.16.121 rac3.ntt.com rac3 192.168.16.122 rac4.ntt.com rac4 #private 10.10.10.111 rac1-pr…...

vue3 + vite 实现版本更新检查(检测到版本更新时提醒用户刷新页面)
背景 当一个页面很久没刷新,又突然点到页面。由于一些文件是因为动态加载的,当重编后(如前后端发版后),这些文件会发生变化,就会出现加载不到的情况。进而导致正在使用的用户,点击页面发现加载…...

【CSP】爆零的独特姿势
硝烟散,繁花尽,第一次CSP折戟沉沙。 代码拿回来,花几分钟订正下,就是300分。 然而,实战只有100分,还是偷懒得的幸运,觉得第一题题目太简单懒得用文件IO调试... ... 啥也不说了,上图。…...

Git仓库
Git初始 概念 一个免费开源,分布式的代码版本控制系统,帮助开发团队维护代码 作用 记录代码内容,,切换代码版本,多人开发时高效合并代码内容 如何学: 个人本机使用:Git基础命令和概念 多…...

【科研日常】论文投稿的几大状态
Manuscript Submitted(Submitted to Journal):表示论文已经投稿成功,等待期刊工作人员检查论文格式排版、重复率是否符合要求,符合要求的文章会分配给期刊编辑进行处理。 Awaiting Admin Processing:意为等…...

SSLHandshakeException错误解决方案
1、错误提示 调用Http工具报如下异常信息: cn.hutool.core.io.IORuntimeException: SSLHandshakeException: Received fatal alert: handshake_failure2、查询问题 一开始我以为是代码bug,网络bug甚至是配置环境未生效,找了一大圈…...

python数据结构基础(7)
本节学习最后一种数据结构---图,在很多问题中应用图可以帮助构建思维空间,快速理清思路,解决复杂问题. 图就是一些顶点的集合,这些顶点通过一系列边链接起来.根据边的有向和无向,图分为有向图和无向图.有时图的边上带有权重,本节暂时不将权重作为重点. 计算机通过邻接表或者邻…...

【系统集成项目管理工程师】英语词汇对照表-项目管理类
英语单词(项目管理类)中文解释Activity活动Accept验收Acceptable Quality Level可接受的质量水平Acceptance Standard验收标准Acquisition Plan Review采购计划评审Action处理Active On the Arrow双代号网络图Activity Based Costing (ABC)基于活动的成本…...

购物车-多元素组合动画css
学习 渡一课程 多元素组合动画 练习。 在我们开发购物车功能时,经常会有点击添加按钮,就会有一个小圆点掉进购物车的动画,如下图所示,今天我们通过css来实现。 首先实现多元素组合动画 直接上代码,可以复制到本地使用…...

【计网不挂科】计算机网络期末考试——【选择题&填空题&判断题&简述题】题库(3)
前言 大家好吖,欢迎来到 YY 滴计算机网络 系列 ,热烈欢迎! 本章主要内容面向接触过C的老铁 本博客主要内容,收纳了一部门基本的计算机网络题目,供yy应对期中考试复习。大家可以参考 欢迎订阅 YY滴其他专栏!…...

[ vulnhub靶机通关篇 ] 渗透测试综合靶场 DarkHole:1 通关详解 (附靶机搭建教程)
🍬 博主介绍 👨🎓 博主介绍:大家好,我是 _PowerShell ,很高兴认识大家~ ✨主攻领域:【渗透领域】【数据通信】 【通讯安全】 【web安全】【面试分析】 🎉点赞➕评论➕收藏 养成习…...

【LeetCode】移除链表中等于设定值的元素、反转链表
主页:HABUO🍁主页:HABUO 🌜有时候世界虽然是假的,但并不缺少真心对待我们的人🌛 1. 移除链表中设定值的元素 题目:给你一个链表的头节点 head 和一个整数 val ,请你删除链表中所…...

Redis - 主从复制
在分布式系统中为了解决单点问题,通常会把数据复制多个副本部署到其他服务器,满⾜故障恢 复和负载均衡等需求。Redis也是如此,它为我们提供了复制的功能,实现了相同数据的多个Redis副 本。复制功能是⾼可⽤Redis的基础,…...

UE5 HLSL 学习笔记
half的取值范围是整形的-60000 到 60000,考虑带宽的情况下使用half vector默认为float4 访问可以.xyzw,也可以.rgba,也可以[index],且顺序可以变,比如说.yzwx 矩阵的获取值的方式 第一个行代表获取第1行第0号元素 第…...

一个简单ASP.NET购物车设计
思路: 创建一个多选列表 在cs文件里初始化购物车会话变量,同,创建一个新的 List<string> 并将其赋值给会话状态中的 "Cart" 键–(利用Session) Session 是一种用于存储用户特定信息的对象,这些信息可…...

双向循环列表
双向循环列表的实现。 根据定义实现。不解释,具体细节看代码。 list.h #pragma once#pragma pack(1)typedef struct _MyListEntry {_MyListEntry* next;_MyListEntry* prev; }MyListEntry;#pragma pack()class MyListClass { public:MyListEntry* m_list0;int m_k…...

go项目出现了ambiguous import要怎么解决?
前言 最近小编在 构建一个项目时出现了问题,提示报错里ambiguous import;查询了解到是 依赖包存在多个不同版本的问题 这样的情况要怎么解决呢? 小编先是将问题抛给了 chatgpt,得到了如下的信息: # 清理缓存 go clea…...

更改Ubuntu22.04锁屏壁纸
更改Ubuntu22.04锁屏壁纸 sudo apt install gnome-shell-extensions gnome-shell-extension-manager安装Gnome Shell 扩展管理器后,打开“扩展管理器”并使用搜索栏找到“锁屏背景”扩展...

ROS2humble版本使用colcon构建包
colcon与与catkin相比,没有 devel 目录。 创建工作空间 首先,创建一个目录 ( ros2_example_ws ) 来包含我们的工作区: mkdir -p ~/ros2_example_ws/src cd ~/ros2_example_ws 此时,工作区包含一个空目录 src : . └── src1 directory, …...

CSRF 跨站请求伪造的实现原理和预防措施
CSRF(跨站请求伪造)概述 CSRF(Cross-Site Request Forgery),即跨站请求伪造,是一种攻击手段,攻击者利用受害者在网站上已认证的身份信息,诱使受害者发起未经授权的请求,从…...

【LeetCode】【算法】22. 括号生成
LeetCode 22. 括号生成 题目描述 数字 n 代表生成括号的对数,请你设计一个函数,用于能够生成所有可能的并且 有效的 括号组合。 解题思路 天天到处看答案,看的灵神的解题思路回溯不会写?套路在此!(Pyth…...

WPF+MVVM案例实战与特效(二十五)- 3D粒子波浪效果实现
文章目录 1、案例效果2、案例实现1、文件创建2. 功能代码实现3、粒子功能应用1、前端布局与样式2、代码解释2、 后端功能代码1、案例效果 2、案例实现 1、文件创建 打开 Wpf_Examples 项目、Models 文件夹下创建 3D粒子模型类 ParticleWaveEffectModel.cs 文件。在Tools 文件…...