关于线程基础
A.
并发在java中本身就是无处不在,例如Servlet天生就是多线程的,还有一些后台线程,进程和线程出现的原因,基本都是为了更好更合理的利用资源,更公平!
如果是在单处理器上,那么并发从某种角度上看,就是将顺序执行的任务拆分成并发执行,算上上下文切换的开销,其实更花时间!但是有阻塞IO或者大计算的时候,如果没有并发,程序会停止。有了并发,其他任务还可以同时进行,更公平合理的分配了资源。
仅仅靠进程也可以实现并发,但是这里我们只讨论线程实现并发的方式!
B.
Java的Thread对线程的操作都是通过native方法,可以通过start方法开启一个线程,不过一个线程真正的事情是在run方法里做的,run方法只是普通的java方法,因此直接调用它,只是想相当于在当前线程调用一个普通方法,没什么意义, 因此要真正多线程就要实现Thread类重写run方法,并调用start方法启动!
另外,也可以将实现Runnable接口的类作为Thread类构造函数的参数,再调用start方法启动!
C.
1.
可以调用线程的静态sleep方法,实现线程休眠,它可以精确到纳秒,并且他响应中断,会抛出InterruptedException。另外,新版的API有了更显示的方法,就是
TimeUnit.MILLSECONDS.sleep(),本质上来说,还是调用Thread的sleep方法,但是因为sleep方法只接受毫秒和纳秒作为参数,因此TimeUnit实现了时间的转换,比如小时--à毫秒
2
线程之间也有一定的优先级,它是不确定的,高的执行平率高,低的执行平率低,但是不会有死锁,可以通过调用setPriority方法设置。
3
我们的主线程是用户线程(User Thread),另外还会有一些后台线程(守护线程,Daemon Thread),他们不是必须的,当所有非后台线程结束的时候,程序也就终止了,同时会杀死所有的后台线程。比如垃圾回收的线程!
4
从我们使用者的角度来说,没什么理由使用守护线程,因为他们随时可能终止,并且连finally方法也不会执行
一个线程可以等待另一个线程的结束,那就是在一个线程Al里面调用另一个线程B的join方法,表示A等待B,直到B结束。Java5以后提供了CountDownLatch和CycleBarrier等,也比较适合线程与线程之间的协作!
5
线程是有相对独立性的,在start方法之后,就和启动它的线程没关系了,因此我们也不能捕获到线程的异常,特别是运行时异常,只会在控制台打印!java5提供了Thread.UncaughtExceptionHandler接口,可以通过
Thread.setDefaultUncaughtExceptionHandler方法给所有线程注册异常处理器,也可以调用线程实例的setUncaughtExceptionHandler方法,为单独的线程设置处理器!
D
其他一些有趣的方法
println Thread.dumpStack()
println Thread.currentThread().state
//getAllStackTraces 一个Map获得所有线程的栈
Map map=Thread.getAllStackTraces()
println map.size()
List list=Thread.currentThread().getStackTrace()
//打出调用栈
list.each { println it }
分享到:
相关推荐
电子书相关:包含4个有关JAVA线程的电子书(几乎涵盖全部有关线程的书籍) OReilly.Java.Threads.3rd.Edition.Sep.2004.eBook-DDU Java Thread Programming (Sams) java线程第二版中英文 java线程第二版中英文 ...
java 线程工具类 java 线程工具类java 线程工具类 java 线程工具类java 线程工具类 java 线程工具类java 线程工具类 java 线程工具类java 线程工具类 java 线程工具类java 线程工具类 java 线程工具类java 线程工具...
根据提供的信息,我们可以推断出这份文档主要关注的是Java线程的相关内容。下面将围绕“Java线程”这一主题展开详细的介绍与解释。 ### Java线程基础 在Java语言中,线程是程序执行流的基本单元。一个标准的Java...
Java线程有五种基本状态:新建(New)、可运行(Runnable)、运行(Running)、阻塞(Blocked)和死亡(Terminated)。这些状态之间的转换是通过调用特定的方法,如start()、sleep()、join()、wait()、notify()等...
它提供关于发现的线程转储的统计信息,提供关于锁定监视器和等待线程的信息。它可以在线程之间进行区分,以寻找相似之处,并具有“长运行线程”检测。如果记录了类的直方图,它还提供了线程转储中的堆对象的概述。
Java线程状态流转图知识点总结 Java线程状态流转图是一种用于描述Java线程生命周期中不同的状态和状态转换的图形表示方式。该图形展示了Java线程从创建到终止的整个生命周期,并详细介绍了每种状态的特点和转换...
Java线程有10个优先级(MIN_PRIORITY, NORM_PRIORITY, MAX_PRIORITY),默认优先级是NORM_PRIORITY。但是,线程优先级并不保证绝对的执行顺序,操作系统调度策略可能影响实际执行顺序。 7. join()方法: 一个线程...
Java线程是并发编程的核心部分,它允许程序在同一时间执行多个独立的任务,从而提高系统效率和响应速度。本文将深入探讨Java线程的概念、生命周期、实现方式以及相关的同步机制。 首先,理解线程的基本概念至关重要...
### JAVA中的单线程与多线程概念解析 #### 单线程的理解 在Java编程环境中,单线程指的是程序执行过程中只有一个线程在运行。这意味着任何时刻只能执行一个任务,上一个任务完成后才会进行下一个任务。单线程模型...
Java线程是Java编程中的重要概念,特别是在多核处理器和并发处理中不可或缺。Java线程允许程序在同一时间执行多个不同的任务,从而提高了程序的效率和响应性。在燕山大学信息学院计算机系的课程中,李峰教授讲解了...
Java线程分析是Java开发中的重要环节,尤其是在处理性能优化、死锁排查或者并发问题时。TDA(Thread Dump Analyzer)是一款强大的Java线程分析工具,它能够帮助开发者深入理解应用在运行时的线程状态,包括线程的...
Java线程是Java编程语言中的一个核心概念,它允许程序同时执行多个任务,极大地提高了程序的并发性和效率。本教程将深入探讨Java线程的使用,帮助开发者掌握这一关键技术。 一、线程基础 1. **线程的概念**:线程...
Java线程是多任务编程的重要概念,它允许程序同时执行多个独立的任务,从而...在"线程池.rar"和"线程实例"这两个文件中,你可以找到关于这些概念的具体示例代码,通过学习和实践,可以深入理解Java线程的运用和管理。
Java线程是Java编程语言中的核心概念,尤其在多任务处理和并发编程中扮演着重要角色。线程允许一个程序内部同时执行多个独立的控制流,使得程序能够更高效地利用处理器资源。本文将深入解析Java线程的相关知识点,...
《Java线程(第三版)》是一本深入探讨Java线程技术的专业书籍,旨在帮助开发者理解和掌握Java平台上的多线程编程。Java线程是并发编程的重要组成部分,它允许程序同时执行多个任务,从而充分利用系统资源,提高程序的...
本资源"JAVA线程学习(源代码)"提供了关于Java线程的源代码示例,帮助我们深入理解和实践线程的使用。 首先,我们要理解Java中的线程模型。Java线程由`java.lang.Thread`类或`java.util.concurrent.Executor`框架来...
JAVA线程dump的分析 JAVA线程dump是指在JAVA程序中,当前线程的状态和调用堆栈的快照,能够帮助开发者了解当前程序的执行情况,诊断问题和性能瓶颈。生成JAVA线程dump的方法在不同的操作系统下是不同的,在Windows...
这份“java线程文档大全”包含了关于Java线程的广泛知识,以下是其中的一些关键点: 1. **线程概念**:线程是程序执行的最小单位,每个线程都有自己的程序计数器、寄存器和局部变量,共享同一块内存空间。在Java中...
Java 模拟线程并发是编程领域中的一个重要概念,尤其在多核处理器和高并发应用中,理解并熟练掌握线程并发技术对于提升程序性能至关重要。在Java中,线程并发可以通过多种方式实现,包括继承Thread类、实现Runnable...
Java多线程设计模式上传文件Java多线程设计模式上传文件Java多线程设计模式上传文件Java多线程设计模式上传文件Java多线程设计模式上传文件Java多线程设计模式上传文件Java多线程设计模式上传文件Java多线程设计模式...