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

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

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

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

  1. java 多线程知识点

    线程状态图 说明: 线程共包括以下5种状态. 新建状态(New) : 线程对象被创建后,就进入了新建状态.例如,Thread thread = new Thread(). 就绪状态(Runnable) ...

  2. 【JAVA】JAVA相关知识点收集

    下面这些链接都是我这段时间(7月-9月)看过的.感觉自己现在处于一个疯狂吸收知识的阶段,如果是文字的方式一点一点搬运到自己的博客既重复又费时间,只有等自己积累到一定程度后才能进行原创性高质量的产出吧. ...

  3. java多线程知识点

    下面是我学习多线程记录的知识点,并没详细讲解每个知识点,只是将重要的知识点记录下来,有时间可以看看,如果有不对的地方,欢迎大家指出,谢谢! 1.多线程的状态和创建方式:     线程的状态:      ...

  4. java多线程知识点汇总(一)多线程基础

    1.什么叫多线程程序? 答:一个进程至少有一个线程在运行,当一个进程中出现多个线程时,就称这个应用程序是多线程应用程序. java编写的程序都是多线程的,因为最少有俩线程,main主线程和gc线程. ...

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

    1.进程和线程: 进程:正在进行的程序.每一个进程执行都有一个执行顺序,该顺序是一个执行路径,或者叫一个控制单元. 线程:进程内部的一条执行路径或者一个控制单元. 两者的区别: 一个进程至少有一个线程 ...

  6. java——多线程知识点大总结

    1:理解线程的概念之前,我们有必要先理解一下进程的概念 程序(Program)是为实现特定目标或解决特定问题而用计算机语言(比如Java语言)编写的命令序列的集合. 进程指一个程序的一次执行过程   ...

  7. java多线程知识点总结

    1.线程调度知识:线程类Thread的了解,几个thread的方法.thread.sleep(),thread.join().(调用join方法的那个线程会立刻执行). object.wait()方法 ...

  8. java多线程知识点概述

    这里只起一个概述的作用,极其简单的列一下知识点,需要在脑海中过一下,如果哪些方面不熟悉的话,建议利用网络资源去学习. 1.线程.进程概念 概念 线程状态及其转换 2.死锁.预防.解决 3.jdk线程实 ...

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

    1.多线程安全问题 1)synchronized关键字:如何加锁的问题,选择synchronized方法还是synchnized代码块. 选择哪个锁问题,this对象,还是class对象(针对stat ...

随机推荐

  1. IOS UIWebView 随记

    UIWebView中加载的网页尺寸太大,如何让网页适应屏幕大小 webview.scalesPageToFit = YES;

  2. 搭建基于Jenkins的CI服务器

    安装Jenkins和创建任务这些操作网上一搜一大把,这里就没必要写了,直接就开始编译.单元测试,覆盖,git提交触发构建,构建失败发送给提交人邮件. 因为项目比较复杂,为了懒省事我直接在CI服务器上安 ...

  3. Linux 中权限的再讨论( 下 )

    前言 上篇随笔讲述了Linux中权限的大致实现机制以及目录权限的相关规则.本文将讲解Linux中的三种特殊权限:SUID,SGID,Sticky权限.看完这两篇文章,你一定会对Linux的权限有个更深 ...

  4. 优化梯度计算的改进的HS光流算法

    前言 在经典HS光流算法中,图像中两点间的灰度变化被假定为线性的,但实际上灰度变化是非线性的.本文详细分析了灰度估计不准确造成的偏差并提出了一种改进HS光流算法,这种算法可以得到较好的计算结果,并能明 ...

  5. hdu 3932 Groundhog Build Home

    Groundhog Build Home Time Limit: 15000/5000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Ot ...

  6. Struts2中数据封装机制

    Struts2当中数据封装的三种机制:属性驱动.标签驱动.模型驱动.下面来一一介绍. 一.属性驱动 1.需要提供对应属性的set方法进行数据的封装. 2.表单的哪些属性需要封装数据,那么在对应的Act ...

  7. cocos2d-js 运行动画

    1.添加动画缓存 //添加动画缓存 cc.spriteFrameCache.addSpriteFrames(res.bug_plist); this.spriteSheet = new cc.Spri ...

  8. js 中常用的正则表达式

    主要有以下几种: 匹配中文字符的正则表达式: [\u4e00-\u9fa5] 评注:匹配中文还真是个头疼的事,有了这个表达式就好办了哦 获取日期正则表达式:\d{4}[年|\-|\.]\d{1,2}[ ...

  9. 一起来学linux:FTP服务器搭建

    首先安装vsftpd: apt install vsftpd有下面几个重要的配置文件:1 /etc/vsftpd.conf. 这个是vsftpd的配置文件.通过“参数=设置值”的方式来设置的. 2 / ...

  10. java JDBM2 的几个简单实例

    JDBM2 提供了 HashMap 和 TreeMap 的磁盘存储功能,简单易用,用于持久化数据.特别适合用于嵌入到其他应用程序中. 磁盘数据库 HelloWorld.java import java ...