实例分析Java单线程与多线程

线程:每一个任务称为一个线程,线程不能独立的存在,它必须是进程的一部分

单线程:般常见的Java应用程序都是单线程的,比如运行helloworld的程序时,会启动jvm进程,然后运行main方法产生线程,main方法也被称为主线程。

多线程:同时运行一个以上线程的程序称为多线程程序,多线程能满足程序员编写高效率的程序来达到充分利用 CPU 的目的。

单线程代码例子:

public class SingleThread {
	public static void main(String[] args){
		Thread thread = Thread.currentThread(); //获取当前运行的线程对象
		thread.setName("单线程"); //线程重命名
		System.out.println(thread.getName()+"正在运行");
		for(int i=0;i<10;i++){
			System.out.println("线程正在休眠:"+i);
			try {
				thread.sleep(1000); //线程休眠,延迟一秒
			} catch (InterruptedException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
				System.out.println("线程出错");
			}
		}
	}
}

多线程代码例子:

注意:多线程有两种实现方式,一种是继承Thread类,另一种是实现Runnable接口。

继承Thread类实现多线程

public class TestThread {
	public static void main(String[] args){
		 Thread t1 = new ExtendThread("t1",1000); //使用上转对象创建线程,并构造线程名字和线程休眠时间
		 Thread t2 = new ExtendThread("t2",2000);
		 Thread t3 = new ExtendThread("t3",3000);
		 t1.start(); //启动线程并调用run方法
		 t2.start();
		 t3.start();
	}
}
class ExtendThread extends Thread{ //继承Thread的类
	String name;
	int time;
	public ExtendThread(String name, int time) { //构造线程名字和休眠时间
		this.name=name;
		this.time=time;
	}
	public void run(){ //重写Thread类的run方法
		try{
			sleep(time); //所有线程加入休眠
		}
		catch(InterruptedExceptione){
			e.printStackTrace();
			System.out.println("线程中断异常");
		}
		System.out.println("名称为:"+name+",线程休眠:"+time+"毫秒");
	}
}

实现Runnable接口的多线程

public class RunnableThread {
	public static void main(String[] args){
		Runnable r1=new ImplRunnable("r1",1000); //Runnable接口必须依托Thread类才能创建线程
		Thread t1=new Thread(r1); //Runnable并不能调用start()方法,因为不是线程,所以要用Thread类加入线程
		Runnable r2=new ImplRunnable("r2",2000);
		Thread t2=new Thread(r2);
		Runnable r3=new ImplRunnable("r3",3000);
		Thread t3=new Thread(r3);

		t1.start(); //启动线程并调用run方法
		t2.start();
		t3.start();
	}
}
class ImplRunnable implements Runnable{ //继承Runnable接口的类
	String name;
	int time;
	public ImplRunnable(String name, int time) { //构造线程名字和休眠时间
		this.name = name;
		this.time = time;
	}

	@Override
	public void run() { //实现Runnable的run方法
		try{
			Thread.sleep(time); //所有线程加入休眠
		}
		catch(InterruptedException e){
			e.printStackTrace();
			System.out.println("线程中断异常");
		}
		System.out.println("名称为:"+name+",线程休眠:"+time+"毫秒");
	}
}

说明:Thread类实际上也是实现了Runnable接口的类。

实现Runnable接口比继承Thread类所具有的优势

您可能感兴趣的文章:

  • Java Socket实现单线程通信的方法示例
  • JavaScrip单线程引擎工作原理分析
  • Java编程一道多线程问题实例代码
  • Java编程多线程之共享数据代码详解
  • Java多线程join方法实例代码
  • JAVA多线程CountDownLatch使用详解
  • 关于Java多线程编程锁优化的深入学习
  • java编程多线程并发处理实例解析
  • Java编程实现多线程TCP服务器完整实例
  • Java语言多线程终止中的守护线程实例
(0)

相关推荐

  • Java编程多线程之共享数据代码详解

    本文主要总结线程共享数据的相关知识,主要包括两方面:一是某个线程内如何共享数据,保证各个线程的数据不交叉:一是多个线程间如何共享数据,保证数据的一致性. 线程范围内共享数据 自己实现的话,是定义一个Map,线程为键,数据为值,表中的每一项即是为每个线程准备的数据,这样在一个线程中数据是一致的. 例子 package com.iot.thread; import java.util.HashMap; import java.util.Map; import java.util.Random; /*

  • Java多线程join方法实例代码

    本文研究的主要是Java多线程中join方法的使用问题,以下文为具体实例. Thread的非静态方法join()让一个线程B"加入"到另外一个线程A的尾部.在A执行完毕之前,B不能工作.例如: Thread t = new MyThread(); t.start(); t.join(); 另外,join()方法还有带超时限制的重载版本. 例如t.join(5000);则让线程等待5000毫秒,如果超过这个时间,则停止等待,变为可运行状态. 线程的加入join()对线程栈导致的结果是线程

  • JAVA多线程CountDownLatch使用详解

    前序: 上周测试给开发的同事所开发的模块提出了一个bug,并且还是偶现. 经过仔细查看代码,发现是在业务中启用了多线程,2个线程同时跑,但是新启动的2个线程必须保证一个完成之后另一个再继续运行,才能消除bug. 什么时候用? 多线程是在很多地方都会用到的,但是我们如果想要实现在某个特定的线程运行完之后,再启动另外一个线程呢,这个时候CountDownLatch就可以派上用场了 怎么用? 先看看普通的多线程代码: package code; public class MyThread extend

  • Java编程实现多线程TCP服务器完整实例

    相关Java类 Socket public class Socket extends Object ·功能:TCP客户端套接字 ·构造方法: Socket(InetAddress address, int port) 创建一个流套接字并将其连接到指定 IP 地址的指定端口号 ·常用方法: 1.getInetAddress 获得InetAddress的相关信息 2.getInputStream 获得此TCP连接的输入流 3.getOutPutStream 获得此TCP连接的输出流 ServerSo

  • 关于Java多线程编程锁优化的深入学习

    正文 并发环境下进行编程时,需要使用锁机制来同步多线程间的操作,保证共享资源的互斥访问.加锁会带来性能上的损坏,似乎是众所周知的事情.然而,加锁本身不会带来多少的性能消耗,性能主要是在线程的获取锁的过程.如果只有一个线程竞争锁,此时并不存在多线程竞争的情况,那么JVM会进行优化,那么这时加锁带来的性能消耗基本可以忽略.因此,规范加锁的操作,优化锁的使用方法,避免不必要的线程竞争,不仅可以提高程序性能,也能避免不规范加锁可能造成线程死锁问题,提高程序健壮性.下面阐述几种锁优化的思路. 一.尽量不要

  • Java语言多线程终止中的守护线程实例

    Java中线程分为两种类型:用户线程和守护(服务)线程.通过Thread.setDaemon(false)设置为用户线程;通过Thread.setDaemon(true)设置为守护线程;不设置则默认为用户线程. 结束单线程用 Thread.interrupt() 方法,多线程结束则需要设置守护线程.当不存在用户线程时,守护线程就会全部终结(可以理解为:守护线程是服务线程,用户线程是被服务线程,用户线程(被服务线程)全都没有了,服务线程便没有存在意义而自动终结) 例子: class StopThr

  • Java Socket实现单线程通信的方法示例

    本文实例讲述了Java Socket实现单线程通信的方法.分享给大家供大家参考,具体如下: 现在做Java直接使用Socket的情况是越来越少,因为有很多的选择可选,比如说可以用spring,其中就可以支持很多种远程连接的操作,另外jboss的remoting也是不错的选择,还有Apache的Mina等等,但是在有些时候一些特殊情况仍然逃脱不了直接写Socket的情况,比如公司内部一些莫名其妙的游戏规则. 废话不说了,下面就看看如果自己写Socket应该怎么做吧. 首先是写一个Server类,这

  • java编程多线程并发处理实例解析

    本文主要是通过一个银行用户取钱的实例,演示java编程多线程并发处理场景,具体如下. 从一个例子入手:实现一个银行账户取钱场景的实例代码. 第一个类:Account.java 账户类: package cn.edu.byr.test; public class Account { private String accountNo; private double balance; public Account(){ } public Account(String accountNo,double

  • Java编程一道多线程问题实例代码

    前面几篇博文基本上总结了一下java并发里的一些内容,这篇博文主要从一个问题入手,看看都能用到前面总结的哪些并发技术去解决. 题目描述: 模拟一个场景:处理16条日志记录,每条日志记录打印时间需要1秒,正常情况下如果将这16条记录去部打完需要16秒,现在为了提高效率,准备开启4个线程去打印,4秒钟打印完,实现这个demo. 先来分析一下这个题目,关于这16条日志记录,我们可以在主线程中产生出来,这没用什么难度,关键是开启4个线程去执行,现在有两种思路:一种是日志的产生和打印日志的线程在逻辑上分开

  • JavaScrip单线程引擎工作原理分析

    从基础的层面来讲,理解JavaScript的定时器是如何工作的是非常重要的.定时器的执行常常和我们的直观想象不同,那是因为JavaScript引擎是单线程的.我们先来认识一下下面三个函数是如何控制计时器的. 我们推荐阅读:雕虫无小技 JavaScript初学者的10个迷你技巧 复制代码 代码如下: var id = setTimeout(fn, delay); 初始化一个计时器,然后在指定的时间间隔后执行.该函数返回一个唯一的标志ID(Number类型),我们可以使用它来取消计时器. 复制代码

随机推荐