volatile 异常 sleep()和wait() 浅克隆
作者:
张文超ai | 来源:发表于
2019-02-28 17:50 被阅读0次//一个共享变量被volatile修饰的含义:
/* 1.保证了不同线程对这个变量进行操作是的可见性,
* 即一个线程修改了变量的值,这个新值对其他线程来说是可见的
* 2.禁止进行指令重排序。volatile修饰的变量,每次被访问都
* 是从内存中读取新值,不会使用寄存器缓存该值
*
*/
//java异常分,运行时异常,非运行时异常(检查性异常),error
/* 1.运行时异常不需要我们处理,jvm会帮助处理
* 类转换异常,类notfound异常,数组越界异常,空指针异常,数组存储异常
* IO的bufferoverflow异常
* 2.非运行异常需要我们手动捕获或者抛出
* 3.error是系统异常,描述了系统内部错误或者资源耗尽等,不需要捕捉
*
*
* try抛出异常,先执行catch语句,再执行finally,再执行catch的return
*
*/
/*
* Java中的多线程是一种抢占式的机制,而不是分时机制。抢占式的机制是有多个线程处于可运行状态,但是只有一个线程在运行。
共同点 :
1. 他们都是在多线程的环境下,都可以在程序的调用处阻塞指定的毫秒数,并返回。
2. wait()和sleep()都可以通过interrupt()方法 打断线程的暂停状态 ,从
而使线程立刻抛出InterruptedException。
如果线程A希望立即结束线程B,则可以对线程B对应的Thread实例调用interrupt方法。
如果此刻线程B正在wait/sleep/join,则线程B会立刻抛出InterruptedException,
在catch() {} 中直接return即可安全地结束线程。
需要注意的是,InterruptedException是线程自己从内部抛出的,并不是interrupt()
方法抛出的。对某一线程调用 interrupt()时,如果该线程正在执行普通的代码,那么该线程根本就不会
抛出InterruptedException。但是,一旦该线程进入到 wait()/sleep()/join()后,就会立刻
抛出InterruptedException 。
不同点 :
1.每个对象都有一个锁来控制同步访问。Synchronized关键字可以和对象的锁交互,来实现线程的同步。
sleep方法没有释放锁,而wait方法释放了锁,使得其他线程可以使用同步控制块或者方法。
2.wait,notify和notifyAll只能在同步控制方法或者同步控制块里面使用,而sleep可以在任何地方使用
3.sleep必须捕获异常,而wait,notify和notifyAll不需要捕获异常
4.sleep是线程类(Thread)的方法,导致此线程暂停执行指定时间,给执行机会给其他线程,但是监控状态依然
保持,到时后会自动恢复。调用sleep不会释放对象锁。
5.wait是Object类的方法,对此对象调用wait方法导致本线程放弃对象锁,进入等待此对象的等待锁定池,只有
针对此对象发出notify方法(或notifyAll)后本线程才进入对象锁定池准备获得对象锁进入运行状态。
*/
/*浅 克隆是先实现cloneable接口,然后在需要克隆的类里面定义一个克隆方法返回super.clone()
* 接下来调用克隆类的克隆方法,进行类的克隆操作
* 注意:浅克隆是在原有对象上克隆出来一个副本,副本对象地址和原对象地址不同
* 优点是这样克隆效率比较高!
*
*/
本文标题:volatile 异常 sleep()和wait() 浅克隆
本文链接:https://www.haomeiwen.com/subject/dnykuqtx.html
网友评论