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();
		}
	}
	
}
发布了57 篇原创文章 · 获赞 55 · 访问量 1973

猜你喜欢

转载自blog.csdn.net/qq_40561126/article/details/99206484