线程安全:

通过加锁保证数据的一致性.也就是说当一个线程访问某个数据时,通过加锁操作对数据进行保护,其它线程在加锁期间不能对其访问

线程封闭

当多个线程访问共享变量时,需要通过加锁来保证数据同步,增加了程序的复杂性. 避免数据同步的一种方式是不共享变量,比如使用局部变量和ThreadLocal

线程调度

系统为线程分配CUP使用权的过程

  • 协同式线程调度

线程的执行时间由线程自己控制,当自己执行完后,主动通知操作系统切换到另外一个线程上执行. 好处是实现简单,线程对自己的操作是可知道的,没有什么线程同步问题.缺点是线程执行时间不可控,如果一个线程有问题,可能会一致阻塞在那里.

  • 抢占式线程调度

每个线程的执行时间有操作系统分配,线程的切换不由线程本身决定(Java中,Thread.yield()可以让出执行时间,但无法获取执行时间)线程执行时间系统可控,也不会有一个线程导致进程阻塞.

java线程调度就是抢占式调度

可以通过设置线程的优先级让一些线程尽可能的先执行多执行(Java一共有10个线程优先级从Thread.MIN_PRIORITY至Thread.MAX_PRIORITY),在两个线程同时处于ready时,优先级越高越容易被执行.但优先级并不靠谱,因为Java线程时通过映射到原生线程来实现的,所以线程调度还是取决于操作系统.

状态转换

  • 新建(New)创建后尚未启动的线程
  • 运行(Runnable):Runnable包括操作系统中的Running和Ready. 处于此状态的线程有可能在运行,也有可能在等待CPU为它分配执行时间.线程创建后,其它线程调用了该线程的start方法,那么该线程就位于可运行线程池中,变得可运行,就差CPU分配执行时间,其它运行所需要的资源都已经获得.
  • 无限期等待(Waiting):该状态下的线程不会被分配CPU执行时间,要等待被其它线程进行显示唤醒. 如没有设置timeout的Object.wait()方法和Thread.join()方法,以及LockSupport.park()方法
  • 限时等待(Timed Waiting):该状态下的线程不会被分配CPU执行时间,只不过不需要被显示的唤醒,在一定时间后会被系统自动唤醒. 如Thread.sleep(),设置了timeout的Object.wait()和Thread.join(),LockSupport.parkNanos()以及LockSupport.parkUntil()方法
  • 阻塞(Blocked):线程被阻塞了,与等待的区别是:阻塞线程在等待一个排它锁.

阻塞状态是因为某种原因放弃CPU使用权,暂时停止执行,直到线程进入就绪状态,才有机会转到运行状态.

  • 结束(Terminated):线程执行完了或者异常退出了run()方法,该线程结束生命周期

阻塞常见的三种情况

1.等待阻塞(无限期等待):运行的线程执行wait()方法,该线程会释放占用的资源,JVM会把该线程放入等待池.进入这个状态后,线程不会自动唤醒,必须依靠其它线程调用notify()或notifyAll()方法才能会被唤醒.

2.同步阻塞:运行的线程在获取对象的同步锁时,若该同步锁被其它线程占用,则JVM会把该线程放入锁池.
3.其它阻塞(限时等待):运行的线程执行了join()或者sleep()方法,或者发起了I/O请求,JVM会把该线程置为阻塞状态,当sleep()状态超时,join()等待线程终止或者超时,I/O处理完成,该线程重新转入就绪状态.

Java多线程概念(一)相关推荐

  1. java多线程概念、实现、状态和生命周期、同步、通信

    1.多线程概念 1.1通俗理解 高速公路收费站(进程)的多个收费匝道(线程): 银行柜台(进程)的多个办事窗口(线程): 浏览器的多窗口,多标签:迅雷的多任务下载等. 1.2进程和线程关系 进程的调度 ...

  2. Java多线程概念[同步容器,并发容器](二)

    同步容器 同步容器通过synchronized关键字修饰容器,保证同一时刻只有一个线程使用容器,从而使容器线程安全. synchronized的意思的同步. 1.Vector和ArrayList都实现 ...

  3. Java 多线程学习笔记

    概念 进程 正在运行的程序,是系统进行资源分配和调用的独立单位 每一个进程都有它自己的内存空间和系统资源,一个进程包括由操作系统分配的内存空间,包含一个或多个线程 一个进程一直运行,直到所有的非守护线 ...

  4. java多线程与线程间通信

    转自(http://blog.csdn.net/jerrying0203/article/details/45563947) 本文学习并总结java多线程与线程间通信的原理和方法,内容涉及java线程 ...

  5. Java多线程编程:Callable、Future和FutureTask浅析(多线程编程之四)

    java多线程-概念&创建启动&中断&守护线程&优先级&线程状态(多线程编程之一) java多线程同步以及线程间通信详解&消费者生产者模式&死锁 ...

  6. java多线程编程01---------基本概念

    一. java多线程编程基本概念--------基本概念 java多线程可以说是java基础中相对较难的部分,尤其是对于小白,次一系列文章的将会对多线程编程及其原理进行介绍,希望对正在多线程中碰壁的小 ...

  7. Java多线程笔记(零):进程、线程与通用概念

    前言 不积跬步,无以至千里:不积小流,无以成江海.在学习Java多线程相关的知识前,我们首先需要去了解一点操作系统的进程.线程以及相关的基础概念. 进程 通常,我们把一个程序的执行称为一个进程.反过来 ...

  8. Java 多线程(一) 基础知识与概念

    多线程Multi-Thread 基础 线程概念 线程就是程序中单独顺序的流控制. 线程本身不能运行,它只能用于程序中. 说明:线程是程序内的顺序控制流,只能使用分配给程序的资源和环境. 进程 进程:执 ...

  9. 学习java多线程,这必须搞懂的这几个概念

    转载自 学习java多线程,这必须搞懂的这几个概念,很重要. 同步和异步 同步,Synchronous,即调用方法开始,一旦调用就必须等待方法执行完返回才能继续下面的操作. 举个例子,你去银行ATM取 ...

最新文章

  1. 使用NVIDIA GRID vPC支持视频会议和算力工具
  2. Visual Studio 2005 Beta2 简体中文版发布
  3. 机器学习之数学基础(四)~Lasso Regression回归, L1、L2 Regularization正则化, 回归问题中的损失函数
  4. [转]php-fpm配置具体解释
  5. 安卓帧数监测软件_扬尘在线监测系统实现工地智能监控
  6. 阿里云 远程 mysql_阿里云 远程mysql
  7. c/c++ 指针函数 和 函数指针
  8. 老蒋征婚启示啊啊啊啊啊啊
  9. Android 为View实现双击效果
  10. 在排序数组中,找出给定数字的出现次数
  11. 新年放大招:Github 私库免费了!
  12. 计算机一级在上网题中如何新建文本文件?
  13. matlab求偏相关系数,计算皮尔逊相关系数t检验——Matlab
  14. python 学生编程--3 多彩同心圆
  15. 程序人生----禅修10日
  16. 谭浩强c语言第五版视频,张子枫平胸
  17. wlop作品集_【图包】【wlop】作品合集
  18. 线性离散系统的分析与校正
  19. mysql(十)条件语句、循环语句、动态执行SQL语句
  20. stm32实现毫秒ms微秒us级延时

热门文章

  1. [转]Win XP常遇网络故障分析:局域网问题
  2. python开发_xml.etree.ElementTree_XML文件操作
  3. Python 程序员必知必会的开发者工具
  4. Startup Error: Unable to detect graphics environment
  5. 蓝桥杯 ALGO-139 算法训练 s01串
  6. LeetCode 58. Length of Last Word
  7. python后端开发书籍_后端书籍推荐
  8. Java 调用http接口
  9. DNS解释问题:java.net.UnknownHostException
  10. fiddler启用过滤规则只显示想要的接口数据