子线程同步在这里不起作用



Java Code:

// Create a second thread.
class NewThread implements Runnable 
{
    Thread t;
    NewThread() 
    {   
        t = new Thread(this, "Demo Thread");    // Create a new, second thread
        System.out.println("Child thread: " + t);
        t.start();              // Start the thread
    }
    public void run()   // This is the entry point for the second thread.
    {
        justCall();
    }
    public synchronized void justCall()
    {
        try 
        {   
                for(int i = 10; i > 0; i--)
                {
                    System.out.println("Child Thread: " + i);
                    Thread.sleep(10000);
                }
        }
        catch (Exception e) 
        {
            System.out.println("Child interrupted.");
        }
        System.out.println("Exiting child thread.");
    }
}
class ThreadDemo 
{
    public static void main(String args[]) 
    {
        NewThread nt = new NewThread();         // create a new thread
        try 
        {
            for(int i = 5; i > 0; i--) 
            {
                System.out.println("Main Thread: " + i);
                Thread.sleep(1000);
            }
        }
        catch (InterruptedException e) 
        {
            System.out.println("Main thread interrupted.");
        }   
        System.out.println("Main thread exiting.");
    }
}

这里你可以删除同步的justCall()方法,你可以在run()方法中初始化一个同步块(把justCall()方法的代码放在一个同步块中)。

如何同步子代码在这里?请帮助。我读到Thread.sleep()方法在同步块或方法中执行时永远不会释放锁。但在我的代码主线程和子代码并发执行。请使用Thread.sleep()方法帮助同步子代码。

当两个线程在同一个对象上同步时,它们不会同时运行相同的代码。这允许许多不同的线程同时在许多不同的代码区域中合作运行。

非静态方法上的synchronizedthis对象上创建了一个锁。如果它是一个静态方法,那么锁就会在NewThread类的Class对象上。任何类和任何类的实例都可以有一个syncronized,从而创建一个锁。

只有一个线程在同步区运行。因此,当它被锁定时,没有其他线程试图运行被锁定的代码。没有其他线程试图同步NewThread类的nt实例。

你可以试着这样做:

NewThread nt1 = new NewThread();         // create a new thread
NewThread nt2 = new NewThread();         // create a 2nd new thread

相关内容

最新更新