java - 关于并发JAVA的建议

标签 java multithreading concurrency

我是并发方面的新手(我相信我在 Monitors、Semaphores 和 reentrantLocks 方面做得很好)所以我不能使用它们。
我必须使用并发包中的任何类或接口(interface)。

Point 1.- 很少有线程必须访问一个数组并对它的元素进行汇总(我在这里使用了原子变量,有一个原子变量用作数组的指针)。

点 2.- 在这里,许多线程(汽车)在岸边有,要过河。有一个模拟船的线程。当船上有 10 辆汽车时,它驶向对岸。重复这种安全措施,直到所有汽车都过河。我真的不知道在这里使用哪些。

点 3.- 在这里,一些线程必须读取一些信息,而其他线程必须修改该信息(任意次数)。我相信在这里我必须使用 ReadWriteLock。

第 4 点.- 生产者/消费者之类的问题。这里我使用了 BlockingQueue。

第 5 点.- 组成一个类似问题的交换器并解决它(完成,非常简单的一个......交换字符串变量的 2 个线程)。

如果您对在某些点使用哪种方法有任何建议(例如“不,在第 3 点使用原子变量,在第 1 点使用 cyclicBarrier”),将对我有很大帮助!

谢谢!

最佳答案

原子变量

原子变量使用 CAS 算法进行,它们可以被多个线程安全地使用:

CAS:

典型的 CAS 操作适用于三个操作数:
操作的内存位置 (M) 现有的预期
变量的值 (A) 需要设置的新值 (B)
CAS 操作将 M 中的值原子更新到 B,但前提是
M 中的现有值与 A 匹配,否则不采取任何措施。

您可以使用可用于交换的交换器,交换一些
两个线程之间的信息

https://docs.oracle.com/javase/7/docs/api/java/util/concurrent/Exchanger.html

阻塞队列是你提到的消费者生产者模型,所以对于
使用它你需要创建两个线程一个将是生产者它将
放入阻塞队列,消费者将从中消费(读取)。
BlockingQueue的实现有很多
这里有更多
详细资料:

http://tutorials.jenkov.com/java-util-concurrent/blockingqueue.html

所以从你的名单上都是他们的地方。

您也可以在这里了解有关 java.util.concurrent 的内容
我认为这会有所帮助:

http://tutorials.jenkov.com/java-util-concurrent/index.html

关于java - 关于并发JAVA的建议,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53290957/

相关文章:

java - 尝试获取本体中特定类的成员

java - Android 上的 SimpleDateFormat 时区错误

java - 带有外部库的 Hadoop Hive UDF

multithreading - Ada83或Ada95是否定义了一种内存模型来支持多任务处理?

c# - SSIS 跨进程通信有哪些选项?

Java EE 7 - 注入(inject) Runnable/Callable 对象

sql - 当行不存在时, "SELECT FOR UPDATE"是否会阻止其他连接插入?

java - 在处理对象树时我应该避免 instanceof 吗?

javascript - 在 Three.js 中从 Web Worker 加载纹理

Java:使来自多个客户端的并发 MySQL 查询同步