黑马程序员_多线程2

---------------------- android培训java培训、期待与您交流! ---------------------


1. JDK5.0实现生产者消费者模型:

public class ProducterConsumer {

public static void main(String[] args) {

Goods goods=new Goods();

Producter pro=new Producter(goods);

Consumer con=new Consumer(goods);

new Thread(pro).start();

new Thread(con).start();

new Thread(pro).start();

new Thread(con).start();

}

}

class Goods{

String name;

int count=0;

Lock lock=new ReentrantLock();

Condition conSetter=lock.newCondition();

Condition conGetter=lock.newCondition();

boolean flag=false;

public void getName() {

lock.lock();

try{

while(!flag)

try {

conGetter.await();

} catch (InterruptedException e) {

e.printStackTrace();

}

    System.out.println(Thread.currentThread().getName()+"~~~消费者~~~~"+name+"  "+count);

    flag=false;

    conSetter.signalAll();

}finally{

lock.unlock();

}

}

public void setName(String name) {

lock.lock();

try{

while(flag)

try {

conSetter.await();

} catch (InterruptedException e) {

e.printStackTrace();

}

this.name=name;

count++;

System.out.println(Thread.currentThread().getName()+"~~~~~~生产者~~~~~~~~~"+name+"  "+count);

flag=true;

conGetter.signalAll();

}finally{

lock.unlock();

}

}

}

class Consumer implements Runnable{

Goods goods=new Goods();

public Consumer(Goods goods) {

this.goods=goods;

}

@Override

public void run() {

while(true)

goods.getName();

}

}

class Producter implements Runnable{

Goods goods=new Goods();

public Producter(Goods goods) {

this.goods=goods;

}

@Override

public void run() {

while(true)

goods.setName("商品");

}

}

10.停止线程:stop方法已经过时,不能用它停止线程。由于多线运行代码通常是循环结构因此,要停止线程时,可以用标记控制线程,使run方法结束。

特殊情况:

当线程处于了冻结状态,即等待状态时,就不会读取到标记。那么线程就不会结束。此时,可以用Thread类提供该方法 interrupt()方法强制让线程恢复到运行状态中来。这样就可以操作标记让线程结束。

class StopThread implements Runnable

{

private boolean flag =true;

public  void run()

{

while(flag)

{

  try {

Thread.sleep(1111111);

} catch (InterruptedException e) {

}

System.out.println(Thread.currentThread().getName()+"....run");

}

System.out.println(Thread.currentThread().getName()+"....over");

}

public void changeFlag()

{

flag = false;

}

}

public class  StopThreadDemo

{

public static void main(String[] args) 

{

StopThread st = new StopThread();

Thread t1 = new Thread(st);

Thread t2 = new Thread(st);

t1.start();

t2.start();

int num = 0;

while(true)

{

if(num++ == 60)

{  

st.changeFlag();

//若没有此段代码,线程要等到睡眠时间结束后才会结束

t1.interrupt();

t2.interrupt();

break;

}

System.out.println(Thread.currentThread().getName()+"......."+num);

}

System.out.println("over");

}

}

11.当在主线程中调用d.join()方法时(d为线程),d线程将会抢夺主线程的cup,此时将执行d线程,主线程处于阻塞状态,直到d线程执行完为止。






---------------------- android培训java培训、期待与您交流! ----------------------

详细请查看:http://edu.csdn.net/heima

黑马程序员多线程练习题主要包括两个问题。第一个问题是如何控制四个线程在打印log之前能够同时开始等待1秒钟。一种解决思路是在线程的run方法中调用parseLog方法,并使用Thread.sleep方法让线程等待1秒钟。另一种解决思路是使用线程池,将线程数量固定为4个,并将每个调用parseLog方法的语句封装为一个Runnable对象,然后提交到线程池中。这样可以实现一秒钟打印4行日志,4秒钟打印16条日志的需求。 第二个问题是如何修改代码,使得几个线程调用TestDo.doSome(key, value)方法时,如果传递进去的key相等(equals比较为true),则这几个线程应互斥排队输出结果。一种解决方法是使用synchronized关键字来实现线程的互斥排队输出。通过给TestDo.doSome方法添加synchronized关键字,可以确保同一时间只有一个线程能够执行该方法,从而实现线程的互斥输出。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [黑马程序员——多线程10:多线程相关练习](https://blog.csdn.net/axr1985lazy/article/details/48186039)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值