鸿蒙开发接口公共事件与通知:【FFI能力(Node-API)】

电子说

1.3w人已加入

描述

FFI能力(N-API)

ArkUI-X中支持的N-API接口情况

Node-API是封装底层JavaScript运行时能力的一套Native接口。OpenHarmony的N-API组件对Node-API的接口进行了重新实现,ArkUI-X同样拥有这部分能力,目前支持部分接口,支持列表。

Node-API

简介

Node-API是封装底层JavaScript运行时能力的一套Native接口。

支持的能力

Node-API屏蔽了底层不同JavaScript引擎的差异,提供一套稳定的接口。

OpenHarmony的N-API组件对Node-API的接口进行了重新实现,ArkUI-X在此基础上进行了跨平台扩展,N-API接口可以在OpenHarmony/HarmonyOS/Android/iOS多个平台上使用。当前支持[Node-API]标准库中的部分接口,如下表所示。

N-API组件扩展的符号列表

开发前请熟悉鸿蒙开发指导文档 :[gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md]
标准库中导出的符号列表

符号类型符号名说明
FUNCnapi_module_registernapi native模块注册接口。
FUNCnapi_get_last_error_info获取napi_extended_error_info结构体,其中包含最近一次出现的error信息。
FUNCnapi_throw抛出一个js value。
FUNCnapi_throw_error抛出一个带文本信息的jsError
FUNCnapi_throw_type_error抛出一个带文本信息的jsTypeError
FUNCnapi_throw_range_error抛出一个带文本信息的jsRangeError
FUNCnapi_is_error判断napi_value是否表示为一个error对象。
FUNCnapi_create_error创建并获取一个带文本信息的jsError
FUNCnapi_create_type_error创建并获取一个带文本信息的jsTypeError
FUNCnapi_create_range_error创建并获取一个带文本信息的jsRangeError
FUNCnapi_get_and_clear_last_exception获取并清除最近一次出现的异常。
FUNCnapi_is_exception_pending判断是否出现了异常。
FUNCnapi_fatal_error引发致命错误以立即终止进程。
FUNCnapi_open_handle_scope创建一个上下文环境使用。
FUNCnapi_close_handle_scope关闭传入的上下文环境,关闭后,在其中声明的全部napi_value都将被回收。
FUNCnapi_open_escapable_handle_scope创建出一个可逃逸的handel scope,可将范围内声明的值返回到父作用域。
FUNCnapi_close_escapable_handle_scope关闭传入的可逃逸的handel scope。
FUNCnapi_escape_handle提升传入的js object的生命周期到其父作用域。
FUNCnapi_create_referencenapi_value创建一个reference,提升js对象生命周期。调用者需要自己管理reference生命周期。
FUNCnapi_delete_reference删除传入的reference。
FUNCnapi_reference_ref增加传入的reference的引用计数,并获取该计数。
FUNCnapi_reference_unref减少传入的reference的引用计数,并获取该计数。
FUNCnapi_get_reference_value获取与reference相关联的jsObject
FUNCnapi_create_array创建并获取一个jsArray
FUNCnapi_create_array_with_length创建并获取一个指定长度的jsArray
FUNCnapi_create_arraybuffer创建并获取一个指定大小的jsArrayBuffer
FUNCnapi_create_external分配一个附加有外部数据的js value。
FUNCnapi_create_external_arraybuffer分配一个附加有外部数据的jsArrayBuffer
FUNCnapi_create_object创建一个默认的jsObject
FUNCnapi_create_symbol创建一个jsSymbol
FUNCnapi_create_typedarray通过现有的ArrayBuffer创建一个jsTypeArray
FUNCnapi_create_dataview通过现有的ArrayBuffer创建一个jsDataView
FUNCnapi_create_int32通过一个C的int32_t数据创建jsNumber
FUNCnapi_create_uint32通过一个C的uint32_t数据创建jsNumber
FUNCnapi_create_int64通过一个C的int64_t数据创建jsNumber
FUNCnapi_create_double通过一个C的double数据创建jsNumber
FUNCnapi_create_string_latin1通过ISO-8859-1编码的C字符串数据创建jsString
FUNCnapi_create_string_utf8通过UTF8编码的C字符串数据创建jsString
FUNCnapi_create_string_utf16通过UTF16编码的C字符串数据创建jsString
FUNCnapi_get_array_length获取array的length。
FUNCnapi_get_arraybuffer_info获取ArrayBuffer的底层data buffer及其长度。
FUNCnapi_get_prototype获取给定jsObjectprototype
FUNCnapi_get_typedarray_info获取给定TypedArray的各种属性。
FUNCnapi_get_dataview_info获取给定DataView的各种属性。
FUNCnapi_get_value_bool获取给定jsBoolean对应的C bool值。
FUNCnapi_get_value_double获取给定jsNumber对应的C double值。
FUNCnapi_get_value_external获取先前通过napi_create_external()传递的外部数据指针。
FUNCnapi_get_value_int32获取给定jsNumber对应的C int32值。
FUNCnapi_get_value_int64获取给定jsNumber对应的C int64值。
FUNCnapi_get_value_string_latin1获取给定js vaule对应的ISO-8859-1编码的字符串。
FUNCnapi_get_value_string_utf8获取给定js vaule对应的UTF8编码的字符串。
FUNCnapi_get_value_string_utf16获取给定js vaule对应的UTF16编码的字符串。
FUNCnapi_get_value_uint32获取给定jsNumber对应的C uint32值。
FUNCnapi_get_boolean根据给定的C boolean值,获取js bool对象。
FUNCnapi_get_global获取global对象。
FUNCnapi_get_null获取null对象。
FUNCnapi_get_undefined获取undefined对象。
FUNCnapi_coerce_to_bool将给定的js value强转成jsBoolean
FUNCnapi_coerce_to_number将给定的js value强转成jsNumber
FUNCnapi_coerce_to_object将给定的js value强转成jsObject
FUNCnapi_coerce_to_string将给定的js value强转成jsString
FUNCnapi_typeof获取给定js value的js type。
FUNCnapi_instanceof判断给定object是否为给定constructor的实例。
FUNCnapi_is_array判断给定js value是否为array。
FUNCnapi_is_arraybuffer判断给定js value是否为ArrayBuffer
FUNCnapi_is_typedarray判断给定js value是否表示一个TypedArray
FUNCnapi_is_dataview判断给定js value是否表示一个DataView
FUNCnapi_is_date判断给定js value是否为jsDate对象。
FUNCnapi_strict_equals判断给定的两个js value是否严格相等。
FUNCnapi_get_property_names以字符串数组的形式获取对象的可枚举属性的名称。
FUNCnapi_set_property对给定Object设置属性。
FUNCnapi_get_property获取给定Object的给定属性。
FUNCnapi_has_property判断给定对象中是否存在给定属性。
FUNCnapi_delete_property尝试从给定Object中删除给定key属性。
FUNCnapi_has_own_property判断给定Object中是否有名为key的own property。
FUNCnapi_set_named_property对给定Object设置一个给定名称的属性。
FUNCnapi_get_named_property获取给定Object中指定名称的属性。
FUNCnapi_has_named_property判断给定Object中是否有给定名称的属性。
FUNCnapi_set_element在给定Object的指定索引处,设置元素。
FUNCnapi_get_element获取给定Object指定索引处的元素。
FUNCnapi_has_element若给定Object的指定索引处拥有属性,获取该元素。
FUNCnapi_delete_element尝试删除给定Object的指定索引处的元素。
FUNCnapi_define_properties批量的向给定Object中定义属性。
FUNCnapi_type_tag_object将tag指针的值与Object关联。
FUNCnapi_check_object_type_tag判断给定的tag指针是否被关联到了jsObject上。
FUNCnapi_call_function在Native方法中调用js function,即native call js。
FUNCnapi_create_function创建native方法给js使用,以便于js call native。
FUNCnapi_get_cb_info从给定的callback info中获取有关调用的详细信息,如参数和this指针。
FUNCnapi_get_new_target获取构造函数调用的new.target
FUNCnapi_new_instance通过给定的构造函数,构建一个实例。
FUNCnapi_define_class定义与C++类相对应的JavaScript类。
FUNCnapi_wrap在js object上绑定一个native对象实例。
FUNCnapi_unwrap从js object上获取先前绑定的native对象实例。
FUNCnapi_remove_wrap从js object上获取先前绑定的native对象实例,并解除绑定。
FUNCnapi_create_async_work创建一个异步工作对象。
FUNCnapi_delete_async_work释放先前创建的异步工作对象。
FUNCnapi_queue_async_work将异步工作对象加到队列,由底层去调度执行。
FUNCnapi_cancel_async_work取消入队的异步任务。
FUNCnapi_get_node_version获取node的版本信息。
FUNCnapi_get_version获取Node运行时支持的最高 N-API 版本。
FUNCnapi_create_promise创建一个延迟对象和js promise。
FUNCnapi_resolve_deferredresolve与js promise对象关联的延迟函数。
FUNCnapi_reject_deferredreject与js promise对象关联的延迟函数。
FUNCnapi_is_promise判断给定js value是否为promise对象。
FUNCnapi_get_uv_event_loop获取当前libuv loop实例。
FUNCnapi_create_threadsafe_function创建线程安全函数。
FUNCnapi_get_threadsafe_function_context获取线程安全函数中的context。
FUNCnapi_call_threadsafe_function调用线程安全函数。
FUNCnapi_acquire_threadsafe_function指示线程安全函数可以开始使用。
FUNCnapi_release_threadsafe_function指示线程安全函数将停止使用。
FUNCnapi_ref_threadsafe_function指示在主线程上运行的事件循环在线程安全函数被销毁之前不应退出。
FUNCnapi_unref_threadsafe_function指示在主线程上运行的事件循环可能会在线程安全函数被销毁之前退出。
FUNCnapi_create_date通过一个C的double数据创建jsDate
FUNCnapi_get_date_value获取给定jsDate对应的C double值。
FUNCnapi_create_bigint_int64通过一个C的int64数据创建jsBigInt
FUNCnapi_create_bigint_uint64通过一个C的uint64数据创建jsBigInt
FUNCnapi_create_bigint_words通过一个C的uint64数组创建单个jsBigInt
FUNCnapi_get_value_bigint_int64获取给定jsBigInt对应的C int64值。
FUNCnapi_get_value_bigint_uint64获取给定jsBigInt对应的C uint64值。
FUNCnapi_get_value_bigint_words获取给定jsBigInt对应的信息,包括符号位、64位小端序数组和数组中的元素个数。
FUNCnapi_create_buffer创建并获取一个指定大小的jsBuffer
FUNCnapi_create_buffer_copy创建并获取一个指定大小的jsBuffer,并以给定数据进行初始化。
FUNCnapi_create_external_buffer创建并获取一个指定大小的jsBuffer,并以给定数据进行初始化,该接口可为Buffer附带额外数据。
FUNCnapi_get_buffer_info获取jsBuffer底层data及其长度。
FUNCnapi_is_buffer判断给定js value是否为Buffer对象。
FUNCnapi_object_freeze冻结给定的对象。
FUNCnapi_object_seal密封给定的对象。
FUNCnapi_get_all_property_names获取一个数组,其中包含此对象过滤后的属性名称。
FUNCnapi_detach_arraybuffer分离给定ArrayBuffer的底层数据。
FUNCnapi_is_detached_arraybufferHarmonyOS与OpenHarmony鸿蒙文档籽料:mau123789是v直接拿判断给定的ArrayBuffer是否已被分离过。

javascript

ArkUI-X中N-API的使用场景

在OpenHarmony中,N-API接口可以实现ArkTS/TS/JS与C/C++(Native)之间的交互。ArkUI-X在此基础上进行了跨平台的拓展,开发者可在OpenHarmony/HarmonyOS/Android/iOS多个平台上使用N-API能力,完成跨语言工程开发。ArkUI-X中的N-API典型使用场景与OpenHarmony相同,即:

  1. 通过N-API封装Native能力,暴露相应接口到ArkTS/TS/JS层,即ArkTS/TS/JS call Native。
  2. Native代码中调用ArkTS/TS/JS提供的方法,即Native call ArkTS/TS/JS。

审核编辑 黄宇

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分