1.线程的创建:
接触过java的人都知道基本实现有3种:创建Thread子类、实现runnable接口、创建callable的接口实现类
import java.util.concurrent.Callable; import java.util.concurrent.ExecutionException; import java.util.concurrent.FutureTask; public class CreateThread { public static void main(String[] args) { //通过创建子类创建线程 Thread thread1 = new ThreadTest("Thread Test"); thread1.start(); //通过实现runnable创建线程 Thread thread2 = new Thread(new RunnableTest("Runnable Test")); thread2.start(); //通过callable创建线程 FutureTask<String> ft = new FutureTask<>(new CallableTest("Callable Test")); Thread thread3 = new Thread(ft); thread3.start(); try { System.out.println("callable 返回了结果:"+ft.get()); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (ExecutionException e) { // TODO Auto-generated catch block e.printStackTrace(); } } } class ThreadTest extends Thread{ private String name; public ThreadTest(String name) { this.name = name; } @Override public void run() { System.out.println("Thread: " + name + "run"); } } class RunnableTest implements Runnable{ private String name; public RunnableTest(String name) { this.name = name; } @Override public void run() { System.out.println("Thread: " + name + "run"); } } class CallableTest implements Callable<String>{ private String name; public CallableTest(String name) { this.name = name; } @Override public String call() throws Exception { System.out.println("Thread: " + name + "run"); return "callable 有返回值"; } }
创建方式的选择:
通常情况下假如你需要返回线程执行结果你则需要callable,不然创建thread子类与实现runnable并没有确定的答案,他们都能实现你的需求。但是线程池可以有效的管理实现了runnable接口的线程,假如线程池满了,之后的线程会排队等待知道线程池空闲出来。而通过thread子类来实现会复杂些。引用http://tutorials.jenkov.com/java-concurrency/creating-and-starting-threads.html中Subclass or Runnable?
2. 线程的其他常见方法
join():通俗的讲就是将制定线程加入到当前线程。实例:
public class JoinTest { public static void main(String[] args) { System.out.println("Main Thread start"); Thread joinThread = new Thread(new TestJoin()); joinThread.start(); try { joinThread.join(); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } System.out.println("Main Thread end"); } } class TestJoin implements Runnable{ @Override public void run() { try { Thread.sleep(2000); System.out.println("join here"); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } } }
输出:
Main Thread start join here Main Thread end
sleep():让当前执行的线程进入休眠状态,sleep将会让出cpu给其他线程,但是他的监控状态依然保持,指定时间到了之后自动恢复运行状态。sleep不会释放对象锁。
interrupt():中断。当调用interrupt()方法的时候,只是设置了要中断线程的中断状态,而此时被中断的线程的可以通过isInterrupted()或者是interrupted()方法判断当前线程的中断状态是否标志为中断。
wait()与notify():
如果对象调用了wait方法就会使持有该对象的线程把该对象的控制权交出去,然后处于等待状态。
如果对象调用了notify方法就会通知某个正在等待这个对象的控制权的线程可以继续运行。
3.生产者消费者
package com.Thead; import java.util.ArrayList; import java.util.List; public class Container { private List<Integer> list = new ArrayList<>(); private int MAX_NUM = 5; public synchronized void put(Integer num){ while(list.size() == MAX_NUM){ try { System.out.println("container is full"); this.wait(); //使当前线程进入等待状态 } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } } try { Thread.sleep(500); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } this.notify(); //唤醒当前访问对象的其他线程 list.add(num); System.out.println("producer add a num " + num); } public synchronized void get(){ while(list.size() == 0){ try { System.out.println("container is empty。。。"); this.wait(); //使当前线程进入等待状态 } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } } try { Thread.sleep(500); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } this.notify(); //唤醒当前访问对象的其他线程 int x = list.remove(0); System.out.println("customer remove a num "+x); } }
package com.Thead; import java.util.Random; public class Producer implements Runnable{ private Container container; public Producer(Container container) { this.container = container; } @Override public void run() { for(int i = 0; i < 10; i++){ int num = new Random().nextInt(10); container.put(num); } } }
package com.Thead; public class Consumer implements Runnable{ private Container container; public Consumer(Container container) { this.container = container; } @Override public void run() { for(int i = 0; i < 10; i++){ container.get(); } } }
package com.Thead; public class Main { public static void main(String[] args) { Container container = new Container(); Producer producer = new Producer(container); Consumer consumer = new Consumer(container); Thread p = new Thread(producer); Thread c = new Thread(consumer); p.start(); c.start(); } }
执行结果
container is empty。。。 producer add a num 5 customer remove a num 5 producer add a num 6 customer remove a num 6 producer add a num 7 customer remove a num 7 producer add a num 1 customer remove a num 1 producer add a num 0 customer remove a num 0 producer add a num 9 customer remove a num 9 ......
相关推荐
《Java多线程编程实战指南》这本书深入浅出地讲解了Java多线程的核心概念和实战技巧,分为核心篇和设计模式篇,旨在帮助开发者掌握并应用多线程技术。 1. **线程基础** - **线程的创建**:Java提供了两种创建线程...
Java多线程编程是Java开发中的...以上内容只是《Java多线程编程核心技术》教程中的一部分核心知识点,实际学习中还需要结合具体示例和实践来深入理解和掌握。通过学习,开发者可以编写出高效、稳定的多线程Java程序。
《Java多线程编程实战指南-核心篇》是一本深入探讨Java并发编程的书籍,旨在帮助读者掌握在Java环境中创建、管理和同步线程的核心技术。Java的多线程能力是其强大之处,使得开发者能够在同一时间执行多个任务,提高...
《深入学习:Java多线程编程》是一本专注于Java并发技术的专业书籍,旨在帮助开发者深入理解和熟练运用Java中的多线程编程。Java多线程是Java编程中的核心部分,尤其在现代高性能应用和分布式系统中不可或缺。理解并...
总之,“Java多线程编程指南”将涵盖这些核心概念,并可能深入到高级话题,如线程池的优化、并发容器的使用以及并发编程的最佳实践,帮助读者提升在多线程环境下的编程能力。通过深入学习和实践,开发者能够构建出...
Java多线程与线程安全编程实践-基于Http协议的断点续传.zip Java多线程与线程安全编程实践-基于Http协议的断点续传.zip Java多线程与线程安全编程实践-基于Http协议的断点续传.zip Java多线程与线程安全编程实践-...
Java多线程编程是Java开发中的重要组成部分,它允许程序同时执行多个任务,提升系统效率。在本教程中,我们将深入探讨Java中的多线程设计模式、并发核心编程概念以及线程池的工作原理和种类。 首先,让我们了解什么...
从给定的文件信息中,我们可以提取出关于Java多线程编程的重要知识点,涉及线程创建、线程生命周期以及线程间的同步与通信等核心概念。...通过实际操作和不断实践,可以更深入地掌握Java多线程编程的精髓。
本资料"Java多线程编程核心技术.zip"深入探讨了这些核心技术,并提供了源码供学习者实践和理解。 1. **线程的创建与启动** - 继承Thread类:自定义类继承Thread类,重写run()方法,然后创建该类对象并调用start()...
通过《Java多线程编程实例》随书源码,读者可以深入了解并实践这些概念,例如创建和管理线程池、实现线程安全的数据结构、解决死锁问题以及优化多线程应用等。书中的实例涵盖了多线程编程的各个重要方面,对于提升...
通过学习和实践这些Java多线程编程的知识点,开发者可以创建高效、健壮的多线程应用程序。提供的源程序文件可以作为学习和调试的实例,帮助你更好地理解和掌握这些概念。在实际开发中,理解并熟练运用这些技术,能...
Java多线程是Java编程中的重要概念,尤其在如今的多核处理器环境下,理解并熟练掌握多线程技术对于提高程序性能和响应速度至关重要...通过对这些知识点的学习和实践,读者可以深入理解Java多线程的运用,提升编程技能。
基于Http协议的断点续传-Java多线程与线程安全实践编程.zip 基于Http协议的断点续传-Java多线程与线程安全实践编程.zip 基于Http协议的断点续传-Java多线程与线程安全实践编程.zip 基于Http协议的断点续传-Java多...
### Java多线程编程详解:深入理解与实践 #### 一、理解多线程机制 多线程,作为现代编程语言的重要特性之一,允许在单一应用程序内并发执行多个任务,从而极大提升了程序的效率和响应速度。在Java中,多线程的...
Java多线程编程深入详解 多线程编程是Java编程语言中的一种...Java多线程编程是一种强大而复杂的技术,需要深入理解和实践。通过本文,我们了解了多线程编程的基础知识和高级技术,掌握了多线程编程的要领和实践经验。
Java多线程编程是Java开发中的重要组成部分,尤其在当今并发处理需求日益增长的时代,对多线程的理解和掌握显得尤为重要。《Java多线程编程(第二版)》这本书深入探讨了这一主题,旨在帮助开发者更好地理解和应用...
在Java编程中,多线程是一项关键技能,它允许程序同时执行多个任务,极大地提高了程序的...通过阅读"Java多线程编程实战指南 设计模式篇.pdf",你将获得更深入的理论知识和实践技巧,为你的编程事业奠定坚实的基础。
Java多线程是Java编程中的核心概念,它允许程序同时执行多个任务,提高了系统的效率和响应性。在Java中,多线程的实现主要通过两种方式:继承Thread类和实现Runnable接口。理解并掌握多线程的使用对于任何Java开发者...
Java多线程编程是Java开发中的...每个章节的源码都是一个独立的案例,可以逐一研究,实践和调试,以便更好地掌握Java多线程编程技巧。在学习过程中,结合理论知识与实际操作,将有助于提升对Java并发编程的全面认识。
《Java多线程编程实战指南(设计模式篇)》由黄文海撰写,是一本深入探讨Java多线程编程和设计模式的专业书籍。书中详细介绍了如何在Java环境中利用多线程来实现高效的并发处理,同时结合设计模式,帮助开发者更好地...