摘要: 多线程实现的方式三: A:创建一个线程池对象,控制要创建几个线程对象。 public static ExecutorService newFixedThreadPool(int nThreads) B:做一个类实现Callable接口。 C:调用如下方法即可 Future<?> submit(Run 阅读全文
posted @ 2018-09-02 23:59 书丶生 阅读(578) 评论(0) 推荐(0) 编辑
摘要: 程序启动一个新线程成本是比较高的,因为它涉及到要与操作系统进行交互。而使用线 程池可以很好的提高性能,尤其是当程序中要创建大量生存期很短的线程时,更应该考虑使 用线程池。 线程池里的每一个线程代码结束后,并不会死亡,而是再次回到线程池中成为空闲状态, 等待下一个对象来使用。 在JDK5 之前,我们必 阅读全文
posted @ 2018-09-02 22:37 书丶生 阅读(125) 评论(0) 推荐(0) 编辑
摘要: Java 中使用ThreadGroup 来表示线程组,它可以对一批线程进行分类管理,Java 允许程 序直接对线程组进行控制。 默认情况下,所有的线程都属于主线程组。 我们也可以给线程设置分组:对一个线程组进行操作,如将一个线程组设置为守护线程,获取线程组的最大优先级等。 阅读全文
posted @ 2018-09-02 21:08 书丶生 阅读(147) 评论(0) 推荐(0) 编辑
摘要: 阅读全文
posted @ 2018-09-02 18:53 书丶生 阅读(149) 评论(0) 推荐(0) 编辑
摘要: 在线程安全解决之后,还是一样存在着如下的问题: A:如果消费者先抢到CPU的执行权,就会去消费数据,但是现在的数据是默认值,没有意义,应该等着数据有意义,再消费。 B:如果生产者先抢到CPU的执行权,就会去生产数据,但是呢,它生产完数据后,还继续拥有执行权,它又继续产生数据。这是有问题的,它应该等着 阅读全文
posted @ 2018-09-02 18:48 书丶生 阅读(283) 评论(0) 推荐(0) 编辑
摘要: 针对同一个资源的操作有不同种类的线程:生产线程和消费线程 执行结果: 分析: 资源类:Student 设置学生数据:SetThread(生产者) 获取学生数据:GetThread(消费者) 测试类:StudentTest 问题一:执行测试类,发现输出结果是null 0 原因:我们在每个线程中都创建了 阅读全文
posted @ 2018-09-02 01:38 书丶生 阅读(174) 评论(0) 推荐(0) 编辑