您的位置:首页 > 编程语言 > Java开发

JAVA学习笔记之(多线程)

2016-09-16 13:23 381 查看
进程与线程二者的联系
1.进程:是程序或任务的执行的过程,具有动态性,它持有资源(共享内存,共享文件)和线程(即进程是资源和线程的载体)

2.线程:是系统中最小的执行单元,同一进程中有多个线程,线程共享线程的资源

3.线程交互:即线程通信

4.线程之间存在同步和互斥


Thread常用方法:
1.获取线程名称:getName();

2.取得当前线程对象:currentThread();

3.判断是否启动:isAlive();

4.强行运行:join();

5.线程休眠:sleep();

6.线程礼让:yield()

Thread中start()方法,join()方法,sleep()方法,volatite作用

Java Thread中,start()方法,等其他代码(Thread.join()和Thread.sleep()除外)执行完后再执行它。

Java Thread中, join()方法主要是让调用该方法的thread完成run方法里面的东西后, 再执行join()方法后面的代码。

Java Thread中, sleep()方法主要是让调用该方法的thread完成run方法里面的东西后且等待休眠的时候结束(唤醒), 再执行sleep()方法后面的代码。
一. volatite 简述
Java 语言提供了一种稍弱的同步机制,即 volatile 变量.用来确保将变量的更新操作通知到其他线程,保证了新值能立即同步到主内存,以及每次使用前立即从主内存刷新. 当把变量声明为volatile类型后,编译器与运行时都会注意到这个变量是共享的.

二. volatite 线程安全?
volatile 变量对所有线程是立即可见的,对 volatile 变量所有的写操作都能立即反应到

其他线程之中,换句话说:volatile 变量在各个线程中是一致的,所以基于 volatile 变量的运算是线程安全的。这句话论据貌似没有错,论点确实错的.
@Java线程——如何正确停止线程
一、错误一:stop()方法
1、not stop:stop()方法会使线程戛然而止
2、使程序突然中止,无法完成完整的业务步骤,也无法进行清理工作
二、错误二:interrupt()方法
1、interrupt()方法只能设置interrupt标志位(且在线程阻塞情况下,标志位会被清除,更无法设置中断标志位),无法停止线程
三、正确方法:设置退出标志
1、使用退出标志位来停止while循环
2、完成最后一次业务后跳出while循环后,之后进行一些清理工作
@Java线程——线程交互——互斥与同步
一、互斥
1、同一时间,只能有一个线程访问数据
互斥的实现:synchronized(lockObj);java的语法保证的同一时间,只有一个线程获得lockObj

同步:wait(),notify(),notifyall(),都是属于object类,并不是thread类

wait set 类似于线程的休息室,访问共享数据的代码称为critical section。一个线程获取锁,然后进入临界区 ,发现某些条件不满足,然后调用锁对象上的wait方法,然后线程释放掉锁资源,进入锁对象上的wait set。其他线程可以获取所资源,然后执行,完了以后调用notify,通知锁对象上的等待线程。

Ps:若调用notify();则随机拿出(这随机拿出是内部的算法,无需了解)一条在等待的资源进行准备进入Critical Section;若调用notifyAll();则全部取出进行准备进入Critical Section。
二、同步
1、是一种通信机制,一个线程操作完成后,以某种方式通知其他线程
三、实现方法
1、【互斥】构建锁对象(Object objLock),通过synchronized(lockObj){ 互斥的代码块 }
2、加锁操作会开销系统资源,降低效率。
3、在某线程的条件不满足任务时,使用lockObj.wait()对线程进行阻挡,防止其继续竞争CPU资源,滞留在wait set中,等待唤醒,【唤醒后继续完成业务】
4、【同步】在某一代码正确执行完业务后,通过lockObj.notifyAll()唤醒所有在lockObj对象等待的线程
拓展:
1、Java Memory Mode:JMM描述了java线程如何通过内存进行交互,了解happens-before,synchronized,voliatile & final
2、Locks % Condition:锁机制和等待条件的高层实现 java.util,concurrent.locks
3、线程安全性:原子性与可见性,死锁等
4、多线程常用的交互模型
· Producer-Consumer模型
· Read-Write Lock模型
· Future模型
· Worker Thread模型
5、Java5中并发编程工具:java.util.concurrent 线程池ExcutorService Callable&Future BlockingQueue
6、推荐书本:CoreJava & JavaConcurrency In Practice
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  java 多线程 线程 内存