JAVA学习笔记之(多线程)

来源:互联网 发布:newtv中国网络电视tv版 编辑:程序博客网 时间:2024/05/22 15:39
进程与线程二者的联系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 & final2、Locks % Condition:锁机制和等待条件的高层实现 java.util,concurrent.locks3、线程安全性:原子性与可见性,死锁等4、多线程常用的交互模型· Producer-Consumer模型· Read-Write Lock模型· Future模型· Worker Thread模型5、Java5中并发编程工具:java.util.concurrent 线程池ExcutorService Callable&Future BlockingQueue6、推荐书本:CoreJava & JavaConcurrency In Practice



0 0
原创粉丝点击