没有加同步出现了线程死 但是即使不加同步,也不会产生死锁的呀!!! 求大神

package com.thread;

public class ThreadCommunicationDeadLock {

public static void main(String[] args) {


    Resource resource=new Resource();
    Thread t1=new Thread(new Producer(resource));
    Thread t2=new Thread(new CCustomer(resource));

    t1.start();
    t2.start();

}

}

class Resource {
private int count = 0;
private String name = "apple";
boolean flag=false;//flag标记 默认没有生产

public void set() {

        count++;
        System.out.println("producer"+Thread.currentThread().getName() +" ..."+ name + "--" + count);



}

/**
 * @return the flag
 */
public boolean getFlag() {
    return flag;
}

/**
 * @param flag the flag to set
 */
public void setFlag(boolean flag) {
    this.flag = flag;
}

public void out() {
    System.out.println("customer"+Thread.currentThread().getName() +"..."+ name + "--" + count);


}

}

class Producer implements Runnable {

Resource resource = null;

public Producer(Resource resource) {
    this.resource = resource;
}

@Override
public void run() {

    while (true) {



        if (resource.flag==false) {

            resource.set();

            resource.setFlag(true);

        }

    }

}

}

class CCustomer implements Runnable {
Resource resource = null;

public CCustomer(Resource resource) {
    super();
    this.resource = resource;
}

@Override
public void run() {

    while(true)
    {

        if (resource.flag==true) {
                resource.out();
                resource.setFlag(false);

        }
    }

}

}

你这只是加了if判断的标记,跟多线程的锁没关系,你把锁的概念理解错啦,还有 if (resource.flag==true)直接 if (resource.flag)这样写就可以,多看看书。

你这程序太乱,看不懂。写个线程有这么复杂吗

用锁旗标控制死锁问题啊,这个自己研究去。可以加我qq,9215695

while (true) 两个死循环,你机器吃得消吗。

package com.thread;

import javax.net.ssl.SSLException;

public class ThreadCommunicationDeadLock {

public static void main(String[] args) {


    Resource resource=new Resource();
    Thread t1=new Thread(new Producer(resource));
    Thread t2=new Thread(new CCustomer(resource));

    t1.start();
    t2.start();

}

}

class Resource {
private int count = 0;
private String name = "apple";
boolean flag=false;//flag标记 默认没有生产

public void set() {

        count++;
        System.out.println("producer"+Thread.currentThread().getName() +" ..."+ name + "--" + count);



}

/**
 * @return the flag
 */
public boolean getFlag() {
    return flag;
}

/**
 * @param flag the flag to set
 */
public void setFlag(boolean flag) {
    this.flag = flag;
}

public void out() {
    System.out.println("customer"+Thread.currentThread().getName() +"..."+ name + "--" + count);


}

}

class Producer implements Runnable {

Resource resource = null;

public Producer(Resource resource) {
    this.resource = resource;
}

@Override
public void run() {

int times=0;
while (true) {

// System.out.println("Producer"+resource.flag);

        try {
            Thread.sleep(1);
        } catch (InterruptedException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }

                if (resource.flag==false) {

                    resource.set();
//              times++;
                    resource.setFlag(true);

                }

// if (times>5) {
//// break;
// }

    }

}

}

class CCustomer implements Runnable {
Resource resource = null;

public CCustomer(Resource resource) {
    super();
    this.resource = resource;
}

int times=0;
public void run() {

    while(true)
    {

// System.out.println("cus"+resource.flag);

        try {
            Thread.sleep(1);
        } catch (InterruptedException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }

                if (resource.flag==true) {
                    resource.out();

// times++;
resource.setFlag(false);

                }

// if (times>5) {
//// break;
// }
}

}

}
休眠了一毫秒,程序就能正常运行了,这是为什么..........................@
休眠了一毫秒,程序就能正常运行了,这是为什么..........................@
休眠了一毫秒,程序就能正常运行了,这是为什么..........................@

同步操作使用锁不当,才会产生死锁问题。你这段代码没有同步操作,当然不会有死锁问题 。但是会有数据不一致问题。
你这段代码,生产者线程和消费者线程共享了Resource这个对象,所以对这个对象访问时需要作同步处理,才能保证数据的一致性。即你的Resource类的方法需要用同步处理。
你的代码就是休眠一秒,继续执行的啊,根本没有锁竞争问题。

1.没死锁,是被你自己的代码轮死的。两个while(true)直接把cpu耗尽了.中间加个Thread.sleep(100)看看
2.Resource.flag需要设置成volatile,否则线程不可见。或则使用AtomicBoolean也行。