`
ilikeido
  • 浏览: 27440 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

重游java系列一线程 从搬运工开始

阅读更多
     java开发已经三年了,总感觉太浮躁。这些天静下心来,对这门语言小深入了一下,特撰写该系列。
    本篇内容以模拟现实场景为线索,主要针对java线程的同步以及线程池的应用。
    模拟场景:
     一家工厂有1000包大米(有编号)放在仓库,最近仓库进水了,老板请了100个农民工,打算搬到外面让太阳晒晒,民工速度有快有慢,工钱根据搬运的大米数量计算,大米随机搬运。
   
   import java.util.HashMap;
import java.util.Iterator;
import java.util.Random;
import java.util.Vector;

public class Test3 {

	public static void n(String[] args) {
		Vector<Goods> goodsList = new Vector<Goods>();//进货
		GoodFactory factory = new GoodFactory(goodsList);//仓库
		for (int i = 0; i < 1000; i++) {
			Goods goods = new Goods(i);
			goodsList.add(goods);
		}

		//ExecutorService service = Executors.newScheduledThreadPool(10);//如果仓库很小
		for (int i = 0; i < 100; i++) {
			Person person = new Person(factory, i);
			new Thread(person).start();
			//service.execute(person);
		}

		//service.shutdown();
		while (factory.getGoodsCount() != 0) {
		}
		Iterator<Integer> iterator = factory.counter.values().iterator();
		int count = 0;
		while (iterator.hasNext()) {
			count += iterator.next();
		}
		System.out.println("共搬了" + count + "件商品");
	}
}

/**
 * 模拟工厂 类
 * @author ilikeido
 *
 */
class GoodFactory {

	Vector<Goods> goodsQueue;//商品

	HashMap<Person, Integer> counter = new HashMap<Person, Integer>();//统计员

	public GoodFactory(Vector<Goods> goodsQueue) {
		this.goodsQueue = goodsQueue;
	}

	/**
	 * 随机搬货
	 * @param person	工人
	 * @return 
	 */
	public synchronized Goods moveRandom(Person person) {
		int old = goodsQueue.size();
		if (old > 0) {
			int index = 0;
			try {
				index = new Random().nextInt(old - 1);
			} catch (Exception e) {
			}
			Goods goods = goodsQueue.get(index);
			goodsQueue.remove(index);
			person.say(goods);
			if (counter.get(person) == null) {
				counter.put(person, 1);
			} else {
				counter.put(person, counter.get(person) + 1);
			}
			return goods;
		}
		return null;
	}

	public int getGoodsCount() {
		return goodsQueue.size();
	}
}

/**
 * 工人
 * @author ilikeido
 *
 */
class Person implements Runnable {

	GoodFactory factory;

	public static ThreadLocal<Integer> count = new ThreadLocal<Integer>() {
		@Override
		protected Integer initialValue() {
			return 1;
		}
	};

	int id;

	public Person(GoodFactory factory, int id) {
		this.factory = factory;
		this.id = id;
	}

	/**
	 * 搬货
	 */
	public void move() {
		factory.moveRandom(this);
		count.set(count.get().intValue() + 1);
	}

	@Override
	public void run() {
		while (factory.getGoodsCount() > 0) {
			move();
			count.set(count.get() + 1);
			try {
				Thread.sleep(new Random().nextInt(1000));
			} catch (InterruptedException e) {
				e.printStackTrace();
			}
		}
	}

	public void say(Goods goods) {
		System.out.println(this.toString() + "搬运了" + goods.toString() + ",共搬了" + count.get() + "包");
	}

	public String toString() {
		return "工人" + id;
	}

}

/**
 * 商品
 * @author ilikeido
 *
 */
class Goods {

	int gflag;

	public Goods(int gflag) {
		this.gflag = gflag;
	}

	public String toString() {
		return "商品编号:" + gflag;
	}
}
分享到:
评论

相关推荐

    java多线程

    线程“装运工”占有CPU资源之后联合线程“仓库管理员”,也就是让“装运工”一直等到“仓库管理员”打开仓库才能开始搬运货物。 2. 编写一个包含主方法main的公共类(访问权限为public的类),在主方法main中,使用...

    搬运工代码

    "搬运工代码"是一个以Java编程语言开发的小游戏项目,主要目标是教授初学者如何进行游戏开发。这个项目特别适合那些对编程有热情但没有基础的人,它将引导你逐步了解编程的基本概念,并通过实际操作让你体验到游戏...

    Java线程核心技术及常见面试问题解答

    内容概要:本文详细介绍了Java线程的基本概念、线程的安全与同步机制、多种线程间通信方式、Java内存模型,以及线程池的原理与使用技巧,涵盖了许多常用的线程和并发控制组件如synchronized、ReentrantLock、...

    后台开发常问面试题集锦(问题搬运工,附链接)

    集合框架是Java中不可或缺的一部分,从List、Set、Map等基本数据结构到其线程安全的变种,如Vector、Hashtable、ConcurrentHashMap等,再到高级特性如fail-fast机制,了解这些集合的实现原理和适用场景对于编写高效...

    JAVA串口采集传感器数据

    `RxtxComm`是一个开源的Java库,它为Java提供了对串口通信的原生支持,使Java开发者能够像在C++或Python中那样方便地进行串口操作。 ### 三、RxtxComm库介绍 `RxtxComm`库提供了一个纯Java实现的API,用于访问操作...

    简单的java游戏。

    作为"搬运工",你的角色可能是将这位老师的成果分享给更多的人,让更多人能体验到这款游戏的魅力,同时也为学习Java游戏开发提供了实例。 【“真男人”标签】 "真男人"这个标签可能暗示游戏具有挑战性、竞技性或者...

    java单例模式实例

    单例模式是软件设计模式中的一种经典模式,用于确保一个类只有一个实例,并提供一个全局访问点。在Java中,有多种实现单例模式的方法,每种都有其特点和适用场景。接下来,我们将深入探讨这些实现方式。 首先,我们...

    java基础.txt 百度云

    深入理解 Java 多线程 Java 网络编程 手动开发一个 Web 服务器 深入理解 Java 注解+反射 Java23 种设计模式 学会 Java 正则表达式 JDBC 详解 Java 数据结构和算法 深入理解 Java 虚拟机 Java 解析XML文件

    Java程序员年中、年终述职报告PPT模板

    Java程序员在年中或年终述职报告中,通常需要展示过去一段时间内的工作成果、技术提升、项目经验以及未来规划。这份“Java程序员年中、年终述职报告PPT模板”旨在帮助他们高效地准备这类报告,通过专业且有条理的...

    java web 服务器 源码

    Java Web服务器源码是开发者学习和理解Web...同时,这也是一个了解Web服务器内部工作原理的好机会,例如线程管理、请求路由、会话管理等方面的知识。对于想要提升Java Web开发技能的人来说,这是一个极好的学习材料。

    java网络编程代码(仅供参考)

    服务器端可以为每个新连接创建一个新线程,或者使用线程池复用已有的线程。 5. **性能优化** 在网络编程中,优化包括减少数据的传输量、合理设置缓冲区大小、避免不必要的同步操作等。对于TCP,还可以考虑使用NIO...

    25个java热点面试题

    - **定义**:`@Deprecated` 是 Java 提供的一个内置注解,用于标记一个类、方法或者构造函数已被废弃,不建议继续使用。 - **作用**: - 帮助开发者识别已过时的代码元素,避免在新版本中使用这些元素。 - 在编译...

    10个java热点面试题

    **多线程**是Java中的一个重要特性,它允许多个线程并发执行。在Java中,可以通过以下两种主要方式实现多线程: - **继承Thread类**: 创建一个新的类继承自`Thread`类,并重写`run`方法。 - **实现Runnable接口**: ...

    Java面试宝典

    - **JDK(Java Development Kit)**: 包含了JRE,同时还包含了一系列开发工具,如编译器(javac)、调试器(jdb)等。JDK是开发Java应用程序所必需的。 - **区别**: JRE主要用于运行Java程序,而JDK主要用于开发Java...

    linux java7 jdk+openjdk

    Java 7,又称为Java SE 7(Java Standard Edition 7),是Oracle公司发布的一个重要版本,提供了许多新特性,如类型推断、多线程的Fork/Join框架、动态语言支持等。在Linux环境下,JDK 7的安装通常涉及下载对应的二...

    JAVA并发编程实践JavaConcurrencyinPractice-中文-高清-带书签-完整版Doug Lea 等著

    根据提供的文件信息,本书《JAVA并发编程实践JavaConcurrencyinPractice》由Doug Lea等著名作者撰写,是一本关于Java并发编程的专业书籍。本书主要聚焦于Java并发编程的基础理论与实践应用,适合对Java并发机制感...

    架构师图谱,java 架构师必学资料

    2. **Java架构师**:Java作为一门广泛应用的编程语言,其架构师需要对Java核心技术有深入理解,如JVM(Java虚拟机)、多线程、内存管理、垃圾回收机制等。此外,Java框架如Spring Boot、Spring Cloud、MyBatis等也是...

    Java核心知识点整理.rar

    下面,我们将详细探讨Java的核心知识点,并按照一个合理的学习路线进行阐述。 1. **基础知识**: - **数据类型与变量**:Java分为基本数据类型(如int、float、boolean等)和引用数据类型(如类、接口、数组)。...

    JAVA面试题大全,祝您面试顺利

    1. **Java基础知识面试题(2020最新版)**:这部分主要测试求职者的Java语言基础,包括但不限于语法、面向对象特性、异常处理、IO流、多线程、内存管理等。面试者应熟悉Java的基本概念,如类、接口、继承、封装、...

Global site tag (gtag.js) - Google Analytics