Java多线程增强

发布 : 2017-07-19 分类 : Java 浏览 :

Java多线程基础

  • 进程:它是内存中的一段独立的空间,可以负责当前应用程序的运行
    • 进程是负责整个程序的运行,而线程是程序中具体的某个独立功能的运行
    • 一个进程中至少应该有一个线程
  • 线程:位于进程中,负责当前进程中的某个具备独立运行资格的空间
  • 多线程:在一个进程中,我们同时开启多个线程,让多个线程同时去完成某些任务(功能)(比如后台服务系统,就可以用多个线程同时响应多个客户的请求)

进程

1
2
3
4
5
不管是我们开发的应用程序,还是我们运行的其他的应用程序,都需要先把程序安装在本地的硬盘上。然后找到这个程序的启动文件,启动程序的时候,其实是电脑把当前的这个程序加载到内存中,在内存中需要给当前的程序分配一段独立的运行空间。这片空间就专门负责当前这个程序的运行

不同的应用程序运行的过程中都需要在内存中分配自己独立的运行空间,彼此之间不会相互的影响。我们把每个独立应用程序在内存的独立空间称为当前应用程序运行的一个进程

进程:它是内存中的一段独立的空间,可以负责当前应用程序的运行。当前这个进程负责调度当前程序中的所有运行细节

线程

1
2
3
4
5
6
7
启动的QQ聊天软件,需要和多个人进行聊天。这时多个人之间是不能相互影响,但是它们都位于当前QQ这个软件运行时所分配的内存的独立空间中

在一个进程中,每个独立的功能都需要独立的去运行,这时又需要把当前这个进程划分成多个运行区域,每个独立的小区域(小单元)称为一个线程

线程:它是位于进程中,负责当前进程中的某个具备独立运行资格的空间
进程是负责整个程序的运行,而线程是程序中具体的某个独立功能的运行
一个进程中至少应该有一个线程

多线程运行的原理

1
2
3
4
5
6
cpu在线程中做时间片的切换

其实真正电脑中的程序的运行不是同时在运行的。CPU负责程序的运行,而CPU在运行程序的过程中某个时刻点上,它其实只能运行一个程序。而不是多个程序。而CPU它可以在多个程序之间进行高速的切换。而切换频率和速度太快,导致人的肉眼看不到

每个程序就是进程, 而每个进程中会有多个线程,而CPU是在这些线程之间进行切换
了解了CPU对一个任务的执行过程,我们就必须知道,多线程可以提高程序的运行效率,但不能无限制的开线程

实现线程的两种方式

1
2


Java同步关键词

synchronized

synchronzied的缺陷

1
2
3
4
5
6
synchronized是java中的一个关键字,也就是说是Java语言内置的特性

如果一个代码块被synchronized修饰了,当一个线程获取了对应的锁,并执行该代码块时,其他线程便只能一直等待,等待获取锁的线程释放锁,而这里获取锁的线程释放锁只会有两种情况:

1)获取锁的线程执行完了该代码块,然后线程释放对锁的占有;
2)线程执行发生异常,此时JVM会让线程自动释放锁。

lock

lock和synchronized的区别

1
2
1)Lock不是Java语言内置的,synchronized是Java语言的关键字,因此是内置特性。Lock是一个类,通过这个类可以实现同步访问;
2)Lock和synchronized有一点非常大的不同,采用synchronized不需要用户去手动释放锁,当synchronized方法或者synchronized代码块执行完之后,系统会自动让线程释放对锁的占用;而Lock则必须要用户去手动释放锁,如果没有主动释放锁,就有可能导致出现死锁现象。
本文作者 : Matrix
原文链接 : https://matrixsparse.github.io/2017/07/19/Java多线程增强/
版权声明 : 本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明出处!

知识 & 情怀 | 二者兼得

微信扫一扫, 向我投食

微信扫一扫, 向我投食

支付宝扫一扫, 向我投食

支付宝扫一扫, 向我投食

留下足迹