gpt4 book ai didi

java - 在 Java 中进行多线程时,常规队列不适合使用吗?

转载 作者:塔克拉玛干 更新时间:2023-11-01 22:00:39 25 4
gpt4 key购买 nike

我正在尝试向我的程序添加异步输出。

目前,我有一个 eventManager 类,它会在每一帧通知主循环中当前存在的任何可移动对象的位置(它正在渲染一个场景;一些对象在帧与帧之间变化,其他对象是静态的并且存在于每一帧)。我希望记录每一帧的状态,这样我就可以添加重播场景的功能。

这意味着我需要存储帧与帧之间的变化信息,并将其保存在内存中或将其写入磁盘以供以后检索和解析。

我做了一些计时实验,将每个对象的状态记录到内存中,每帧的时间增加了大约 25%(更不用说最终达到内存限制的可能性)。直接将每个帧写入磁盘所花费的时间(可以预见)甚至更长,几乎是根本不记录帧的时间的两倍。

不用说,我想实现多线程,这样我就不会在我的主渲染循环中每秒丢帧,因为该进程不断地写入磁盘。

我想知道为这个任务使用常规队列是否可以,或者我是否需要更专用的东西,比如 this question 中讨论的队列.

在我的情况下,只有一个生产者(主线程)和一个消费者(我要异步写入磁盘的线程)。生产者永远不会从队列中移除,而消费者永远不会添加到队列中 - 所以我是否需要一个专门的队列?

无论如何使用更专业的队列是否有优势?

最佳答案

是的,常规的 Queue 是不合适的。由于您有两个线程,因此您需要担心边界条件,例如空队列、满队列(假设出于内存考虑需要对其进行绑定(bind))或可见性等异常情况。

LinkedBlockingQueue 最适合您的应用程序。 puttake 方法使用不同的锁,因此不会发生锁争用。如果 take 方法神奇地 catch 了生产者渲染帧,它会自动阻止消费者写入磁盘。

关于java - 在 Java 中进行多线程时,常规队列不适合使用吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7761739/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com