day20、多线程下的单例模式

● 定时器
○ 1、创建任务类,继承TimerTask
○ 2、覆写run方法
○ 3、在主线程创建Timer对象,调用schedule方法
timer.schedule(new TimerTest(),new Date(),1000);
//第一个参数timerTask类中的run方法就是你想要做个事
//第二个参数从。。。开始(当前时间之前的,立刻开始执行,当前时间之后,等到了开始执行)
//第三个参数 每隔多少毫秒执行一次
● 死锁
○ 不同的线程分别占用对方需要的同步资源不放弃,都在等待对方放弃自己需要的同步资源,就形成了线程的死锁。
○ 出现死锁后,不会出现异常,不会出现提示,只是所有的线程都处于阻塞状态,无法继续
○ 解决方法
■ 专门的算法、原则
■ 尽量减少同步资源的定义
■ 尽量避免嵌套同步
● 线程通信
○ a) wait():令当前线程挂起并放弃CPU、同步资源并等待,使别的线程可访问并修改共享资源,并释放锁而当 前线程排队等候其他线程调用notify()或notifyAll()方法唤醒,唤醒后等待重新获得对监视器的所有 权后才能继续执行。
○ b) notify():唤醒正在排队等待同步资源的线程中优先级最高者结束等待
○ c) notifyAll ():唤醒正在排队等待资源的所有线程结束等待.
○ 注意:这三个方法只有在synchronized方法或synchronized代码块中才能使用,否则会报java.lang.IllegalMonitorStateException异常。
● 单例模式
○ 1、私有化构造方法
○ 2、提供一个公共的静态方法供外部获取对象
○ 3、需要提供一个私有静态变量,保存这个对象
○ 多线程下的单例模式
■ 1、双重判断
■ 2、防止指令重排,volatile修饰符修饰静态变量,让内存中的对象对线程可见
● 生产者消费者

● 网络编程概述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值