Java线程:线程的调度-合并
线程的合并的含义就是将几个并行线程的线程合并为一个单线程执行,应用场景是当一个线程必须等待另一个线程执行完毕才能执行时可以使用join方法。
join为非静态方法,定义如下:
void join()
等待该线程终止。
void join(long millis)
等待该线程终止的时间最长为 millis 毫秒。
void join(long millis, int nanos)
等待该线程终止的时间最长为 millis 毫秒 + nanos 纳秒。
等待该线程终止。
void join(long millis)
等待该线程终止的时间最长为 millis 毫秒。
void join(long millis, int nanos)
等待该线程终止的时间最长为 millis 毫秒 + nanos 纳秒。
/**
* Java线程:线程的调度-合并
*
* @author leizhimin 2009-11-4 9:02:40
*/
public class Test {
public static void main(String[] args) {
Thread t1 = new MyThread1();
t1.start();
for (int i = 0; i < 20; i++) {
System.out.println("主线程第" + i + "次执行!");
if (i > 2) try {
//t1线程合并到主线程中,主线程停止执行过程,转而执行t1线程,直到t1执行完毕后继续。
t1.join();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}
class MyThread1 extends Thread {
public void run() {
for (int i = 0; i < 10; i++) {
System.out.println("线程1第" + i + "次执行!");
}
}
}
* Java线程:线程的调度-合并
*
* @author leizhimin 2009-11-4 9:02:40
*/
public class Test {
public static void main(String[] args) {
Thread t1 = new MyThread1();
t1.start();
for (int i = 0; i < 20; i++) {
System.out.println("主线程第" + i + "次执行!");
if (i > 2) try {
//t1线程合并到主线程中,主线程停止执行过程,转而执行t1线程,直到t1执行完毕后继续。
t1.join();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}
class MyThread1 extends Thread {
public void run() {
for (int i = 0; i < 10; i++) {
System.out.println("线程1第" + i + "次执行!");
}
}
}
主线程第0次执行!
主线程第1次执行!
主线程第2次执行!
线程1第0次执行!
主线程第3次执行!
线程1第1次执行!
线程1第2次执行!
线程1第3次执行!
线程1第4次执行!
线程1第5次执行!
线程1第6次执行!
线程1第7次执行!
线程1第8次执行!
线程1第9次执行!
主线程第4次执行!
主线程第5次执行!
主线程第6次执行!
主线程第7次执行!
主线程第8次执行!
主线程第9次执行!
主线程第10次执行!
主线程第11次执行!
主线程第12次执行!
主线程第13次执行!
主线程第14次执行!
主线程第15次执行!
主线程第16次执行!
主线程第17次执行!
主线程第18次执行!
主线程第19次执行!
Process finished with exit code 0
主线程第1次执行!
主线程第2次执行!
线程1第0次执行!
主线程第3次执行!
线程1第1次执行!
线程1第2次执行!
线程1第3次执行!
线程1第4次执行!
线程1第5次执行!
线程1第6次执行!
线程1第7次执行!
线程1第8次执行!
线程1第9次执行!
主线程第4次执行!
主线程第5次执行!
主线程第6次执行!
主线程第7次执行!
主线程第8次执行!
主线程第9次执行!
主线程第10次执行!
主线程第11次执行!
主线程第12次执行!
主线程第13次执行!
主线程第14次执行!
主线程第15次执行!
主线程第16次执行!
主线程第17次执行!
主线程第18次执行!
主线程第19次执行!
Process finished with exit code 0
相关推荐
Java线程:线程的调度-合并 Java线程:线程的调度-守护线程 Java线程:线程的同步-同步方法 Java线程:线程的同步-同步块 Java线程:并发协作-生产者消费者模型 Java线程:并发协作-死锁 Java线程:volatile关键字 ...
Java中的线程调度策略涉及优先级、让步、合并等概念。线程的优先级会影响线程获取CPU的时间片,但并不是绝对的。 #### 八、Java线程:线程的同步-同步方法与同步块 Java中可以通过定义同步方法或使用同步块来实现...
本篇总结涵盖了Java多线程的基础概念、创建与启动、线程调度、同步与协作以及新特性。 **一、Java线程:概念与原理** 1. **线程与进程**: - **进程**:是操作系统资源分配的基本单位,每个进程都有独立的内存...
- **线程调度**:包括休眠、优先级调整、线程让步、合并线程以及守护线程的概念。 - **并发协作**:深入探讨了生产者-消费者模型和死锁问题,提供了理解和避免死锁的策略。 - **新特征**:Java 5引入的并发工具,如`...
- **线程控制**:多线程用于并发下载不同部分的数据,可能通过线程池来管理和调度线程。 - **错误处理**:包括网络异常、文件操作异常等,确保程序在出现问题时能优雅地处理并尝试恢复。 **5. 论文文档** 完成此...
Java多线程与线程安全在实际开发中扮演着至关重要的角色,特别是在处理并发操作时。本项目聚焦于Java中的多线程技术和基于Http协议的断点续传功能,这在大文件传输、网络下载场景中尤其常见。下面将详细阐述这两个...
Java线程是多任务编程中的核心概念,它允许程序同时执行多个不同的任务,极大地提高了程序的效率和响应性。在Java中,线程是通过Java.lang.Thread类或实现Runnable接口来创建和管理的。这份“java线程文档大全”包含...
### JAVA经典教材笔记知识点梳理 #### 第一章:JAVA概述及开发环境搭建 - **Java学习概述** - Java作为一种广泛使用的编程语言,其学习路径包括掌握基本语法、理解面向对象编程思想、熟悉标准库使用等。 - **JAVA...
在Java编程领域,多线程下载是一种常见的优化技术,它能显著提高大文件下载的速度,通过将文件分割成多个部分并同时下载,充分利用了网络连接的带宽资源。本项目"Java实现多线程下载源代码"正是这样一个示例,它使用...
Java多线程导出Excel是处理大数据量时的一种高效策略,尤其在面对千万级别的数据时。传统的Apache POI库在处理大规模数据时可能会遇到栈溢出(StackOverflowError)和内存溢出(OutOfMemoryError)等问题,因为这些...
- 线程是操作系统调度的基本单位,一个进程中可以有多个线程并发执行。 - Java提供了内置的线程支持,包括`Thread`类和`Runnable`接口,通过它们可以创建并运行线程。 2. **Java多线程实现**: - 实现方式一:...
Java线程的状态及主要转化方法** - **新建 (New)**:当一个线程对象被创建但尚未启动时的状态。 - **就绪 (Runnable)**:线程已经准备好运行,等待获取 CPU 资源。 - **运行 (Running)**:线程正在执行中。 - **...
Java线程是Java编程中非常重要的一个概念,它允许程序同时执行多个任务,从而提高了程序的效率和响应性。在Java中,线程是通过`java.lang.Thread`类或者实现`java.lang.Runnable`接口来创建和管理的。 1. **线程与...
主控类可以使用`ExecutorService`和`Future`来管理和调度线程,这样可以更方便地控制并发数量和处理结果。 在下载过程中,`Downloader`类会使用`HttpURLConnection`或`HttpClient`等HTTP客户端库发起HTTP请求,设置...
本专题涵盖了20多篇关于Java线程的精选技术文章,涉及了多个关键领域,如死锁、合并、休眠、优先级、阻塞等。以下是对这些主题的详细阐述: 1. **条件变量**: 条件变量是Java线程通信的一种机制,用于在特定条件...
- 线程的概念:操作系统能够进行运算调度的最小单位。 - 创建线程的方式:继承Thread类或实现Runnable接口。 - 同步与锁:synchronized关键字、ReentrantLock。 - 线程间通信:wait()、notify()、notifyAll()。 ...
Java线程有多种状态,包括: - **新建**(New):线程对象已经创建但尚未启动。 - **可运行**(Runnable):线程正在等待CPU分配时间片以运行。 - **阻塞**(Blocked):线程因为等待某种条件的发生而暂时停止运行。...
- **动态任务分配**:如果数组很大,可以进一步将子序列分割,分配给更多的线程进行排序,这需要一个任务调度器来管理线程和工作负载。 然而,多线程排序也需要注意几个问题: - **线程安全**:确保在并发操作中,...
3. **线程调度**: - **分时调度**:操作系统将CPU时间片分配给每个线程,让它们轮流执行。 - **抢占式调度**:高优先级的线程优先获得CPU资源,如果优先级相同,则可能随机选择。Java采用抢占式调度。 4. **创建...