繁体   English   中英

java中的thread / synch

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM