首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Java线程(四):线程中断、线程让步、线程睡眠、线程合并

本篇文章是插进来的,因为原来没有写,现在来看传统线程描述的不太完整,所以就补上了。理解了线程同步和线程通信之后,再来看本文的知识点就会简单的多了,本文是做为传统线程知识点的一个补充。...另外一点,了解传统线程的工作原理,使我们在使用并发包时更加得心应手。 线程中断        线程中断涉及到三个方法,如下: void interrupt()           中断线程。...很多人实现一个线程类时,都会再加一个flag标记,以便控制线程停止执行,其实完全没必要,通过线程自身的中断状态,就可以完美实现该功能。...线程让步 static void yield()           暂停当前正在执行的线程对象,并执行其他线程        线程让步用于正在执行的线程,在某些情况下让出CPU资源,让给其它线程执行...,所谓合并,就是等待其它线程执行完,再执行当前线程,执行起来的效果就好像把其它线程合并到当前线程执行一样。

1.6K00
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    线程(二)线程互斥+线程同步

    Linux线程互斥 线程间互斥相关概念 临界资源:多线程执行流共享的资源叫做临界资源。...互斥量mutex 大部分情况,线程使用的数据都是局部变量,变量的地址空间在线程栈空间内,这种情况,变量归属单个线程,其他线程无法获得这种变量。...但有时候,很多变量都需要在线程间共享,这样的变量称为共享变量,可以通过数据的共享,完成线程之间的交互。 多个线程并发的操作共享变量,会带来一些问题。...代码必须要有互斥行为:当代码进入临界区执行时,不允许其他线程进入该临界区。 如果多个线程同时要求执行临界区的代码,并且临界区没有线程在执行,那么只能允许一个线程进入该临界区。...函数是可重入的,那就是线程安全的 函数是不可重入的,那就不能由多个线程使用,有可能引发线程安全问题 如果一个函数中有全局变量,那么这个函数既不是线程安全也不是可重入的 可重入与线程安全区别 可重入函数是线程安全函数的一种

    1.2K10

    【Java】线程线程安全、线程状态

    本期介绍 本期主要介绍线程线程安全、线程状态 文章目录 第一章 线程 1.1 多线程原理 1.2 Thread类 1.3 创建线程方式二 1.4 Thread和Runnable的区别 1.5 匿名内部类方式实现线程的创建...第二章 线程安全 2.1 线程安全 2.2 线程同步 2.3 同步代码块 2.4 同步方法 2.5 Lock锁 第三章 线程状态 3.1 线程状态概述 3.2 Timed Waiting(计时等待)...当执行线程的任务结束了,线程自动在栈内存中释放了。但是当所有的执行线程都结束了,那么进 程就结束了。...2.2 线程同步 当我们使用多个线程访问同一资源的时候,且多个线程中对资源有写的操作,就容易出现线程安全 问题。...比如,线程 A 与线程 B 代码中使用同一 锁,如果线程 A 获 取到锁,线程 A 进入到 Runnable 状态,那么线程 B 就进入到 Blocked 锁阻塞状态。

    1.7K30

    线程&多线程

    当多线程中出现了相互谦让,都主动将资源释放给别 的线程使用,这样这个资源在多个线程之间跳动而又得不到执行,这就是活锁。...饥饿 我们知道多线程执行中有线程优先级这个东西,优先级高的线程能够插队并优先执 行,这样如果优先级高的线程一直抢占优先级低线程的资源,导致低优先级线程无 法得到执行,这就是饥饿。...(1)继承 Thread 类实现多线程 (2)实现 Runnable 接口方式实现多线程 (3)使用 ExecutorService、Callable、Future 实现有返回结果的多线程 (4)通过线程池创建线程...RUNNABLE: 表示线程已经触发 start()方式调用,线程正式启动,线程处于运行中 状态。...单核 CPU 上所谓的"多线程"那是 假的多线程,同一时间处理器只会处理一段逻辑,只不过线程之间切换得比较快, 看着像多个线程"同时"运行罢了。

    79720

    线程(一)线程概念+线程控制

    1.Linux线程概念 什么是线程 在一个程序里的一个执行路线就叫做线程(thread)。...线程可以同时等待不同的I/O操作。 线程的缺点 性能损失 一个很少被外部事件阻塞的计算密集型线程往往无法与共它线程共享同一个处理器。...编程难度提高 编写与调试一个多线程程序比单线程程序困难得多 线程异常 单个线程如果出现除零,野指针问题导致线程崩溃,进程也会随着崩溃 线程是进程的执行分支,线程出异常,就类似进程出异常,进而触发信号机制...,终止进程,进程终止, 该进程内的所有线程也就随即退出 线程用途 合理的使用多线程,能提高CPU密集型程序的执行效率 合理的使用多线程,能提高IO密集型程序的用户体验 2.Linux进程VS线程 进程和线程...pthread_ create函数第一个参数指向一个虚拟内存单元,该内存单元的地址即为新创建线程线程ID,属于NPTL线程库的范畴。线程库的后续操作,就是根据该线程ID来操作线程的。

    1.1K20

    Python 线程 - 多线程

    线程 python的thread模块是比较底层的模块,python的threading模块是对thread做了一些包装的,可以更加方便的被使用 1....说明 可以明显看出使用了多线程并发的操作,花费时间要短很多 当调用start()时,才会真正的创建线程,并且开始执行 2....主线程会等待所有的子线程结束后才结束 [root@server01 many_task]# vim test3.py #coding=utf-8 import threading from time...Wed Dec 12 00:12:03 2018 抽烟...1 喝酒...1 抽烟...2 喝酒...2 [root@server01 many_task]# 可以看出,虽然瞬间打印了结束的时间,但是主线程还是等子线程跑完了...:3 当前运行的线程数为:3 抽烟...1 当前运行的线程数为:3 喝酒...1 当前运行的线程数为:3 抽烟...2 当前运行的线程数为:3 喝酒...2 当前运行的线程数为:3 当前运行的线程数为:

    94230

    【C++ 语言】线程 ( 线程创建方法 | 线程标识符 | 线程属性 | 线程属性初始化 | 线程属性销毁 | 分离线程 | 线程调度策略 | 线程优先级 | 线程等待 )

    文章目录 I 线程创建方法 II 线程执行函数 III 线程标识符 IV 线程属性 V 线程属性 1 ( 分离线程 | 非分离线程 ) VI 线程属性 2 ( 线程调度策略 ) VII 线程属性...3 ( 线程优先级设置 ) VIII 线程等待 IX 互斥锁 X 线程代码示例 I 线程创建方法 ---- 1....线程的默认属性 : 线程创建后 , 默认是非分离线程 ; 2....非分离线程 与 分离线程 比较 : ① 设置非分离线程属性 : 先执行完线程内容 , 等待线程执行完毕后 , 才执行 pthread_join 后的代码 ; ② 设置分离线程属性 : pthread_join...线程函数执行完毕 ; // 非分离线程允许在其它线程中 , 来等待另外线程执行完毕 ; //分离线程 : // 不能被其它线程操作 , 如调用 pthread_join 函数 , 无法等待该分离线程执行完毕

    1.6K10

    话说 用户线程&守护线程&线程组&线程优先级

    用户线程&守护线程&线程组&线程优先级 如果把公司比喻成进程, 那么你和我就是用户线程, 后勤部门就是守护线程(负责给你订水,打扫办公环境等), 每个项目组就是一个线程组, 程序员等级就是优先级(高级程序员..."守护线程":"用户线程"); } } // 输出: 用户线程 2 我们看一下main线程中新建的线程 public static void main(String[] args) {..."t=守护线程":"t=用户线程"); } // 输出 t=用户线程 3 我们看一下main线程中的线程中的线程 public static void main(String[] args) {..."t2= 守护线程":"t2=用户线程"); }).start(); } 输出: t2= 用户线程 4 我们定义一个deamon线程 然后在这个线程中新建一个线程看看 新建的这个线程是不是与父线程一致...线程组作用 首先 他们表示线程所属 , 比如你操作一个线程的时候,如果他是main线程组的你就过滤掉 期次线程组提供了一些方法来批量操作线程: public static void main

    91800

    线程(守护线程

    我们一般使用多线程,都是while的死循环,想要结束线程,只需退出死循环即可 当线程中调用了sleep()方法或者wait()方法,当前的线程就会进入冻结状态,这个线程就结束不了 调用Thread对象的...interrupt()方法,可以强制解冻,此时run()方法中需要捕获到InterruptException异常,然后进行处理,就可以关闭线程了 调用Thread对象的setDaemon()方法,参数:...true 守护线程是后台线程,当前台线程全都结束以后,后台线程自动结束 class Ticket implements Runnable { private int nums = 100;...setDaemon(true); t2.setDaemon(true); t1.start(); t2.start(); //主线程执行...1秒就结束,其他守护线程还没走完也会结束 while(true){ try { Thread.sleep(1000);

    51310

    线程笔记(四)线程的状态,线程的停止,线程的休眠,线程礼让,join,线程优先级,守护线程

    线程 线程方法 线程的停止(建议) 线程的休眠 线程礼让 A和B 两个线程,当CPU执行B的时候,B进行礼让,那么就离开cpu,这个时候B就变为就绪状态,CPU就重新 在A线程和B线程之间进行选择...join 相当于插队 线程的优先级 利用代码设置线程的优先级 和 获取线程的优先级 public class Priority { public static void main(...main函数就是用户线程 gc 垃圾回收机制 就是 守护线程 当我们执行一段程序,里面有很多的线程,其中一个线程是守护线程,那么当其他线程执行完毕,这个守护线程就关闭了,虚拟机是不管守护线程是否关闭的..."); } System.out.println("我结束了"); } } 思路: 我们参加一个 用户线程,一个守护线程,如果一个线程要变为守护线程,那么必须手动设置为...当我们用户线程走完,整个就结束了,虚拟机是不管守护线程是否走完的。 守护线程不用管

    65030

    【Linux】详解线程控制之线程创建&线程终止&线程等待&线程分离

    一、线程创建 thread:这是一个指向pthread_t类型的指针,用于获取新创建线程线程ID。在调用pthread_create后,这个指针会被设置为新线程的ID。...二、线程终止 终止线程的三种方法 在线程函数的内部使用return语句。 在线程函数的内部使用pthread_exit函数。 在主线程中使用pthread_cancel函数,可以回收指定的子线程。...pthread_join函数可以用来回收子线程,第一个参数为子线程的id, 第二个参数可以得到子线程的退出信息。...主线程退出整个进程就跟着退出了,也就意味着主线程退出所有线程都要跟着退出,所以我们一般需要主线程最后退出来等待回收子线程。...四、线程创建、终止、回收的例子 下面由主线程创建一批子线程,分配给子线程任务,子线程将结果封装起来并返回给主线程,主线程由此可以获取子线程的执行结果。

    36500

    线程——线程概念和线程控制

    线程图片线程的概念什么是线程在一个程序里的一个执行路线就叫做线程(thread)。...实际上线程内的变量存储在线程的子栈结构中,即线程具有自己独立的栈结构。图片线程的优点创建一个新线程的代价要比创建一个新进程小得多。...值得注意,新线程引发段错误,OS向新线程所在的进程发送信号来终止,那么新线程和主线程赖以利用的资源将会被进程回收,以至于线程都被终止了。...通过ldd可以看到,线程库是磁盘上的文件图片线程库内有部分线程的数据结构,如 struct pthread,当中包含了对应线程的各种属性;线程局部存储,当中包含了对应线程被切换时的上下文数据;线程栈。...线程的其余数据结构或资源由OS提供,并且线程由OS调度,这部分线程被称为内核级线程,用户级线程:内核级线程=1:1每创建出一个线程线程库中就具有一个这样的用户级线程数据结构,其中线程ID指向线程数据结构的首地址

    44610

    线程——线程交互

    在实际功能中,会存在一些线程交互的情况。比如:一个线程执行某个操作,当操作的对象到达某种状态时,会等待其他线程来执行。...下面代码的功能是,一个线程对一个数字执行减少方法,当减到1时,等待增加线程操作。...但是由于增加线程比减少线程慢,所以最后会一直在1、2之间徘徊。 wait、notify和notifyAll wait:让占用了这个同步对象的线程,临时释放当前的占用,并且等待。...notify:通知一个等待在这个同步对象上的线程,你可以苏醒过来了,有机会重新占用当前对象了。当这个线程执行完再次释放后,之前等待的线程会重新开始占用,并不会一直等下去。...notifyAll:通知所有的等待在这个同步对象上的线程,你们可以苏醒过来了,有机会重新占用当前对象了。

    14700

    线程与Java线程

    操作系统线程的实现有3种方式:使用内核线程实现,使用用户线程实现,使用用户线程加轻量级进程混合实现。 ? ? ?...在JDK中代表线程的是Thread类,Java Thread定义了线程名、线程ID、优先级、是否守护线程、执行目标、线程组、线程状态等属性。...线程join:在线程A中,线程B调用join方法(可带时间参数),会使线程A进入等待,直到线程A结束生命周期或者超过指定的时间参数,在此期间线程B处于BLOCKED状态。...线程关闭:stop方法(已过期,不建议使用);正常关闭(线程结束生命周期正常结束;捕获中断信号关闭线程;使用volatile变量控制线程关闭);异常关闭(通过抛出异常退出线程;进程假死-线程阻塞或者死锁导致...线程的sleep和wait看起来都是让线程进入等待状态,不过二者是有区别的,线程sleep之后,不会释放调monitor对象锁,只有当线程执行完成之后,其他线程才可以重新进入,而线程wait之后,当前线程会释放调

    1.7K30

    Python多线程、阻塞线程线程同步和守护线程实例详解

    一、多线程(主线程和子线程同时执行) 1、主线程是程序本身,看不到的,主线程和子线程没有依赖关系,同步执行的,若主线程先执行完,会等子线程执行完毕,程序结束 2、启动一个线程就是把一个函数传入并创建Thread...;子线程运行完,主线程可能还在运行 二、多线程线程阻塞,子线程.join()(设置在start之后,等所有阻塞线程运行完,再运行主线程) 1、阻塞主线程必须在start()方法后执行,t1.join(...(timeout)此方法有个timeout参数,是线程超时时间设置 4、阻塞线程和非阻塞线程实例 #非阻塞线程,主线程休眠1s,子线程休眠3s 时间未统计到子线程,只统计到主线程的,说明主线程和子线程是同步执行的...exit code 0 三、守护线程(设置在start之前,设置子线程A为守护线程,主线程所在的进程内所有非守护线程统统运行完毕 ,无论子线程A有没有结束,程序都结束 1、主线程退出时,不等那些子线程完成...,主线程才算运行完毕 10、守护线程实例 #设置线程1和线程2为守护线程 因为程序没有其他非守护线程,所以当主线程运行完,不等线程1和线程2,就直接结束 import threading,time

    4.7K40
    领券