Java多线程

线程可以理解为是在进程中独立运行的子任务。

Java多线程

使用方法

Java中实现多线程主要有以下两种方法:

  • 继承Thread,而后实例化该对象调用start()即启动了新线程;
  • 实现Runnable,通过new Thread(Runnable run)实例化该线程,而后调用start();

常用方法

  • Thread.currentThread() 静态方法,获取当前线程对象;
  • isAlive() 判断线程是否处于活动状态,即线程已启动且尚未终止;
  • Thread.sleep(long ) 在指定的毫秒数内让当前线程休眠,需要catch InterruptedException
  • Thread.interrupted() 判断该线程是否中断,执行后将清除中断标志;
  • isInterrupted() 测试线程是否已经中断;
  • suspend() resume() stop() 暂停、开始和结束线程,不应该使用。暂停方法不会释放资源;
  • yield() 该线程放弃当前CPU资源,放弃后马上进行CPU竞争;
  • setPriority() 设置线程优先级,1~10,越大优先级越高;
    • 优先级具有继承性,即子线程有父线程的优先级;
    • 高优先级的线程总是大部分先执行完,但不代表高优先级将全部先完成;
    • 优先级较高的不一定每一次都先执行完,具有随机性;
    • 具体的与OS相关;
  • setDaemon() 设置守护线程,当进程不存在非守护线程时则守护线程将销魂而后进程销毁;

停止线程

停止线程有一下方法:

  1. 使用退出标志,在线程中检查标志判断是否退出。
  2. 使用stop方法强制终止线程,该方法可能导致线程不安全,不要使用。
  3. 使用interrupt方法中断线程,其原理就是第1条,只是Thread对其进行了封装。
  • 使用interrupt中断结合异常退出线程,在线程中当读到中断标志已经设置,可在此时抛出InterruptedException使线程退出。
  • 在sleep状态下如果该线程被中断,则将进入catch InterruptedException同时将清除中断标志。
  • 使用interrupte与return实现停止线程,但是仍然建议使用异常退出,这样可以保留中断异常使线程停止异常得到传播。

同步

非线程安全:存在多个线程对同一个对象中的实例变量进行并发访问控制由此导致的数据脏读;

  • 方法内的局部变量和实例内的私有变量(不存在get/set)均不能被外部访问,因此是线程安全的;

synchronized

  • synchronized取得的是对象锁而非方法或代码块的锁;
  • synchronized声明的方法一定是排队运行的,而且只有共享资源的读写才需要使用其进行同步;
  • synchronized声明的非静态方法其获取的锁是该实例对象的锁;
  • synchronized声明的静态方法获取的锁是该类对象(永久代中类对象)的锁;
  • synchronized声明的代码块获取的锁则是括号里声明的对象的锁;
  • synchronized未声明的方法对其调用时不需要考虑锁的问题,因此不会有synchronized方法或代码块冲突;
  • synchronized支持锁重入(同一线程多次获取同一个锁);
  • 同步方法或代码块中出现异常则其所持锁将自动释放;
  • 方法的同步不具有继承性;
  • 同步方法或代码块是否冲突只看两者锁持有的锁是否是同一个;
  • synchronized声明的非静态方法与synchronized(this)的代码块使用的锁都是对象本身;
  • 由于String的常量池可能使相同字符串指向同一个对象,因此不要使用String作为synchronized代码块的对象监视器;
  • synchronized方法或代码块内的变量也有可见性;

volatile

  • volatile是使变量拥有可见性;
  • volatile修饰的变量在使用时并非从工作内存获取而是都从主内存中获取;
  • volatile修饰的变量在修改时其修改结果将直接写入到主内存;
  • 多线程访问volatile变量不会阻塞,但是不保证变量的原子性;

---恢复内容结束---

《Java多线程编程核心技术》——多线程与同步的更多相关文章

  1. Java多线程编程核心技术---多线程技能

    1.继承Thread /** * Copyright (C), 2018-2018, * FileName: MyThread * Author: 大象 * Date: 2018-06-08 22:3 ...

  2. Java多线程编程核心技术---学习分享

    继承Thread类实现多线程 public class MyThread extends Thread { @Override public void run() { super.run(); Sys ...

  3. Java多线程编程核心技术---对象及变量的并发访问(二)

    数据类型String的常量池特性 在JVM中具有String常量池缓存的功能. public class Service { public static void print(String str){ ...

  4. Java多线程编程核心技术

    Java多线程编程核心技术 这本书有利于对Java多线程API的理解,但不容易从中总结规律. JDK文档 1. Thread类 部分源码: public class Thread implements ...

  5. 《Java 多线程编程核心技术》- 笔记

    作为业务开发人员,能够在工作中用到的技术其实不多.虽然平时老是说什么,多线程,并发,注入,攻击!但是在实际工作中,这些东西不见得用得上.因为,我们用的框架已经把这些事做掉了. 比如web开发,外面有大 ...

  6. Java多线程编程核心技术(三)多线程通信

    线程是操作系统中独立的个体,但这些个体如果不经过特殊的处理就不能成为一个整体.线程间的通信就是成为整体的必用方案之一,可以说,使线程间进行通信后,系统之间的交互性会更强大,在大大提高CPU利用率的同时 ...

  7. Java多线程编程核心技术(二)对象及变量的并发访问

    本文主要介绍Java多线程中的同步,也就是如何在Java语言中写出线程安全的程序,如何在Java语言中解决非线程安全的相关问题.阅读本文应该着重掌握如下技术点: synchronized对象监视器为O ...

  8. Java多线程编程核心技术(一)Java多线程技能

    1.进程和线程 一个程序就是一个进程,而一个程序中的多个任务则被称为线程. 进程是表示资源分配的基本单位,线程是进程中执行运算的最小单位,亦是调度运行的基本单位. 举个例子: 打开你的计算机上的任务管 ...

  9. java多线程编程核心技术学习-1

    实现多线程的两种方式 继承Thread类,重写Thread类中的run方法 public class MyThread extends Thread{ @Override public void ru ...

  10. 《java多线程编程核心技术》不使用等待通知机制 实现线程间通信的 疑问分析

    不使用等待通知机制 实现线程间通信的 疑问分析 2018年04月03日 17:15:08       ayf 阅读数:33 编辑 <java多线程编程核心技术>一书第三章开头,有如下案例: ...

随机推荐

  1. Camtasia studio8.0破解方法

    Camtasia Studio 8.0 注册说明: 1.安装时使用以下信息注册: 用户名: Honorary User密钥: GCABC-CPCCE-BPMMB-XAJXP-S8F6R 或者是 Nam ...

  2. Forward团队-爬虫豆瓣top250项目-设计文档

    组长地址:http://www.cnblogs.com/mazhuangmz/p/7603594.html 成员:马壮,李志宇,刘子轩,年光宇,邢云淇,张良 设计方案: 1.能分析HTML语言: 2. ...

  3. Java理论学时第三节。课后作业。

    如果一个类中既有初始化块,又有构造方法,同时还设定了字段的初始值,谁说了算? 运行结果. 根据我的总结,它们三个的优先级是:构造方法 > 字段初始值 > 初始化块. 当多个类之间有继承关系 ...

  4. POJ3045--Cow Acrobats(theory proving)

    Farmer John's N (1 <= N <= 50,000) cows (numbered 1..N) are planning to run away and join the ...

  5. PAT甲级 1127. ZigZagging on a Tree (30)

    1127. ZigZagging on a Tree (30) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue ...

  6. 如何更好地使用Java 8的Optional

    Java 8中的Optional<T> 是一个可以包含或不可以包含非空值的容器对象,在 Stream API中很多地方也都使用到了Optional. java中非常讨厌的一点就是nullp ...

  7. spark checkpoint详解

    checkpoint在spark中主要有两块应用:一块是在spark core中对RDD做checkpoint,可以切断做checkpoint RDD的依赖关系,将RDD数据保存到可靠存储(如HDFS ...

  8. JS中访问对象的两种方式区别

    可以使用下面两种方式访问对象的属性和方法 1.对象名.属性名 对象名.方法名() 2.对象名["属性名"] 对象名["方法名"]() var obj = { n ...

  9. 未能加载文件或程序集,PublicKeyToken=“**********”,或它的某一个依赖项。强名称验证失败。

    就是这种错误.这种错误怎么办? 以下步骤: (以上图dll为例) 1.看项目的Debug文件夹下是否有以下三个文件 2.看项目的.csproj文件下引用的报错dll的publickeytoken和版本 ...

  10. MS SQL的某一数据库成了Single User模式

    数据库恢复失败,原来的数据却变成了 当尝试打开数据库的属性,即出现上面图片异常的信息. 正常来说,是可以打开数据库的属性 此刻,你可以运行SQL语句来解决: USE master; GO ALTER ...