多线程分享(一)

一、什么是多线程

二、为什么使用多线程

•使用多线程的优点
–最大化使用硬件的资源(最大化利用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等)
 
 
 

 

转载于:https://www.cnblogs.com/TortoiseRun/p/4718164.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值