Java学习--多线程

在我们最开始学的程序中,都只有一个线程,即同一时刻之内做一件事,程序中的任务都是一个一个的顺序完成的。可很多时候我们面临的问题却是有多个任务同时进行的,这个时候就需要用到多线程。多线程就是java中内置的用来同时运行多个任务的机制。前面也提到过java的多线程只是用户视觉上的多线程,其实只是jvm把cpu资源的使用权在不同的线程之间快速地切换而已(多个cpu的电脑则不用切换,而是把不同的任务分给不同的cpu,实现了真正意义上的多线程),只是这个时间间隔足够的小使人感觉就像是在同时执行罢了。

在学习多线程之前必须明白什么是线程,区分程序、进程和线程。
程序是指一段静态的代码,他是应用软件执行的蓝本。
进程是程序一次动态的执行过程,包括加载静态代码、执行以及执行结束三个过程。
线程进程的一次更小的划分,一个进程可以产生多个不同的线程,形成多条执行线索,每个执行线索(线程)都有他创建、开始、中断、结束的生命周期。线程之间可以通过共享内存单元实现数据的共享、信息的沟通。

多线程的实现

1、创建Thread的子类来实现多线程

package com.mfs.test.thread;

public class ThreadTest {

	public static void main(String[] args) {
		// TODO Auto-generated method stub

		StringBuffer sb = new StringBuffer();
		Windows win1 = new Windows("窗口一",sb);
		Windows win2 = new Windows("窗口二",sb);
		
		win1.start();
		win2.start();
		
	}

}

class Windows extends Thread{
	private StringBuffer targets;
	
	public Windows(String name,StringBuffer targets) {
		setName(name);
		this.targets = targets;
	}
	
	public void run() {
		for(int i = 0;i < 3;i ++) {
			targets.append(getName());
			System.out.println("我是"+getName()+",StringBuffer是:"+targets);
			Thread.yield();         //建议jvm在此处切换cpu的使用权,只是建议真正会不会这样做不一定
		}
		
	}
	
}

2、通过实现Runnable接口实现多线程

用多线程实现多个斐波纳契数列

package com.mfs.test.thread;

import java.text.DecimalFormat;

public class RunnableTest {

	public static void main(String[] args) {
		// TODO Auto-generated method stub

		for(int i = 0;i < 5;i ++) {
			new Thread(new Run(10)).start();
		}
		
	}

}

class Run implements Runnable{

	protected int countDown;   //一个数列的元素个数
	private static int taskCount = 0;
	private final int id = taskCount++;  //做线程的标识id
	private double first = -1;         //斐波纳契数列的”第负一“
	private double second = 1;         //第零个
	private int count = 0;
	
	public Run(int n) {
		System.out.println("#"+id+"(Run Now),");
		countDown = n;
	}
	
	private String status() {
		return "#"+id+"id"+(++count)+"("+new DecimalFormat("0").format(first+second)+"),";
	}
	
	@Override
	public void run() {
		// TODO Auto-generated method stub
		while(countDown-- >0) {
			System.out.println(status());
			double n = first;
			first = second;
			second = n + second;
			Thread.yield();
		}
	}
	
}
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

M FS

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值