java多线程知识点收集-总

1.线程与进程的关系

进程(Process):当一个程序进入内存开始运行时,就产生一个进程。进程是一个独立单元,它的资源由系统分配和调度。

线程(Thread):线程是进程的执行单元,线程在进程中是独立的、并发的执行流。当进程被初始化后,主线程(main)就被创建。

1)线程是进程的组成部分,一个进程可以拥有多个线程,一个线程必须有一个父进程。

2)线程拥有自己的堆栈、程序计数器以及局部变脸,但不拥有系统资源,它与父进程的其他线程共享共享父进程的全部资源。

3)线程的调度和管理由进程本身负责完成。

2.创建线程的方式

http://www.cnblogs.com/moonpool/p/5472549.html

有三种创建方法

1)继承Thread类--不能资源共享,当实现方便

Thread类是一个抽象类

2)实现Runnable接口--可以资源共享,在新建Thread对象时,需要Runnable接口实现类的对象作为target

Runnable是一个接口类

3)使用Callable和Future创建线程--有返回值的线程

Callable和Future都是接口类,FutureTask是Future的实现类

3.线程的生命周期(图片来自java疯狂讲义)

4.线程控制方法

http://www.cnblogs.com/moonpool/p/5494935.html

1)join--Thread中的方法,由使用线程的程序调用

--如果对象A在自己方法内使用对象B.join , 那么A的线程就会被阻塞,等到B线程死亡,A线程才能继续。

2)后台线程--Thread中的方法setDeamon(true)

--守护进程,当前台线程全部死亡后,后台线程也随之死亡

3)sleep--Thread类的静态方法

--在设置的时间内处于阻塞状态,时间一到,就变成就绪状态,等待被调用

4)yield与线程优先级--Thread类的静态方法

--使用了该方法后,当前线程就会变成就绪状态,操作系统就会在处于就绪状态的线程中,挑选优先级最高的线程,给它分配资源并允许。正常的线程都是普通优先级,优先级还有高级和低级,有相应的方法去设置。

5.线程同步方法

http://www.cnblogs.com/moonpool/p/5480593.html

1)同步代码块--在重写run()方法时使用synchronized修饰符修饰代码块

2)同步方法--在定义类时使用synchronized修饰符修饰修改方法

3)同步锁lock--lock和ReadWriteLock两个接口,对应的实现类是ReentrantLock以及ReentrantReadWriteLock

6.线程通讯方法

http://www.cnblogs.com/moonpool/p/5496887.html

1)如果采用的是同步代码块和同步方法的方式来实现线程的同步,就需要使用传统的线程通讯方式

在被线程调用方法(该方法被synchronized修饰)内添加wait ()、notify()以及notifyAll(),来阻塞调用线程或者通知其他线程运行。

wait ()、notify()以及notifyAll()这三个方法是由Object类提供

http://www.cnblogs.com/moonpool/p/5500845.html

2)如果采用的是同步锁方式来实现线程同步,就需要使用Condition控制线程通讯

和第一种类似,这里需要使用Condition对象在被线程调用方法(该方法不需要被synchronized修饰)内添加Lock.lock()、Condition.await ()、Condition.signal()、Condition.signalAll()以及Lock.unlock(),来实现线程通信

这里首先需要由lock对象的newCondition()方法返回一个Condition对象,await ()、signal()、signalAll()是Condition对象提供的方法

class BoundedBuffer {
   final Lock lock = new ReentrantLock();
   final Condition notFull  = lock.newCondition();
   final Condition notEmpty = lock.newCondition(); 

   final Object[] items = new Object[100];
   int putptr, takeptr, count;

   public void put(Object x) throws InterruptedException {
     lock.lock();
     try {
       while (count == items.length)
         notFull.await();
       items[putptr] = x;
       if (++putptr == items.length) putptr = 0;
       ++count;
       notEmpty.signal();
     } finally {
       lock.unlock();
     }
   }

   public Object take() throws InterruptedException {
     lock.lock();
     try {
       while (count == 0)
         notEmpty.await();
       Object x = items[takeptr];
       if (++takeptr == items.length) takeptr = 0;
       --count;
       notFull.signal();
       return x;
     } finally {
       lock.unlock();
     }
   }
 }

http://www.cnblogs.com/moonpool/p/5503287.html

3)阻塞队列(BlockingQueue)

BlockingQueue是Queue的子接口,但主要用于线程同步

  抛出异常 不同的返回值 阻塞线程 指定超时时间
队尾插入元素 add(e) offer(e) put(e) offer(e,time,unit)
对头删除元素 remove() poll() take() poll(time,unit)
获取、不删除元素 element() peek()

----------------------------------------------------------------------------------------------

7.线程组

可以将线程分类管理,并设置优先级等

ThreadGroup类

由Thread类提供的构造方法来指定新建的线程属于哪个线程组。

8.线程池

存在的目的就是为了节省系统资源,将新建好的线程放入线程池,由线程池给线程分配资源并运行,当该线程销往后,给该线程分配的资源将会被回收回线程池。

由Executor工厂类提供的静态工厂方法来创建ExecutorService对象

9.线程相关类

ThreadLocal类     该类的成员变量在被线程调用时,将会产生一个副本,让线程可以随意维护自己拥有的变量副本,从而保证线程之前不会产生资源冲突,这和资源共享的同步方法由本质区别,使用场景也不一样。

线程安全的集合类   正常的集合类都是线程不安全的,这里线程安全的集合类就是可以被线程调用时产生一个副本,最终可以保证原集合的数据完整性。

思考:线程相关类的使用场景。

时间: 2024-07-30 10:12:18

java多线程知识点收集-总的相关文章

Java 多线程知识点整理

1.如何停止一个正在运行的线程? 使用共享变量,用volatile变量修饰,线程循环去访问该变量.如果线程因为发生某些事件进行阻塞,可以使用Thread的interrupt方法.可以使一个被阻塞的线程抛出一个中断异常,从而使线程提前结束阻塞状态,退出堵塞代码. class MyThread extends Thread { volatile boolean stop = false; public void run() { while (!stop) { System.out.println(g

java多线程知识点

下面是我学习多线程记录的知识点,并没详细讲解每个知识点,只是将重要的知识点记录下来,有时间可以看看,如果有不对的地方,欢迎大家支出,谢谢! 1.多线程的状态和创建方式:     线程的状态:          1.新状态:线程对象已经创建,还没有在其上调用start()方法.          2.可运行状态:当线程有资格运行,但调度程序还没有把它选定为运行线程时线程所处的状态.当start()方法调用时,线程首先进入可运行状态.在线程运行之后或者从        阻塞.等待或睡眠状态回来后,也

软帝学院:java多线程知识点分享

1.进程和线程: 进程:正在进行的程序.每一个进程执行都有一个执行顺序,该顺序是一个执行路径,或者叫一个控制单元. 线程:进程内部的一条执行路径或者一个控制单元. 两者的区别: 一个进程至少有一个线程 进程在执行过程中拥有独立的内存单元,而多个线程共享内存: 2.jvm多线程的启动是多线程吗? java的虚拟机jvm启动的是单线程,就有发生内存泄露的可能,而我们使用java程序没出现这样的问题, 也就是jvm启动至少有两个线程,一个执行java程序,一个执行垃圾回收.所以是多线程. 2.多线程的

Java重点知识点收集

什么是Java的序列化 就是将一个对象保存到一个文件,可以通过流的方式进行传输,可以将文件内容的读取,转化为一个对象,序列化是为了解决对象流在进行读写操作的时候的引发的问题, 对象流就是将对象进行流化,流化后的对象可以在网络之间进行传输,可以对流化后的对象进行读写操作. 一个".java"源文件中是否可以包括多个类?有什么限制 就是一个java文件里可以写多个类,但是只有一个public修饰的类,如下 1 2 3 4 5 6 7 public class A { } class B {

java多线程知识点总结

1.线程调度知识:线程类Thread的了解,几个thread的方法.thread.sleep(),thread.join().(调用join方法的那个线程会立刻执行). object.wait()方法,notifyAll()方法. 2.线程间通信知识(共享资源):synchronized,volatile,readWriteLock,生产者消费者存储模型.队列.消息队列. 队列也算共享资源的访问啊.加锁在哪里加?(在共享对象里加锁) 3.实际中用到的地方:1.多线程访问缓存(数据队列,有生产者消

java多线程知识点汇总(四)多线程知识点脉络图

1.多线程安全问题 1)synchronized关键字:如何加锁的问题,选择synchronized方法还是synchnized代码块. 选择哪个锁问题,this对象,还是class对象(针对static方法或者变量),或者object对象 推荐使用同步代码块,因为加锁灵活,可以自己选择使用哪个锁,尤其一个类里面有多个同步方法时. 读写问题,保证多线程对同一对象的读写正常,不至于读到脏数据.读写方法共用同一个锁. 共享资源,这又涉及到单例模式的线程安全问题,线程池等. 2)线程安全类,比如str

java多线程知识点概述

这里只起一个概述的作用,极其简单的列一下知识点,需要在脑海中过一下,如果哪些方面不熟悉的话,建议利用网络资源去学习. 1.线程.进程概念 概念 线程状态及其转换 2.死锁.预防.解决 3.jdk线程实现方式 继承Thread重写run方法.实现Runnable实现run方法.实现Callable重写call方法 call方法能抛出异常允许有返回值 join/jield/interrupt/stop/wait/sleep/setDaemon/suspend 4.线程同步.线程异步 同步使用场景:共

java多线程知识点汇总(二)---多线程实例解析

本实验主要考察多线程对单例模式的操作,和多线程对同一资源的读取,两个知识.实验涉及到三个类: 1)一个pojo类Student,包括set/get方法. 2)一个线程类,设置student的成员变量age和name的值为111和111 3)另一个线程类,设置student的成员变量age和name的值为222和2222 4)main类,for循环200次,分别创建200个线程1和线程2对同一资源访问.(共400个线程) 1.第一种情况:饿汉式单例模式保证多线程操控的是同一对象 //饿汉式单例模式

深入聊聊Java多线程

一.背景 在没有学习Java多线程以前,总觉得多线程是个很神秘的东西,只有那些大神才能驾驭,新年假期没事就来学习和了解一下Java的多线程,本篇博客我们就来从头说一下多线程到底是怎么回事. 二.概述 1.进程的概念 每一个正在运行的程序都是一个进程,它是系统进行资源分配和调用的独立单位.且 每一个进程都有自己的内存空间和系统资源. 2.线程的概念 是进程中的单个顺序控制流,是一条执行路径.每个进程都可以拥有一个或者多个线程.各个线程之间都共享所属的那个进程的内存空间和系统资源. 3.单线程和多线