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

标签 java multithreading queue

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

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

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

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

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

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

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

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

最佳答案

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

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

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

相关文章:

java - 在 JDK8 中导入 java.util.Arrays

multithreading - 如何并行排序?

ios - 如何从 Swift 中的后台线程从 CoreData 中获取未保存的数据?

python - 多处理队列最大限制为 32767

java - 使用 Spark 从多个动态复选框请求查询

java - 如何在 IntelliJ 类路径中找到冲突的类?

java - protected 为什么不能在不同的包子类中访问?

c - 线程退出后是否可以取消分配C __thread线程本地内存?

c - 基于比较函数插入链表队列

c++ - 排队基本功能(放入)调用(程序崩溃)