多线程分享(一)
一、什么是多线程
二、为什么使用多线程
•使用多线程的优点
–最大化使用硬件的资源(最大化利用CPU的性能)
–更合理的利用时间
•使用多线程的缺点
–线程同步问题
–死锁问题
三、多线程的程序如何运行
代码如下:
![](https://images0.cnblogs.com/blog2015/647810/201508/101508510989252.png)
运行结果如下:
![](https://images0.cnblogs.com/blog2015/647810/201508/101509395208159.png)
四、如何创建线程
•方式一:创建Thread对象,重写run()方法。代码如下:
![](https://images0.cnblogs.com/blog2015/647810/201508/101511166765944.png)
•方式二:创建Thread对象,使用参数为Runnable的构造方法,传入Runnable接口实现类的实例。代码如下:
![](https://images0.cnblogs.com/blog2015/647810/201508/101512095359562.png)
五、线程池
•线程池的优点
–避免了频繁的创建和销毁线程对象
–方便管理线程
•线程池的创建,代码如下:
![](https://images0.cnblogs.com/blog2015/647810/201508/101513223799807.png)
六、线程同步问题
•现在有如下一个静态方法print(),方法将输入的字符串的字符逐一打印出来,代码如下:
![](https://images0.cnblogs.com/blog2015/647810/201508/101514219422778.png)
•单线程调用该方法:
![](https://images0.cnblogs.com/blog2015/647810/201508/101515420209746.png)
•运行结果:
![](https://images0.cnblogs.com/blog2015/647810/201508/101516319103639.png)
•多线程调用该方法(两个线程,循环5次):
![](https://images0.cnblogs.com/blog2015/647810/201508/101517353796248.png)
•运行结果:
![](https://images0.cnblogs.com/blog2015/647810/201508/101518279572653.png)
七、解决线程同步问题(一)
•修改print()方法,加入synchronized关键字修饰,代码如下:
![](https://images0.cnblogs.com/blog2015/647810/201508/101519336769374.png)
•运行结果:
![](https://images0.cnblogs.com/blog2015/647810/201508/101520088175306.png)
八、解决线程同步问题(二)
•修改print()方法,使用Lock,代码如下:
![](https://images0.cnblogs.com/blog2015/647810/201508/101521030042251.png)
•运行结果:
![](https://images0.cnblogs.com/blog2015/647810/201508/101521452709705.png)
九、解决线程同步问题(三)
•修改print()方法,自定义锁,代码如下:
![](https://images0.cnblogs.com/blog2015/647810/201508/101523046608518.png)
•运行结果:
![](https://images0.cnblogs.com/blog2015/647810/201508/101523368482251.png)
十、实例:批量订单创建
•场景:批量创建100笔订单,订单状态全部为已付款未发货
•多线程模型:“生产者-消费者” 模型
–生产者工作:订单创建过程
–消费者工作:订单付款
–过程:生产者创建订单后,将订单放入一个池中,消费者去池中获取订单,然后进行付款操作
生产者和消费者各5个线程,共10个线程![](https://images0.cnblogs.com/blog2015/647810/201508/101524583954205.jpg)
•代码如下:
![](https://images0.cnblogs.com/blog2015/647810/201508/101526053646912.png)
![](https://images0.cnblogs.com/blog2015/647810/201508/101526352392019.png)
十一、死锁问题
![](https://images0.cnblogs.com/blog2015/647810/201508/101527304426020.png)
十二、多线程下的单例模式
•单线程下的单例模式,代码如下:
![](https://images0.cnblogs.com/blog2015/647810/201508/101528400353026.png)
•多线程下的单例模式,代码如下:
![](https://images0.cnblogs.com/blog2015/647810/201508/101529174267368.png)
![](https://images0.cnblogs.com/blog2015/647810/201508/101529431925664.png)
一个遗留问题
•ArrayList在循环过程中调用remove()方法,代码如下:
![](https://images0.cnblogs.com/blog2015/647810/201508/101530435041305.png)
•出现以下异常:
![](https://images0.cnblogs.com/blog2015/647810/201508/101531560989793.png)
后续分享内容预览
•多线程分享(二)
–多线程间的数据共享(ThreadLocal介绍)
–volatile关键字
–原子操作类介绍(基础类型对应的原子类型,如AtomicInteger等)
–读写锁
–阻塞条件Condition的使用
–异步任务处理(Callable、Future、ExecutorCompletionService)
•多线程分享(三)
–线程同步工具的使用(Semaphere、CyclicBarrier、CountDownLatch、Exchanger)
–堵塞队列(ArrayBlockingQueue等)与同步集合(ConcurrentLinkedQueue等)
posted on 2015-08-10 15:38 tortoiserun 阅读(158) 评论(0) 编辑 收藏 举报