tortoiserun

导航

多线程分享(一)

一、什么是多线程

二、为什么使用多线程

•使用多线程的优点
–最大化使用硬件的资源(最大化利用CPU的性能)
–更合理的利用时间

 

•使用多线程的缺点
–线程同步问题
–死锁问题
 

三、多线程的程序如何运行

代码如下:
运行结果如下:

四、如何创建线程

•方式一:创建Thread对象,重写run()方法。代码如下:
•方式二:创建Thread对象,使用参数为Runnable的构造方法,传入Runnable接口实现类的实例。代码如下:

五、线程池

•线程池的优点
–避免了频繁的创建和销毁线程对象
–方便管理线程
•线程池的创建,代码如下:

六、线程同步问题

•现在有如下一个静态方法print(),方法将输入的字符串的字符逐一打印出来,代码如下:
•单线程调用该方法:
•运行结果:
•多线程调用该方法(两个线程,循环5次):
•运行结果:

七、解决线程同步问题(一)

•修改print()方法,加入synchronized关键字修饰,代码如下:
•运行结果:

八、解决线程同步问题(二)

•修改print()方法,使用Lock,代码如下:
•运行结果:

九、解决线程同步问题(三)

•修改print()方法,自定义锁,代码如下:
•运行结果:

十、实例:批量订单创建

•场景:批量创建100笔订单,订单状态全部为已付款未发货
•多线程模型:“生产者-消费者” 模型
–生产者工作:订单创建过程
–消费者工作:订单付款
–过程:生产者创建订单后,将订单放入一个池中,消费者去池中获取订单,然后进行付款操作
生产者和消费者各5个线程,共10个线程
•代码如下:

十一、死锁问题

十二、多线程下的单例模式

•单线程下的单例模式,代码如下:
•多线程下的单例模式,代码如下:
一个遗留问题
•ArrayList在循环过程中调用remove()方法,代码如下:
•出现以下异常:
 
后续分享内容预览
•多线程分享(二)
–多线程间的数据共享(ThreadLocal介绍)
–volatile关键字
–原子操作类介绍(基础类型对应的原子类型,如AtomicInteger等)
–读写锁
–阻塞条件Condition的使用
–异步任务处理(Callable、Future、ExecutorCompletionService)
•多线程分享(三)
–线程同步工具的使用(Semaphere、CyclicBarrier、CountDownLatch、Exchanger)
–堵塞队列(ArrayBlockingQueue等)与同步集合(ConcurrentLinkedQueue等)
 
 
 

 

posted on 2015-08-10 15:38  tortoiserun  阅读(158)  评论(0编辑  收藏  举报