Java并发编程基础---(14)实现多线程的3种方式

写在前面:

   Java 实现多线程共有3种方式,第一种是继承Thread类,第二种是实现Runnable接口,而在Java5之后,又增加了第三种方式,实现Callable接口。

  • 继承Thread类:
package createthread;

public class Demo1 {
	public static void main(String[] args) {
		ThreadDemo thread1 = new ThreadDemo();
		thread1.start();
	}

}

class ThreadDemo extends Thread {
	public void run() {
		System.out.print("thread1");
	}
}

  • 实现Runnable接口
package createthread;

public class Demo2 {
	public static void main(String[] args) {
		ThreadDemo3 demo = new ThreadDemo3();
		Thread thread1 = new Thread(demo);
		thread1.start();

	}

}

class ThreadDemo3 implements Runnable {

	@Override
	public void run() {
		System.out.println("实现Runnable接口方式");
	}

}
    与直接继承Thread不同,实现Runnable接口的方式,在调用时,我们仍然要先创建一个Thread实例,这种做的好处是,由于Java支持单继承,多实现,避免线程类继承了Thread,就不能继承其他类了。

  • 实现Callable接口:

要想使用Callable接口,分为以下几个步骤:

(1)创建一个Callable的实现类,并且实现call方法

(2)创建Callable实现类的实现,使用FutureTask类来包装一个Callable对象,这个FutureTask类的实例封装了Callable对象run方法的返回值。

(3)使用FutureTask对象作为Thread对象的target,创建并启动线程。

(4)调用FutureTask对象的get方法来获取子线程结束的返回值。

Demo:

package createthread;

import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.FutureTask;

public class Demo3 {
	public static void main(String[] args) throws InterruptedException, ExecutionException {
		Callable<Integer> call = new ThreadDemo4();
		FutureTask<Integer> task = new FutureTask<Integer>(call);
		Thread thread = new Thread(task);
		thread.start();
		System.out.println(task.get());
	}

}

class ThreadDemo4 implements Callable<Integer> {

	@Override
	public Integer call() throws Exception {
		System.out.println("Callable实现");
		return 7;
	}

}

控制台输出:

Callable实现
7

总结:

    三种方式对比之下,继承Thread类不如实现Runnable接口,因为Java支持单继承,多实现,避免线程类继承了Thread,就不能继承其他类了。

    实现Callable接口,可以满足,在线程执行结束时,会返回一个值的需求。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java并发编程是指在Java程序中使用多线程实现并发执行的编程技术。它能有效利用多核处理器的优势,提升程序的性能和响应能力。以下是Java并发编程基础知识: 1. 线程与进程:Java中的线程是程序中执行的最小单位,线程共享进程的资源,包括内存空间和文件等。多线程可以同时执行不同的任务,相比单线程能更高效地利用系统资源。 2. 线程创建:Java中创建线程有两方式,一是继承Thread类,实现run()方法;另一实现Runnable接口,重写run()方法。通过调用start()方法启动线程。 3. 线程同步:多个线程在访问共享资源时可能会产生竞争条件,可能会导致数据不一致或者出现死锁等问题。通过使用同步机制来保证线程安全,例如使用synchronized关键字实现对共享资源的互斥访问。 4. 线程通信:线程之间可以通过共享变量来进行通信。使用wait()、notify()和notifyAll()方法实现线程的等待和唤醒。 5. 线程池:线程池是一管理线程的机制,可以有效控制线程的数量和复用线程资源,避免频繁创建销毁线程的开销。 6. 并发容器:Java提供了一些线程安全的数据结构,如ConcurrentHashMap和ConcurrentLinkedQueue等,用于在多线程环境下安全地操作数据。 7. 原子操作:Java提供了一些原子操作类,如AtomicInteger和AtomicLong等,它们能够保证对共享数据的操作是原子的,不会发生数据不一致的情况。 8. 同步工具类:Java提供了一些同步工具类,如CountDownLatch和CyclicBarrier等,用于控制线程的执行顺序和线程之间的同步。 以上是Java并发编程基础知识,掌握了这些知识可以更好地利用多线程来提高程序的性能和并发能力。同时也需要注意并发编程可能带来的线程安全问题,合理使用同步机制和并发容器等工具类来保证程序的正确运行。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值