Java学习笔记(Java名词解释和多线程编程)

上传人:ji****72 文档编号:37542781 上传时间:2018-04-18 格式:DOC 页数:19 大小:70.50KB
返回 下载 相关 举报
Java学习笔记(Java名词解释和多线程编程)_第1页
第1页 / 共19页
Java学习笔记(Java名词解释和多线程编程)_第2页
第2页 / 共19页
Java学习笔记(Java名词解释和多线程编程)_第3页
第3页 / 共19页
Java学习笔记(Java名词解释和多线程编程)_第4页
第4页 / 共19页
Java学习笔记(Java名词解释和多线程编程)_第5页
第5页 / 共19页
点击查看更多>>
资源描述

《Java学习笔记(Java名词解释和多线程编程)》由会员分享,可在线阅读,更多相关《Java学习笔记(Java名词解释和多线程编程)(19页珍藏版)》请在金锄头文库上搜索。

1、名词解释名词解释 public class Thread1 implements Runnable public void run() synchronizedsynchronized(this) for (int i = 0; i 0) System.out.println(Thread.currentThread().getName() + “ : “ + i); try Thread.sleep(500); catch (InterruptedException ie) public void m4t2() int i = 5; while( i- 0) System.out.print

2、ln(Thread.currentThread().getName() + “ : “ + i); try Thread.sleep(500); catch (InterruptedException ie) public static void main(String args) final Thread2 myt2 = new Thread2(); Thread t1 = new Thread( new Runnable() public void run() myt2.m4t1(); , “t1“ ); Thread t2 = new Thread( new Runnable() pub

3、lic void run() myt2.m4t2(); , “t2“ ); t1.start(); t2.start(); 结果: t1 : 4 t2 : 4 t1 : 3 t2 : 3 t1 : 2 t2 : 2 t1 : 1 t2 : 1 t1 : 0 t2 : 0三、尤其关键的是,当一个线程访问 object 的一个 synchronizedsynchronized(this) 同步代码块时,其他线程对 object 中所有其它 synchronizedsynchronized(this)同步代码 块的访问将被阻塞。/修改 Thread2.m4t2()方法: public void m4

4、t2() synchronizedsynchronized(this) int i = 5; while( i- 0) System.out.println(Thread.currentThread().getName() + “ : “ + i); try Thread.sleep(500); catch (InterruptedException ie) 结果:t1 : 4 t1 : 3 t1 : 2 t1 : 1 t1 : 0 t2 : 4 t2 : 3 t2 : 2 t2 : 1 t2 : 0四、第三个例子同样适用其它同步代码块。也就是说,当一个线程访问 object 的一个 sync

5、hronizedsynchronized(this)同步代码块时,它就获得了这个 object 的 对象锁。结果,其它线程对该 object 对象所有同步代码部分的访问都被暂时 阻塞。/修改 Thread2.m4t2()方法如下:public synchronizedsynchronized void m4t2() int i = 5; while( i- 0) System.out.println(Thread.currentThread().getName() + “ : “ + i); try Thread.sleep(500); catch (InterruptedException

6、ie) 结果: t1 : 4 t1 : 3 t1 : 2 t1 : 1 t1 : 0 t2 : 4 t2 : 3 t2 : 2 t2 : 1 t2 : 0五、以上规则对其它对象锁同样适用:package ths;public class Thread3 class Inner private void m4t1() int i = 5; while(i- 0) System.out.println(Thread.currentThread().getName() + “ : Inner.m4t1()=“ + i); try Thread.sleep(500); catch(Interrupte

7、dException ie) private void m4t2() int i = 5; while(i- 0) System.out.println(Thread.currentThread().getName() + “ : Inner.m4t2()=“ + i); try Thread.sleep(500); catch(InterruptedException ie) private void m4t1(Inner inner) synchronizedsynchronized(inner) /使用对象锁 inner.m4t1(); private void m4t2(Inner i

8、nner) inner.m4t2(); public static void main(String args) final Thread3 myt3 = new Thread3(); final Inner inner = myt3.new Inner(); Thread t1 = new Thread( new Runnable() public void run() myt3.m4t1(inner); , “t1“); Thread t2 = new Thread( new Runnable() public void run() myt3.m4t2(inner); , “t2“); t

9、1.start(); t2.start(); 结果:尽管线程 t1 获得了对 Inner 的对象锁,但由于线程 t2 访问的是同一个 Inner 中的非同步部分。所以两个线程互不干扰。t1 : Inner.m4t1()=4 t2 : Inner.m4t2()=4 t1 : Inner.m4t1()=3 t2 : Inner.m4t2()=3 t1 : Inner.m4t1()=2 t2 : Inner.m4t2()=2 t1 : Inner.m4t1()=1 t2 : Inner.m4t2()=1 t1 : Inner.m4t1()=0 t2 : Inner.m4t2()=0现在在 Inner

10、.m4t2()前面加上 synchronizedsynchronized:private synchronizedsynchronized void m4t2() int i = 5; while(i- 0) System.out.println(Thread.currentThread().getName() + “ : Inner.m4t2()=“ + i); try Thread.sleep(500); catch(InterruptedException ie) 结果:尽管线程 t1 与 t2 访问了同一个 Inner 对象中两个毫不相关的部分,但因为 t1 先获得了对 Inner 的

11、对象锁,所以 t2 对 Inner.m4t2()的访问也被阻塞,因为 m4t2()是 Inner 中的一个同步方法。t1 : Inner.m4t1()=4 t1 : Inner.m4t1()=3 t1 : Inner.m4t1()=2 t1 : Inner.m4t1()=1 t1 : Inner.m4t1()=0 t2 : Inner.m4t2()=4 t2 : Inner.m4t2()=3 t2 : Inner.m4t2()=2 t2 : Inner.m4t2()=1 t2 : Inner.m4t2()=0第二篇:synchronizedsynchronized 关键字,它包括两种用法:sy

12、nchronizedsynchronized 方法和 synchronizedsynchronized 块。 1. synchronizedsynchronized 方法:通过在方法声明中加入 synchronizedsynchronized 关键字来声明 synchronizedsynchronized 方法。如: public synchronizedsynchronized void accessVal(int newVal); synchronizedsynchronized 方法控制对类成员变量的访问:每个类实例对应一把锁,每个 synchronizedsynchronized 方法

13、都必须获得调用该方法的类实例的锁方能执行,否则所属线程阻塞,方法一旦执行,就独占该锁,直到从该方法返回时 才将锁释放,此后被阻塞的线程方能获得该锁,重新进入可执行状态。这种机制确保了同一时刻对于每一个类实例,其所有声明为 synchronizedsynchronized 的成员函数中至多只有一个处于可执行状态(因为至多只有一个能够获得该类实例对应的锁),从而有效避免了类成员变量的访问冲突 (只要所有可能访问类成员变量的方法均被声明为 synchronizedsynchronized)。 在 JavaJava 中,不光是类实例,每一个类也对应一把锁,这样我们也可将类的静 态成员函数声明为 syn

14、chronizedsynchronized ,以控制其对类的静态成员变量的访问。 synchronizedsynchronized 方法的缺陷:若将一个大的方法声明为 synchronizedsynchronized 将会大大 影响效率,典型地,若将线程类的方法 run() 声明为synchronizedsynchronized ,由于在线程的整个生命期内它一直在运行,因此将导致它对 本类任何 synchronizedsynchronized 方法的调用都永远不会成功。当然我们可以通过将访问类成员变量的代码放到专门的方法中,将其声明为 synchronizedsynchronized ,并在主

15、方法中调用来解决这一问题,但是 JavaJava 为我们提供了更好的解决办法,那就是 synchronizedsynchronized 块。 2. synchronizedsynchronized 块:通过 synchronizedsynchronized 关键字来声明 synchronizedsynchronized 块。 语法如下: synchronizedsynchronized(syncObject) /允许访问控制的代码 synchronizedsynchronized 块是这样一个代码块,其中的代码必须获得对象 syncObject (如前所述,可以是类实例或类)的锁方能执行,具体机制同前所述。由于可以针对任意代码块,且可任意指定上锁的对象,故灵活性 较高。 对 synchronizedsynchronized(this)的一些理解 一、当两个并发线程访问同一个对象 object 中的这个 synchronizedsynchronized(this)同 步代码块时

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 行业资料 > 其它行业文档

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号