Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Docs
提交
26ac64d7
D
Docs
项目概览
OpenHarmony
/
Docs
1 年多 前同步成功
通知
159
Star
292
Fork
28
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
Docs
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
26ac64d7
编写于
7月 22, 2022
作者:
O
openharmony_ci
提交者:
Gitee
7月 22, 2022
浏览文件
操作
浏览文件
下载
差异文件
!6976 add compilation error warnning
Merge pull request !6976 from Hu_zq/master
上级
720aa377
2bf6cf5a
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
9 addition
and
4 deletion
+9
-4
zh-cn/application-dev/napi/napi-guidelines.md
zh-cn/application-dev/napi/napi-guidelines.md
+9
-4
未找到文件。
zh-cn/application-dev/napi/napi-guidelines.md
浏览文件 @
26ac64d7
...
...
@@ -10,23 +10,28 @@ js侧通过`import`引入native侧包含处理js逻辑的so,如:`import hell
## 开发建议
###
1.
注册建议
### 注册建议
*
nm_register_func对应的函数需要加上static,防止与其他so里的符号冲突。
*
模块注册的入口,即使用
\_\_
attribute
\_\_
((constructor))修饰的函数的函数名需要确保不与其他模块重复。
### 2. so命名规则
### so命名规则
*
每个模块对应一个so
*
如模块名为
`hello`
,则so的名字为
`libhello.so`
,
`napi_module`
中
`nm_modname`
字段应为
`hello`
,大小写与模块名保持一致,应用使用时写作:
`import hello from 'libhello.so'`
###
3.
js对象线程限制
### js对象线程限制
ark引擎会对js对象线程使用进行保护,不正确使用会引起应用crash。
*
napi接口只能在js线程使用。
*
env与线程绑定,不能跨线程使用。native侧js对象只能在创建时的线程使用,即与线程所持有的env绑定。
### 4. napi_create_async_work接口说明
### 头文件引入限制
在使用napi的对象和方法时需要引用"napi/native_api.h"。否则在只引入三方库头文件时,会出现未支持
**接口无法找到的编译报错**
。
### napi_create_async_work接口说明
napi_create_async_work里有两个回调:
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录