今天,我们开始Java高并发与多线程的第三篇,线程的基本属性和主要方法。

【属性】

  • 编号(ID)

  类型long

用于标识不同的线程,编号唯一,只存在java虚拟机的一次运行

  • 名称(Name)

  类型String

可以不设置,默认值为Thread-线程编号

  • 线程类别(Daemon)

  类型boolean

主要用于区分用户线程和守护线程

值为true表示该线程为守护线程,否则为用户线程

默认值与相应线程的父线程该属性值相同,该属性必须在线程启动前设置!否则会报错

    • 用户线程

    用户行为运行的线程;

一个Java虚拟机,必须等待所有的用户线程结束之后才可以停止运行。

    • 守护线程

    通常用于执行一些重要性不是很高的任务,比如监控资源等;

守护线程不会影响Java虚拟机的正常停止。

  • 优先级(Priority)

  类型int

该属性是给线程调度器的提示,用于表示应用程序那个线程优先运行,但是并不保证真实的线程执行顺序。

java定义了1~10的10个优先级别。默认值为5(普通优先级别)。

对应一个具体的线程而言,优先级别的默认值与父线程相同。

注:在JVM中,使用-Xss参数来控制每个线程分配的内存大小,默认JDK1.4中是256K,JDK1.5+中是1M.

【常用方法】

  • public static native Thread currentThread()

  返回当前线程,当前代码的执行线程

  • public long getId()

  此方法返回线程的唯一标识,是一个long型的正数,在线程创建的时候被赋值。

  • public final native boolean isAlive()

  isAlive方法用于判断当前线程是否处于活动状态。

什么是活动状态呢?

活动状态就是已经启动尚未终止的,线程处于正在运行或者准备开始运行的状态就认为线程是"活动"的。

(新建状态的线程isAlive()返回的是false)

  • public synchronized void start()

  启动线程

  • public void run()

  线程的实际执行方法

  • public void interrupt ()

  interrupt() 中断线程  由运行状态到死亡状态。

在Core Java中有这样一句话:"没有任何语言方面的需求要求一个被中断的程序应该终止。中断一个线程只是为了引起该线程的注意,被中断线程可以决定如何应对中断 "。

中断线程操作实质上是修改了一下中断标示位为true

当前线程正在运行,仅仅修改标示位,不再做其他的事

当前线程正在阻塞,修改标识位,如果是join,sleep,yield,则会抛出Interrup异常,修改标示位为false

  • public static boolean interrupted()

  测试当前线程是否已经是中断状态,执行后具有清除中断状态功能

  • public boolean isInterrupted()

  测试线程 Thread 对象是否已经是中断状态,但不清除中断状态标志

  • public static native void yield()

  此方法的作用是放弃当前的CPU资源,将它让给其他的任务去占用CPU的时间。但是放弃的时间不确定,有可能刚刚放弃就马上获得CPU时间片。

sleep 方法使当前运行中的线程睡眠一段时间,进入超时等待状态,这段时间的长短是由程序设定的,yield方法使当前线程让出CPU占有权,但让出的时间是不可设定的。

yield()不会释放锁标志

yield()只是使当前线程重新回到可运行状态,所以执行yield()的线程有可能在进入到可执行状态后马上又被执行。

yield()只能使同优先级或更高优先级的线程有执行的机会

  • public static native void sleep(long millis) throws InterruptedException

  sleep 导致当前线程休眠;

与 wait 方法不同的是 sleep 不会释放当前占有的锁

sleep(long)会导致线程进入 TIMED-WATING状态,而 wait()方法会导致当前线程进入 WATING状态

可以抛出中断异常

Thread.sleep(0)

由于Java采用抢占式的线程调度算法,因此可能会出现某条线程常常获取到CPU控制权的情况,为了让某些优先级比较低的线程也能获取到CPU控制权,可以使用Thread.sleep(0)手动触发一次操作系统分配时间片的操作,这也是平衡CPU控制权的一种操作。

  • void join()

  等待相应线程结束,若线程A调用B的join方法,那么线程A会被暂停,直到线程B运行结束。

join方法中如果传入参数,则表示这样的意思:如果A线程中掉用B线程的join(10),则表示A线程会等待B线程执行10毫秒,10毫秒过后,A、B线程并行执行。

join(0)等价于join()

  • public final void setPriority(int newPriority)

  设置线程优先级

  • public final void setDaemon(booleanon)

  将线程设置为守护线程

  • public static int activeCount()

  程序中活跃的线程数

  • public static native boolean holdsLock(Object obj)

  当前线程是否拥有某个具体对象的锁。

  • @Deprecated

  public final void stop()

强制停止,已废弃

可能释放锁导致数据不对。

可能导致清理工作做不好。

  • suspend和resume

  暂停和恢复

同上,已废弃。

  • public final native void wait (longtimeout)

  继承object

调用该方法的线程进入 WAITING 状态,只有等待另外线程的通知或被中断才会返回,需要注意的

是调用 wait()方法后,会释放对象的锁

因此,wait 方法一般用在同步方法或同步代码块中。

  • public final native void notify()

  继承自object

唤醒在此对象监视器上等待的单个线程,如果所有线程都在此对象上等待,则会选择唤醒其中一个线程,选择是任意的,并在对实现做出决定时发生,线程通过调用其中一个wait() 方法,在对象的监视器上等待,直到当前的线程放弃此对象上的锁定,才能继续执行被唤醒的线程,被唤醒的线程将以常规方式与在该对象上主动同步的其他所有线程进行竞争。

但是要注意,notify不释放锁

类似的方法还有 notifyAll() ,唤醒再次监视器上等待的所有线程。

  • public final native void notifyAll()

  把该对象等待队列里面的所有线程唤醒,成为可运行线程。

本篇比较短,但是因为容易被遗漏掉,所以单独拿出来讲,下一篇咱们讲多线程里面的重头戏------锁。

Java高并发与多线程(三)-----线程的基本属性和主要方法的更多相关文章

  1. Java高并发与多线程(二)-----线程的实现方式

    今天,我们开始Java高并发与多线程的第二篇,线程的实现方式. 通常来讲,线程有三种基础实现方式,一种是继承Thread类,一种是实现Runnable接口,还有一种是实现Callable接口,当然,如 ...

  2. Java高并发与多线程(四)-----锁

    今天,我们开始Java高并发与多线程的第四篇,锁. 之前的三篇,基本上都是在讲一些概念性和基础性的东西,东西有点零碎,但是像文科科目一样,记住就好了. 但是本篇是高并发里面真正的基石,需要大量的理解和 ...

  3. java高并发编程(三)

    java高并发主要有三块知识点: synchronizer:同步器,在多个线程之间互相之间怎么进行通讯,同步等: 同步容器:jdk提供了同步性的容器,比如concurrentMap,concurren ...

  4. Java高并发与多线程(一)-----概念

    其实之前一直想专门写一篇,单独说一说Java的多线程与高并发,但是一直以来,都没有想到能够用什么比较有趣的表现形式去表达出来,而且网上充斥着很多类似的博客,有好的又不好的,有简介的有繁琐的,所以也一直 ...

  5. Java高并发和多线程系列 - 1. 线程基本概念

    1. 什么是线程? 线程和进程的区别 在了解线程的概念前,我们应该先知道什么是进程? 进程是操作系统的基本概念之一, 它是正在执行的程序实例. * 下面的一些进程的基本概念你可以了解下 ------- ...

  6. java高并发实战(三)——Java内存模型和线程安全

    转自:https://blog.csdn.net/gududedabai/article/details/80816488

  7. Java高并发网络编程(三)NIO

    从Java 1.4开始,Java提供了新的非阻塞IO操作API,用意是替代Java IO和Java Networking相关的API. NIO中有三个核心组件: Buffer缓冲区 Channel通道 ...

  8. java高并发锁的三种实现

    提到锁大家会想到Synchronized同步关键字,使用它确实可以解决一切并发问题,但是对于体统吞吐量要求更高,在这里提供了几个小技巧.帮助大家减少锁粒度.提高系统的并发能力 一.乐观锁 试用场景:读 ...

  9. Java并发编程入门与高并发面试(三):线程安全性-原子性-CAS(CAS的ABA问题)

    摘要:本文介绍线程的安全性,原子性,java.lang.Number包下的类与CAS操作,synchronized锁,和原子性操作各方法间的对比. 线程安全性 线程安全? 线程安全性? 原子性 Ato ...

随机推荐

  1. react第三单元(react组件的生命周期)

    第三单元(react组件的生命周期) #课程目标 灵活掌握react组件的生命周期以及组件的活动过程. 能够灵活使用react的生命周期 #知识点 react的类组件的生命周期分为三个阶段 实例期 存 ...

  2. Web服务器-正则表达式-小例子(3.1.2)

    @ 目录 1.邮箱 2.手机号码 关于作者 1.邮箱 import re def main(): email = input("请输入一个邮件地址:") ret = re.matc ...

  3. 仙剑4CPK加密解密算法(转)

    // RSTEncDec.h: interface for the CRSTEncDec class. // ///////////////////////////////////////////// ...

  4. python lambda表达式应用

    在python中有两种函数,一种是通过def得到的函数,一种是匿名函数,也就是lambda表达式.语法格式如下: lambda argument_list:expersion 语法中的argument ...

  5. CI/CD自动化发版系统设计简介

    转载自:https://www.cnblogs.com/wellful/archive/2004/01/13/10604151.html 版本迭代是每一个互联网公司必须经历的,尤其是中小型公司,相信不 ...

  6. .NET Core 使用MediatR CQRS模式 读写分离

    前言 CQRS(Command Query Responsibility Segregation)命令查询职责分离模式,它主要从我们业务系统中进行分离出我们(Command 增.删.改)和(Query ...

  7. Word2Vec和LDA的区别与联系

    Word2vec是目前最常用的词嵌入模型之一.是一种浅层的神经网络模型,他有2种网络结构,分别是CBOW(continues bag of words)和 skip-gram.Word2vec 其实是 ...

  8. 查看权限详情 将部门大类单据整合,将子类单据id去重合并

    /** * 查看权限详情 * @param id 部门id * @return */ @GetMapping("getListInfo") public R getDetail(S ...

  9. Spring Boot面试杀手锏————自动配置原理

    转:https://blog.csdn.net/u014745069/article/details/83820511 引言不论在工作中,亦或是求职面试,Spring Boot已经成为我们必知必会的技 ...

  10. Linux服务器上搭建测试环境(war包+tomcat)

    悟空CRM项目环境部署(Java war项目) 在/root目录下创建一个文件夹(名字自取). ls命令查看一下是否创建成功,看到了新建的文件夹说明创建成功. tomcat和war包的准备:可以使用X ...