1 线程中的几个方法解释

Thread.sleep(long 毫秒)

在指定的时间内让当前线程休眠,将控制权交给其他线程,休眠的线程依旧拥有它所占用的锁,

Thread.yield();

暂停或者放弃当前正在执行的线程,并且执行其他线程,但是并没有释放该线程所拥有的锁,线程放弃后,让其他相同或者更高线程得以运行。

t.join()

在A线程中等待t线程,可以指定一定时间后继续执行或者无限等待

t.interrupt()

中断t的线程,可以唤醒打断处于sleep,join和wait状态下的线程,

p.wait()

线程可以等待一个它锁定的对象,在等待的时候,它会释放此对象的锁并且暂停进入休眠,它会在时间到期、该线程被中断和对象得到通知之前一直保持休息。直到它得到了其他线程的通知,如该对象调用notify()和notifyAll()的时候才会执行。

对于使用wait和notify与notifyAll的时候均要先利用同步代码块或者同步方法获取该对象的锁,利用wait后,会首先获取该对象锁,然后进入该对象的wait set中,暂停当前的线程,释放该对象的锁,在该对象的wait set等待着

对于直接wait()就是this.wait(),执行wait()的线程会在this的wait set中等待着。

Yield和Sleep区别

sleep 方法使当前运行中的线程睡眠一段时间,进入不可以运行状态,这段时间的长短是由程序设定的,它只有被吵醒或者睡眠时间到才会继续运行;

yield方法使当前线程让出CPU占有权即时间片,重新排队,但让出的时间是不可设定的,该线程依然是可运行状态

yield()方法对应了如下操作:先检测当前是否有相同优先级的线程处于同可运行状态,如有,则把CPU的占有权交给该线程,否则继续运行原来的线程,所以yield()方法称为“退让”,它把运行机会让给了同等级的其他线程。

sleep 方法允许较低优先级的线程获得运行机会,但yield()方法执行时,当前线程仍处在可运行状态,它在队列中等候cpu调用,所以说是可运行状态(注意不是运行状态),所以不可能让出较低优先级的线程此时获取CPU占有权。在一个运行系统中,如果较高优先级的线程没有调用sleep方法,也没有受到I/O阻塞,那么较低优先级线程只能等待所有较高优先级的线程运行结束,方可有机会运行。

yield()只是使当前线程重新回到可运行状态,所有执行yield()的线程有可能在进入到可运行状态后马上又被执行,所以yield()方法只能使同优先级的线程有执行的机会
2 线程的启动

线程的启动永远都是调用Start()方法开始的, Thread.start ()方法启动线程,使之进入就绪状态,当cpu 分配时间片给该线程时,由 JVM 调度执行 run ()方法, 之所以要start和run方法的原因是,因为JVM 创建一个单独的线程不同于普通方法的调用,启动一个线程是由start 方法完成,start 由本地方法实现,需要显示地被调用。Run方法是真正执行的任务部分,另一个好处就是在于当一个对象需要继承多类的时候,此时就可以将具体的任务实现了 Runnable 接口,然后传递给Thread中,避免因继承了Thread 类而造成的 Java 的多继承问题。

对于同一个Thread类的实例变量,只能调用一次Start方法,一旦调用start方法,就会变成结束start状态,当其再次调用start方法的时候,就会出现IllegalThreadStateException,就会进行退让让线程的启动不会再次执行。Thread类的start方法采用的就是Balking Pattern模式。

多线程都是针对多个线程操作同一个对象下作用的。

3 Single Threaded Execution Pattern

Single Threaded Execution指的就是“只允许一个线程执行”的意思,它表明对于调用这个方法或对象的时候必须只能让一个线程来执行。利用synchronized来设置对象的监听器,在synchronized方法体或者同步块中。必须要注意synchronized实例方法共享的是类的实例对象的锁,而synchronized类方法即static synchronized的方法共享的是类的锁,这两把锁完全不同。

对于一个对象的某一个方法,当有多个线程需要访问的时候,这些线程是共享这个对象的所有成员属性的。线程是共享这个对象的内存。

Single Threaded Execution中,作为共享资源的类,即可以被多个线程访问的。有两种方法,安全方法和非安全方法,所谓的安全方法就是多个线程调用也不会出现问题。而非安全方法在多个线程访问的过程可能会出现问题。需要对于非安全方法做处理。
适用性:当共享资源类的实例可能被多个线程访问的时候,实例的状态即属性会被修改,在多个线程中,此时就需要对于对于实例的状态发生变化的范围作为临界区,利用synchronized来保护,实现临界区间,来监听多线程的访问。

4 Immutable Pattern

Immutable Pattern指的就是“有着能够保证实例的状态绝不会发生变化更改的类”,再次说明这里指实例的状态都是指的是类的成员属性。所谓的不能发生变化,也就是对于类的状态只允许赋值一次,且不会给外界提供任何setter方法,并且属性是private final,一般通过在构造器来对于这些状态赋值,当然也可以将类声明为final。利用这种方式,就克服利用共享互斥机制来造成的时间浪费。

Immutable Pattern参与者是一个字段值无法更改的类,也没有任何用来更改字段值的方法。当Immutable参与者的实例一旦创建后,状态就固定下来,无法更改了。
适用性:当实例产生后,状态不再发生变化。实例需要多个线程共享,访问很频繁的时候。

5 Guarded Suspension Pattern--要等到我准备好再通知你们哟

  Guarded Suspension指的意思是“在多线程中,当线程访问某一个资源时候,此时并不适合马上执行某个操作时,就要求想要执行该操作的线程必须等待。”Guarded是“被保护的”,suspension是“暂停”的意思。

Guarded Suspension要求线程必须等待。利用的就是wait,再通过notifyAll来通知所有等待的线程。将线程要执行某一个操作,必须满足的条件称为警戒条件。每个线程在执行的时候,如果不满足警戒条件就必须在等待,只有收到通知后,判断警戒条件成功后,才能进而执行所要的目的操作。

常用的警戒条件结构如下:

public synchronized void methodName()

{

while(警戒条件的否定)

使用wait;//这里直接在共享类中wait,所有等待的都会进入该类实例的this wait set中等候

//跳出循环,说明满足警戒条件

执行目的操作。

}
注:不能将while替换为if,因为凡是处于等待中的线程一旦获得唤醒,就必须在执行目的操作之前先进行警戒条件的判断才能进而执行目的操作。必须将捕获wait的异常包括在while循环体中,否则一旦发生异常可能就会进而执行目的操作。这里的wait也不能换为sleep,因为利用sleep该线程会一直拥有它所获得锁。

在这里wait和notify都是隐藏在共享资源中,这样凡是使用该共享资源的线程就不需要考虑这些问题了。

GuardedObject参与者是一个拥有被防卫的方法guardedMethod,一般就是利用synchronized来修饰,在线程执行这个方法的时候,只要满足警戒条件就会执行,否则就会一直等待。警戒条件会随着实例的状态变化而变化。还需要一个更改实例状态的方法stateChangingMethod,来通知那些等待的线程。

一般使用while语句和wait方法来实现guardedMethod,使用notify和notifyAll来实现stateChangingMethod

6 Balking Pattern

Balking Pattern指的是“多线程访问共享资源时候,当现在不适合进行这个操作,或者没有必要进行这个操作的时候,此时就会直接放弃进行这个操作而返回”。

Balking Pattern也是需要警戒条件的。GuardedObject参与者是一个拥有被防卫的方法guardedMethod,一般就是利用synchronized来修饰,在线程执行这个方法的时候,只要满足警戒条件就会执行,否则就会。警戒条马上返回,直接退出该方法。警戒条件的成立会随着实例的状态变化而变化。还需要一个更改实例状态的方法stateChangingMethod,来通知那些等待的线程。

警戒条件的结构:

public synchronized void guardedMethod()

{

if(警戒条件否定)

return ;

//警戒条件满足情况

目的操作

}
适用性:在线程访问警戒条件不成立的时候,不需要刻意执行等待的时候,不想一直等待警戒条件成立的时候,或者警戒条件只有第一次成立的时候。注意线程的start方法就是利用这种方式的,即只有第一次成立的时候才会调用,第二次调用就会出错。

Java多线程设计模式(1)的更多相关文章

  1. java多线程设计模式

    详见:http://blog.yemou.net/article/query/info/tytfjhfascvhzxcyt220 java多线程设计模式 java语言已经内置了多线程支持,所有实现Ru ...

  2. [温故]图解java多线程设计模式(一)

    去年看完的<图解java多线程设计模式>,可惜当时没做笔记,导致后来忘了许多东西,打算再温习下这本书,顺便在这里记录一下~  1.顺序执行.并行.并发 顺序执行:多个操作按照顺序依次执行. ...

  3. Java多线程设计模式(一)

    目录(?)[-] Java多线程基础 Thread类的run方法和start方法 线程的启动 线程的暂时停在 线程的共享互斥 线程的协调 Single Threaded Execution Patte ...

  4. Java多线程设计模式(4)线程池模式

    前序: Thread-Per-Message Pattern,是一种对于每个命令或请求,都分配一个线程,由这个线程执行工作.它将“委托消息的一端”和“执行消息的一端”用两个不同的线程来实现.该线程模式 ...

  5. Java多线程设计模式(四)

    目录(?)[-] Future Pattern Two-Phase Termination Pattern Thread-Specific Storage Pattern Active Object ...

  6. Java多线程设计模式(三)

    目录(?)[-] Read-Wirte Lock Pattern Thread-Per-Message Pattern Worker Thread Pattern   Read-Wirte Lock ...

  7. Java多线程设计模式(二)

        目录(?)[-] Guarded Suspension Pattern Balking Pattern Producer-Consumer Pattern   Guarded Suspensi ...

  8. Java多线程设计模式系列

    通过几天的认真阅读,发现这是一本难得一见的好书,为了加深巩固学习成功,我打算将书中的例子全部自己实现一遍,特此记录下来也方便其他朋友学习. 第一章,java语言的线程 单线程程序:打印10000次go ...

  9. java多线程设计模式(3)读写锁模式

    1 Read-Write Lock Pattern Read-Write Lock Pattern是一种将对于共享资源的访问与修改操作分离,称为读写分离.即访问是reader,修改是write,用单独 ...

随机推荐

  1. ubantu 系统常见问题

    1 搜狗输入法错误: 删除home路径下的 .config/SouGouP...整个文件夹并重启 2  ubantu系统更新:sudo apt-get update  获取最近更新的软件包列表     ...

  2. Android 程序怎么打log

    常见的做法: 1. 定义一个常量(变量)作为是否输出log的flag: 2. 定义一个常量(变量)作为log级别设定: 2. 调试.打包时,按需要调整常量的值,从而控制log打印. 常见代码参考: h ...

  3. 历届试题 带分数 全排列模板 JAVA

    标题:带分数 100 可以表示为带分数的形式:100 = 3 + 69258 / 714 还可以表示为:100 = 82 + 3546 / 197 注意特征:带分数中,数字1~9分别出现且只出现一次( ...

  4. 团队Alpha版本(七)冲刺

    目录 组员情况 组员1(组长):胡绪佩 组员2:胡青元 组员3:庄卉 组员4:家灿 组员5:凯琳 组员6:翟丹丹 组员7:何家伟 组员8:政演 组员9:黄鸿杰 组员10:刘一好 组员11:何宇恒 展示 ...

  5. qemu中device和driver的区别 使用9p文件系统

    qemu配置中经常会出现-driver/-device的选项,可以理解成-driver是后端设备,即一个实际的物理的磁盘:device是把这块磁盘插入到虚机中的pci控制器中. 这样的话,虚机也能看到 ...

  6. 【bzoj1927】[Sdoi2010]星际竞速 有上下界费用流

    原文地址:http://www.cnblogs.com/GXZlegend/p/6832464.html 题目描述 10年一度的银河系赛车大赛又要开始了.作为全银河最盛大的活动之一,夺得这个项目的冠军 ...

  7. [洛谷P4178]Tree

    题目大意:给一棵树,问有多少条路径长度小于等于$k$ 题解:点分治 卡点:无 C++ Code: #include <cstdio> #include <algorithm> ...

  8. 2017 多校6 String

    多校6 String(ac自动机) 题意: 给一本有\(n\)个单词的字典 \(q\)个查询 \(pref_i,suff_i\) 查询字典里有多少单词前缀匹配\(pref_i\),后缀同时匹配\(su ...

  9. 洛谷 P2041 分裂游戏 解题报告

    P2041 分裂游戏 题目描述 有一个无限大的棋盘,棋盘左下角有一个大小为 n 的阶梯形区域,其中最左下角的那个格子里有一枚棋子.你每次可以把一枚棋子"分裂"成两枚棋子,分别放在原 ...

  10. javascript传递参数如果是object的话,是按值传递还是按引用传递?

    作者:苏墨橘链接:https://www.zhihu.com/question/27114726/answer/35481766来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明 ...