我是并发方面的新手(我相信我在 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/