- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我一直在研究一些关于垃圾收集的知识,主要应用于服务器端/实时应用程序,并且我已经开始草拟一种算法,使用它可以拥有一个异步垃圾收集系统。由于我现在开始讨论这个主题,所以我对 gc 算法不是很了解,所以我想知道这样的实现可能存在的陷阱。算法很粗糙,有很多未定义的部分。
我是这样想的:
就是这样!
无论如何,我对一个可能的实现感到非常兴奋,它不会停止世界,并且只使用仅适用于被复制对象的快速自旋锁。但我想知道这是否有可能实现,或者是否有可能在某处有一个悬空指针,或者内存泄漏,或者它是无效的,等等。任何有助于此的信息将不胜感激!
我不太确定例如它将处理来自不同线程的循环引用。我认为这会很自然地处理,因为我们更新了当前 gc'ed 线程具有的所有危险指针。可能还有某种我没有考虑到的并发访问。
谢谢!
---- 编辑:感谢欧内斯特的贡献,我正在考虑不使用复制算法,而是使用简单的标记和扫描。那是因为我们每次访问对象的变量时都需要检查指针是否已更新。这在我看来是一个相当大的开销。不是吗?
最佳答案
你的想法很好,但我相信有很多微妙的问题需要大量的工作来解决,一旦解决,你将无法获得有竞争力的吞吐量性能。
each thread has its own heap space to manage, and stores a list of pointers it owns that are in use by other threads With that, garbage collection works totally asynchronous to the running threads, and:
如果有一个共享对象,哪个线程拥有它?如果一个并发集合有不同线程添加的对象,会不会有很多堆间指针?您如何处理堆之间的循环?
phase 1 start following the threads' roots and marking all objects reacheable by them. If we get into another thread's space, we stop following this pointer, and mark this pointer as "in use" on the owner thread
如果这与 mutator 运行同时完成,您如何防止在 GC 执行此标记时 mutator 改变拓扑以引入或消除堆间引用的竞争条件?
after we have marked all regions, we select a region (maybe with most dead references as possible), and start copying its live object references to another space. (it might be the whole thread heap space, but I think it could be too memory-intensive this operation)
如果这是针对多核,复制将使全局内存带宽饱和并破坏可伸缩性。
copying starts with setting with CAS a flag which states that the object is being copied. Any mutable action to be performed on this particular object while that flag is set will spin lock until a new address is set by the gc thread. When copying finishes, a new address is set on the old one, and any mutable reference to be performed on the object will be routed to the new object
无锁是棘手的。您正在对内存模型做出假设。您可能需要内存屏障。看起来您只是在模拟一个锁,在这种情况下,您谈论的是在每次将引用写入堆时获取和释放锁,这会非常昂贵。
自旋锁也不利于并发,因为您不仅会占用一个线程,还会燃烧一个无法再完成您正在等待的工作的核心!查看last core slowdown GHC 中的错误。无等待解决方案将使用 CAS 来获取 mutator 线程来帮助 GC 工作,而不是阻塞等待另一个线程来完成它。
after updating all references made to those pointers using CAS, the old space is finally freed (no new pointers will be updated with the wrong address, since every mutator will first check to see if the reference has changed locations)
好的。
关于multithreading - 这种异步垃圾收集器可能存在的缺陷,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5684306/
引用网址 http://hi.baidu.com/quiteuniverse/blog/item/9f3f043d46ad1e07bba16716.html 以下函数调用方式:&nbs
我什至不确定如何描述我正在尝试做的事情,因为我对 cookie 了解不多,但就这样吧。 是否可以使用PHP从浏览器缓存中收集一个cookie(或cookie文件),将其保存到数据库中,然后清除缓存并重
我正在使用 Room(v. 2.2.1)和协程支持(v. 1.3.2)并进行以下设置 @Entity(tableName = "simple_table") data class SimpleEnti
我正在尝试编写一个基于时间运算符收集/累积值的规则。 rule "Zone6 Overlap" when $i1 : Instance ($e1 : event == " Vel : 20.9
我有一个简单的 BST,定义了节点结构: struct node { int key_value; struct node *left; struct node *right; }; ty
我有这个对象: public class MenuPriceByDay implements Serializable { private BigDecimal avgPrice; p
我正在开发一个应用程序,需要访问给定传感器的“最后 5 秒有值(value)的数据”。我的计划是以某种方式存储这些数据,然后当我请求数据时,它将返回最近 5 秒内获得的所有数据。鉴于以下情况,我不确定
在 Ruby 中,您可以对数组使用 map/collect 方法来修改它: a = [ "a", "b", "c", "d" ] a.collect! {|x| x + "!" } a
我即将开始实时收集大量数字数据(对于那些感兴趣的人,各种股票和 future 的出价/要价/最后或“磁带”)。稍后将检索数据以进行分析和模拟。这一点都不难,但我想高效地做到这一点,这会带来很多问题。我
我提出这个问题是为了寻求有关如何设计系统的实用建议。 像 amazon.com 和 pandora 这样的网站拥有并维护着庞大的数据集来运行他们的核心业务。例如,亚马逊(以及所有其他主要电子商务网站)
假设我们有一个数据数组和另一个带索引的数组。 data = [1, 2, 3, 4, 5, 7] index = [5, 1, 4, 0, 2, 3] 我们想从 index 的 data 元素创建一个
好的,我已经阅读了几个关于它的主题,但现在就开始吧。假设我有一个应用程序,基本上我会时不时地点击一个按钮,几分钟内会发生很多事情,然后它可能会再闲置一个小时,或者可能只是 1 分钟。难道不是在整个结束
我有一个数据框,例如 Seq Chrm start end length score 0 A C1 1 50 49 12 1 B
我正在考虑在 Object[] 数组中收集泛型方法的所有方法参数以进行记录。我知道使用方面可以更好地实现这一点,但是我不允许使用它,并且如果可能的话我正在寻找一种基于纯反射的方法 为了澄清, 假设一个
快速提问: 如果 Socket 对象(及其本地缓存的 InputStream 和 OutputStream 对象)超出范围并被垃圾收集,连接是否在 JVM 中保持打开状态? (即,不会在监听服务器上抛
是否有用于收集 facebook 公共(public)数据作为实时提要的 API。我阅读了关于用于收集数据的公共(public)提要 API,但我现在不能申请,而且它不是免费的,还有 Open str
摘要 :我使用自定义收集器收集给定搜索的所有命中的文档 ID(它使用 ID 填充 BitSet)。根据我的需要,搜索和获取文档 ID 的速度非常快,但是当涉及到从磁盘实际获取文档时,事情变得非常缓慢。
我正在寻找一种方法来从自定义 Gradle 插件收集给定项目的所有依赖约束(通过常规 platform 和/或 enforcedPlatform 和/或“手动”强制执行)。 在 Maven 世界中,您
我有一个 CSV 格式的用户列表,但我需要按广告中的名称从每个用户收集 SamAccount 属性。 CSV 模型 脚本 Get-ADObject -Filter 'ObjectClass -eq "
我得到了一个非常大的列表,其中包含大约 200 个带有文本和图像的项目。 ng-repeat 是一种缓慢渲染的方式。它尝试过这个 solution 。效果很好。但不适合重复收集。 我的网络服务返回此:
我是一名优秀的程序员,十分优秀!