ArkTS的SendableClass对象内存共享的原理和限制是什么
ArkTS的SendableClass对象内存共享的原理和限制是什么
HarmonyOS
赞
收藏 0
回答 1
待解决
相关问题
通过PixelMap_CreatePixelMap创建的对象,内存在ArkTS侧和Native侧是否共享
404浏览 • 1回复 待解决
OceanBase 复制表的原理是什么?
2250浏览 • 1回复 待解决
LazyForEach懒加载的原理是什么
248浏览 • 1回复 待解决
PolarDB 的备份恢复原理是什么?
1171浏览 • 1回复 待解决
MongoDB 库名和命名空间的限制是什么?
1751浏览 • 1回复 待解决
性能优化中的组件复用原理是什么
184浏览 • 1回复 待解决
ArkTS是否支持类似Java的共享内存模型进行多线程开发
195浏览 • 1回复 待解决
ArkTS的对象数据与Native的对象数据如何绑定,相互持有对象数据时内存如何管理
193浏览 • 1回复 待解决
OceanBase 多租户原理是什么?
2575浏览 • 1回复 待解决
TaskPool线程内存如何共享
202浏览 • 1回复 待解决
AppStorage是否支持线程间共享对象,如果不支持,推荐替代方案是什么
140浏览 • 1回复 待解决
postgresql copy的执行原理是什么?greenplum上执行copy的过程是怎样的?
1485浏览 • 1回复 待解决
请问一下,ArkTs的页面布局style的底层实现是什么样的?有没有相关帖子介绍原理?
891浏览 • 1回复 待解决
Worker线程内存如何共享
212浏览 • 1回复 待解决
如何将类Java语言的线程模型(内存共享)的实现方式转换成在ArkTS的线程模型下(内存隔离)的实现方式
181浏览 • 1回复 待解决
为什么FA模型不支持进程内对象共享
252浏览 • 1回复 待解决
ArkTS如何遍历object和Record这种类型的对象
717浏览 • 1回复 待解决
Tair 持久内存型与Redis 社区版相比的优势是什么?
2531浏览 • 1回复 待解决
SVN版本控制器更新文件数据,即解决冲突的原理是什么?
4130浏览 • 1回复 待解决
HAP和HAR的区别是什么
177浏览 • 1回复 待解决
OpenID和UnionID的长度限制要求
131浏览 • 1回复 待解决
你学习ArkTS遇到最大的问题是什么
509浏览 • 1回复 已解决
Worker和TaskPool的线程数量是否有限制
217浏览 • 1回复 待解决
HSP共享资源并不是很方便,它的使用场景是什么?
195浏览 • 1回复 待解决
前端开发中,DOM对象和JS对象的区别?
740浏览 • 1回复 待解决
SendableClass是基于Actor内存隔离并发模型的扩展,Sendable对象的内存是线程间共享的,但是仍然需要满足单线程无锁化运行。因此,要保证同一个Sendable实例不能多线程并发访问,开发者需要通过同步机制保证线程安全。
Sendable对象需要满足一定的规格:
1. 成员属性为 Sendable类或者基础类型(string number boolean等)。
2. 成员属性必须显式初始化。
3. 成员函数不能使用闭包,只能使用入参或者this成员或者import导入的变量。
4. 只允许Sendable类继承Sendable类。
5. @Sendable只能写在ArkTS(ets)文件中。
6. 不支持定义私有属性,要用private。
7. 导出Sendable类的文件,不能导出非Sendable属性。
8. 传输方式有如下两种:
a. 序列化传递:深拷贝到其他线程,非共享模式。
b. 共享模式:可以跨线程引用传递,多线程可同时读写,开发者需要自行采用同步机制避免多线程竞争。
参考链接
多线程并发概述