Java并发学习笔记(一)-Runnable和Executor

在多处理器情况下,并发能够提升程序的性能。在单处理器上,并发有什么优势?表面上看,单处理器时,并发程序往往由于增加了上下文切换导致程序CPU开销大,程序以单线程顺序执行开销会小一点,节省上下文切换的代价。

那么为什么要在单处理器上使用并发呢?有以下两个原因:

  1. 阻塞。程序的某个任务由于某些条件(一般是I/O),导致不能继续执行,那么这个任务或者线程阻塞了。单线程情况下,整个程序都将停下来,直到条件成熟。如果使用并发,当一个任务阻塞时,另外的任务还可以继续执行。如果如果没有任务阻塞,在单处理器上使用并发,会导致性能差。
  2. 简化程序设计。某些问题,比如游戏的人物,每个人物都很复杂,都有自己的独立的动作和任务,每一条线程管理一个人物,会简化程序。

(一)Thread和Runnable

线程有两种定义方式,一是继承Thread类,二是实现Runnable接口。以Runnable接口为例

public class BallThread implements Runnable{
	//Ball Count
	private static AtomicInteger count = new AtomicInteger(0);
	public final AtomicInteger id;
	private AtomicInteger kickCount = new AtomicInteger(0);
	
	public BallThread(){
		synchronized(count){
			this.id = new AtomicInt
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值