[英]thread/synch in java
我对Java不感到失望,因为它不允许以下代码同时移动。 当没有同步时,两个线程更频繁地切换,但是当试图访问同步方法时,在第二个线程获得锁定之前它将花费太长时间(例如30秒),并且在第一个线程获得锁定之前再次从第二个。 什么编码可以更好地分享锁:
public synchronized static void i()
{
System.out.println(Thread.currentThread().getName());
}
public static void main(String[] f)
{
Thread t = new Thread(new Runnable(){
public void run()
{
while(true)
i();
}});
t.setName("a: ");
Thread t2 = new Thread(new Runnable(){
public void run()
{
while(true)
i();
}});
t2.setName("b: ");
t.start();
t2.start();
}
使用ReentrantLock
,公平性设置为true。
public static final ReentrantLock lock = new ReentrantLock(true);
public static void i()
{
lock.lock();
try {
System.out.println(Thread.currentThread().getName());
} finally {
lock.unlock();
}
}
问题不是java,而是你的代码。 锁定合约的哪一部分意味着公平收购? 简单地让现有的锁具持续存在更快更有效率; 通常他们会完成他们的工作并且无论如何都要释放锁。 您的程序应该对锁和线程交错的公平性做出0假设。
如果你想要一个公平的交错,你不应该使用同步方法。 您需要创建一个私有Object,然后在该私有对象上手动使用wait()和notify()方法来强制交错,但即便如此,这也是一个假设:)为了确保您得到公平的交错,您将不得不创建一个volatile
条件变量,指示轮到谁执行。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.