多线程分享(一)
一、什么是多线程

二、为什么使用多线程
•使用多线程的优点
–最大化使用硬件的资源(最大化利用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 阅读(173) 评论(0) 收藏 举报
浙公网安备 33010602011771号