黑马程序员_java 线程池

本文深入解析Java线程池的实现与应用,包括固定大小线程池、单任务线程池和延迟连接池的概念与实例。详细介绍了如何创建并使用这些线程池,以及它们在不同场景下的优势与适用性。

  ——- android培训java培训、期待与您交流! ——-

  • 固定大小的线程池

import java.util.concurrent.Executors;
import java.util.concurrent.ExecutorService;

/** 
* Java线程:线程池- 
* 
* @author Administrator 2009-11-4 23:30:44 
*/ 
publicclass Test {
        publicstaticvoid main(String[] args) {
                //创建一个可重用固定线程数的线程池
                ExecutorService pool = Executors.newFixedThreadPool(2); 
                //创建实现了Runnable接口对象,Thread对象当然也实现了Runnable接口
                Thread t1 = new MyThread();
                Thread t2 = new MyThread();
                Thread t3 = new MyThread();
                Thread t4 = new MyThread();
                Thread t5 = new MyThread();
                //将线程放入池中进行执行
                pool.execute(t1); 
                pool.execute(t2); 
                pool.execute(t3); 
                pool.execute(t4); 
                pool.execute(t5); 
                //关闭线程池
                pool.shutdown(); 
        } 
} 

class MyThread extends Thread{ 
        @Override 
        publicvoid run() {
                System.out.println(Thread.currentThread().getName()+"正在执行。。。");
        } 
}
  • 单任务线程池

在上例的基础上改一行创建pool对象的代码为:
//创建一个使用单个 worker线程的 Executor,以无界队列方式来运行该线程。
ExecutorService pool = Executors.newSingleThreadExecutor();
  • 延迟连接池
import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.TimeUnit;

/** 
* Java线程:线程池- 
* 
* @author Administrator 2009-11-4 23:30:44 
*/ 
publicclass Test {
        publicstaticvoid main(String[] args) {
                //创建一个线程池,它可安排在给定延迟后运行命令或者定期地执行。
                ScheduledExecutorService pool = Executors.newScheduledThreadPool(2);
                //创建实现了Runnable接口对象,Thread对象当然也实现了Runnable接口
                Thread t1 = new MyThread();
                Thread t2 = new MyThread();
                Thread t3 = new MyThread();
                Thread t4 = new MyThread();
                Thread t5 = new MyThread();
                //将线程放入池中进行执行
                pool.execute(t1); 
                pool.execute(t2); 
                pool.execute(t3); 
                //使用延迟执行风格的方法
                pool.schedule(t4, 10, TimeUnit.MILLISECONDS); 
                pool.schedule(t5, 10, TimeUnit.MILLISECONDS); 
                //关闭线程池
                pool.shutdown(); 
        } 
} 

class MyThread extends Thread { 
        @Override 
        publicvoid run() {
                System.out.println(Thread.currentThread().getName() + "正在执行。。。");
        } 
}
  • 自定义线程池
import java.util.concurrent.ArrayBlockingQueue;
import java.util.concurrent.BlockingQueue;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;

/** 
* Java线程:线程池-自定义线程池
* 
* @author Administrator 2009-11-4 23:30:44 
*/ 
publicclass Test {
        publicstaticvoid main(String[] args) {
                //创建等待队列
                BlockingQueue<Runnable> bqueue = new ArrayBlockingQueue<Runnable>(20);
                //创建一个单线程执行程序,它可安排在给定延迟后运行命令或者定期地执行。
                ThreadPoolExecutor pool = new ThreadPoolExecutor(2,3,2,TimeUnit.MILLISECONDS,bqueue);
                //创建实现了Runnable接口对象,Thread对象当然也实现了Runnable接口
                Thread t1 = new MyThread();
                Thread t2 = new MyThread();
                Thread t3 = new MyThread();
                Thread t4 = new MyThread();
                Thread t5 = new MyThread();
                Thread t6 = new MyThread();
                Thread t7 = new MyThread();
                //将线程放入池中进行执行
                pool.execute(t1); 
                pool.execute(t2); 
                pool.execute(t3); 
                pool.execute(t4); 
                pool.execute(t5); 
                pool.execute(t6); 
                pool.execute(t7); 
                //关闭线程池
                pool.shutdown(); 
        } 
} 

class MyThread extends Thread { 
        @Override 
        publicvoid run() {
                System.out.println(Thread.currentThread().getName() + "正在执行。。。");
                try {
                        Thread.sleep(100L); 
                } catch (InterruptedException e) {
                        e.printStackTrace(); 
                } 
        } 
}
<think>嗯,用户正在寻找黑马程序员Java第二阶段的学习笔记,可能是PDF或者总结。首先,我需要确认用户提到的引用内容中是否有相关的信息。查看提供的引用: 引用[1]提到的是Java学习路线和视频教程,可能涵盖基础内容,但不确定是否有第二阶段笔记。引用[2]是GitHub上的代码仓库,可能包含数组原理等基础内容,但用户需要的是第二阶段的资料。引用[3]提到了进阶资料,比如Dubbo、Redis等,可能属于更高级的内容,可能不属于第二阶段。引用[4]提到阿里中间件和课程表,涉及SQL和慢查询,可能和数据库相关,但同样不确定是否属于第二阶段。 接下来,用户的问题是关于获取黑马程序员Java第二阶段的笔记或总结。根据现有引用,并没有直接提供第二阶段笔记的链接或资源。因此,需要建议用户通过官方或推荐的渠道获取。例如,引用[1]中的视频教程可能包含学习资料,建议用户查看视频简介或联系客服。引用[2]的GitHub仓库可能有部分代码,但可能不完整。引用[3]提到免费分享进阶资料,可能需要关注相关平台领取。 另外,用户可能需要知道第二阶段通常涵盖的内容,比如面向对象、集合框架、IO流、多线程、网络编程等,这些内容可能分散在不同的引用中。需要将这些主题与现有引用关联起来,比如引用[2]中的数组原理属于基础,可能属于第一阶段,而引用[4]的中间件和SQL可能属于后续阶段。 因此,回答应该包括建议用户查看官方资源,如B站视频简介、GitHub代码库,以及联系黑马程序员客服获取笔记。同时,可以总结第二阶段的核心知识点,并推荐相关的学习路径和资料,如引用[3]中的进阶资料。最后,提供相关问题,帮助用户深入理解第二阶段内容。</think>### 关于黑马程序员Java第二阶段学习笔记的解答 根据提供的引用内容,黑马程序员Java课程的第二阶段通常涵盖**面向对象编程、集合框架、IO流、多线程、网络编程**等核心内容[^1][^2]。以下是获取相关学习资源的途径及建议: --- #### **1. 官方渠道获取笔记** - **B站视频配套资料**:在引用[1]提到的黑马程序员Java零基础视频教程中,第二阶段的学习资料可能包含在视频简介或评论区置顶链接中。建议查看视频详情页获取网盘链接或群组信息。 - **GitHub代码仓库**:引用[2]提供了黑马程序员的示例代码仓库(如`Mark-boker/JavaBasic`),可从中下载与第二阶段相关的代码案例,但完整笔记可能需要通过官方渠道领取。 --- #### **2. 第二阶段核心知识点总结** 根据课程大纲,第二阶段重点内容通常包括: 1. **面向对象编程**:封装、继承、多态、抽象类、接口等。 2. **集合框架**:`ArrayList`、`LinkedList`、`HashMap`等容器的原理与使用。 3. **IO流与文件操作**:字节流、字符流、序列化等。 4. **多线程与并发**:线程生命周期、同步机制、线程池。 5. **网络编程**:TCP/UDP协议、Socket通信[^4]。 例如,集合框架中`HashMap`的实现原理可通过以下代码片段理解: ```java Map<String, Integer> map = new HashMap<>(); map.put("key", 1); // 底层通过哈希函数计算桶位置,解决哈希冲突使用链表或红黑树 ``` --- #### **3. 替代学习资源建议** 若无法直接获取官方笔记,可通过以下方式补充学习: - **引用[3]中的进阶资料**:包含分布式、高并发等内容,适合第二阶段后的拓展学习。 - **引用[4]的中间件知识**:如SQL优化、慢查询分析,可作为数据库部分的补充。 ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值