多线程 -- 初学简单例子

多线程初学

  • 该模式是生产者--消费者模式。
  • 规定了两个任务内部类,Consumer 和Producer .
  • Producer负责给 num 加1,Consumer 负责给num 减 1。
  • run()方法只是负责任务,不负责启动。
  • 通过 new Thread(new Producer()) 将任务分配给线程。通过start()方法开启线程。
  • Main 线程中有 线程Consumer 的实例consumer ,以及Producer 的实例 producer,所以可以说看的到另外两个线程,所以可以对其他线程进行一定程度的操作。
  • consumer ,producer不知道Main线程,彼此也不知道,所以可以通过Main线程作为中介,使之发生联系。比如说,在main中,将producer传给consumer(一般不建议这么做。),可以使用监听者模式
  • synchronized注意同步,为了正确共享资源。


代码如下:

package tree.test.testThread;

import java.util.Observable;
import java.util.Observer;

public class TestConsumer {

	public static int num = 0;
	public final static int CONSUMER_SLEEP_TIME = 50;
	public final static int PRODUCER_SLEEP_TIME = 40;

	@SuppressWarnings("deprecation")
	public static void main(String[] args) {

		System.out.println("started `````");
		Thread consumer = new Thread(new Consumer());
		Thread producer = new Thread(new Producer());
		consumer.start();
		producer.start();
		try {
			Thread.sleep(2000);
			Thread.yield();
		} catch (InterruptedException e) {
			e.printStackTrace();
		}
		System.out.println("ended `````");
		//TODO main thread tell others to stop 
		consumer.stop();
		producer.stop();

	}

	static class Producer implements Runnable,Observer {

		public void run() {
			synchronized (this) {
				while (true) {

					num++;
					System.out.println("after produce , num = " + num);
					try {
						Thread.sleep(PRODUCER_SLEEP_TIME);
					} catch (InterruptedException e) {
						e.printStackTrace();
					}
				}
			}

		}

		public void update(Observable o, Object arg) {
			//TODO how to use the pattern observer to control the thread end time .
		}

	}

	static class Consumer implements Runnable {

		public void run() {
			synchronized (this) {
				while (true) {
					try {

						if (num > 0) {
							num--;
							System.out.println("after consume , num = " + num);
						} else {
							System.out.println("nothing in the pool !!");
						}
						Thread.sleep(CONSUMER_SLEEP_TIME);

					} catch (InterruptedException e) {
						e.printStackTrace();
					}
				}
			}

		}

	}

}


  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
《Linux多线程服务器编程》是由陈硕所著的一本关于Linux多线程服务器编程的书籍的PDF版。它是针对Linux操作系统下的多线程服务器编程进行详细讲解的书籍,内容丰富、实用性强,对想要从事服务器编程的开发人员来说是一本非常有价值的参考书。 该书的内容主要包括多线程服务器编程的基础知识、常见的服务器架构、多线程编程的原理与技巧、网络编程、并发模型与同步机制、IO复用与信号驱动IO、线程池与任务队列、负载均衡与高可用技术等。通过对这些方面的深入讲解,读者可以了解到如何在Linux环境下进行高效、稳定的多线程服务器编程。 这本书的特点是实用性强、例子丰富、讲解逻辑清晰、代码简洁明了。作者通过一些生动的例子和具体的代码实现,将复杂的概念和技术转化为易于理解和操作的知识点,非常适合读者学习和实践。无论是初学者还是有一定经验的开发人员,都可以从这本书中获得不少启发和帮助。 总的来说,《Linux多线程服务器编程》是一本非常实用的Linux服务器编程的参考书,它帮助读者全面了解了多线程服务器编程的核心概念和技术,提供了丰富的例子和代码实现,对于开发人员提高编程技能和解决实际问题具有重要意义。如果你对Linux多线程服务器编程感兴趣,这本书将是你不可错过的一本参考书。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值