一、进程与线程
每一个进程都独享一块内存空间。一个应用程序可以同时启动多个进程,比如IE浏览器,打开一个IE浏览器,就相当于开启了一个进程。
线程指进程中的一个执行流程,一个进程可以包含多个线程。
每个进程都需要操作系统为其分配独立的内存地址,而同一进程中的多个线程在同一块地址空间工作,他们共享一块内存和资源。
每次调用java.exe的时候操作系统都会启动一个java虚拟机进程,当启动java虚拟机进程的时候,java虚拟机都会创建一个主线程,改线程从 程序入口main方法开始执行,这个线程的名字就叫main( Thread.currentThread().getName())
java虚拟机每启动一个线程,就给他分配一块线程方法栈,用来存放相关信息(比如局部变量等),线程就在这个栈上运行。所以java中对象的局部变量是线程安全的,但是实力变量以及类变量由于不是保存在栈中,所以他们不是线程安全的。
二、线程的创建和启动
java中有两中方法创建一个多线程的类
1、继承java.lang.Thread类,覆盖Thread类的run()方法
2、实现Runnable接口,实现Runnable接口的run()方法。推荐使用第二种,因为第二种更加的灵活。
注意:每次程序运行的时候除了自定义的线程外还有一个main线程:
java 代码
- public class ThreadTest2 implements Runnable {
-
-
-
-
- public void run() {
- for(int i=0;i<3;i++){
- System.out.println(Thread.currentThread().getName()+" "+i);
- }
- }
-
-
-
-
- public static void main(String[] args) {
- Runnable r = new ThreadTest2();
- Thread t1 = new Thread(r,"t1");
- Thread t2 = new Thread(r,"t2");
- t1.start();
- t2.start();
- t1.run();
- }
- }
运行结果可能是:
main 0
main 1
main 2
t1 0
t1 1
t1 2
t2 0
t2 1
t2 2
三、线程的调度
线程调度的几个常用的方法,这几个方法都是Thread的静态方法:sleep();yield();join()
sleep(xxx),指当前运行的线程睡眠xxx秒,睡眠的时候当前线程会交出cpu,以便给其他线程运行的机会,但是不会交出对象的锁!
yield(),指当前运行的线程交出cpu,给其他线程运行的机会。yield()与sleep()的区别在于:yield()只给同等级别,或者比自 己级别还高的线程运行的机会,而sleep()是给所有线程运行的机会()。貌似yield()与操作系统关系很大。
join(),指将cpu交给调用join()方法的线程,直到他运行结束,在一定程度上可以实现synchronized类似的功能。
四、线程的各种状态
新建状态(new) //线程刚被创建出来
Runnable r = new ThreadTest2();
Thread t1 = new Thread(r,"t1");//创建线程t1 线程处在new状态
就绪状态(Runnable)
t1.start();//启动线程t1,这时候他处在Runnable状态,等待cpu
运行状态(Running)
如果处在Runnable状态的线程,被调度获得cpu,那么他就处在Running状态
阻塞状态(Blocked)
如果Running中的线程调用sleep(),yield()等方法,他 就处在阻塞状态
死亡状态(Dead)
线程执行完毕,就处于死亡状态。
五、线程同步
线程同步使用synchronized关键字来惊进行。
每一个对象都有一把锁,可以想象对象有一个等待池,一个对象锁池。
因为每个对象都有一把锁,所以对同一个对象的不同方法使用synchronized,他们的锁只有一把,就是对象的本身。
一个线程获得了对象的锁,其余的线程就得在对象锁池中等待当前线程释放对象的锁。
六、线程通讯:
Object的两个方法;wait()和notify()实现线程之间的通讯。
wait()使对象放弃cpu,释放对象的锁。jvm将该线程放到该对象的等待池中,等待其他线程将其唤醒
notify()执行改方法的线程唤醒在对象的等待池中等待的一个线程,jvm从对象等待池中随机选择一个线程,把他转换到对象的锁池中
分享到:
相关推荐
Java多线程复习笔记,包括线程创建,关键字讲解,线程池等等。
深入了解Java多线程,对Java的复习有了一定的提供基础
适合复习多线程
java多线程编程总结,超级细致与权威,我看过的最好的理解多线程知识点的复习资料
Java多线程的临界资源.pdf 学习资料 复习资料 教学资源
Java多线程原理.pdf 学习资料 复习资料 教学资源
Java多线程编程.pdf 学习资料 复习资料 教学资源
Java多线程服务器原理.pdf 学习资料 复习资料 教学资源
Java 多线程服务器编程.pdf 学习资料 复习资料 教学资源
适用人群:适合想了解或学习高并发多线程的 IT 学生、开发人员、研究人员以及使用Java多线程进行开发的任何人。 能学到什么:常见Java高并发多线程面试问题及在相关场景下如何处理和解决这些问题。 阅读建议:通过...
Java多线程的互斥原理.pdf 学习资料 复习资料 教学资源
计算机后端-Java-Java核心基础-第20章 多线程 02. 复习:IDEA使用与多线程基本概念.avi
这一篇文章主要关于java多线程,主要还是以例子来驱动的。因为讲解多线程的书籍和文章已经很多了,所以我也不好意思多说,呵呵、大家可以去参考一些那些书籍。我这个文章主要关于实际的一些问题。同时也算是我以后...
多线程开发的优势:改善用户体验,提高资源利用率(单线程的处理效率低下) 线程的使用步骤:定义一个线程,创建线程的实例,启动线程,终止线程 主线程:(java中所有的线程都是java.lang.Thread类或者其子类的一...
多线程 深入理解内部类 javac和javap Java8新特性终极指南 序列化和反序列化 继承封装多态的实现原理 集合类 Java集合类总结 Java集合详解:一文读懂ArrayList,Vector与Stack使用方法和实现原理 Java集合详解:Queue...
01大数据面试复习----Java基础---集合类、多线程、JVM.zip
D、java内置对多线程的支持。 10.下面语句执行后,i 的值是( B )。 for( int i=0, j=1; j ; j+=3 ) i=i+j; A) 4 B) 5 C) 6 D) 7 11.设有定义 float x=3.5f, y=4.6f, z=5.7f;则以下的表达式中,值为true的是( B )...
429.427.JAVA基础教程_多线程-复习:线程的创建与常用方法(429).rar
计算机后端-Java-Java核心基础-第20章 多线程 03. 复习:线程的创建与常用方法.avi
Java应用程序设计之多线程和泛型 Thread、Runnable、Callable 线程操作:isAlive()、isInterrupted()、join()、sleep()、stop()、interrupted()、setDaemon()、setPriority()、yield() 同步与死锁、Object类对线程的...