Java多线程系列-------一个简单的多线程示例

接下来我们就要正式讲解在java中怎么执行多线程了。

首先我们知道关于java文件在jvm上运行,对象的建立,执行以及最后的回收都有jvm完成。具体的方法是什么呢。

我们来打开Object类,发现一个方法

 protected void finalize() throws Throwable { }

这是一个专门用来回收对象内存的方法,我们可以重写这个方法。

/**
	 * 当垃圾收集确定不再有对该对象的引用时,垃圾收集器在对象上调用该对象。
	 * 自定义垃圾回收方法
	 */
	public void finalize(){
		System.out.println("Demo OK");
	}

在执行过程中我们会发现,会不断输出这个语句Demo OK。那么我们的系统的垃圾回收器在哪呢,就是System类里面的

gc()方法,通过它来启动垃圾回收器来回收垃圾,当然具体的回收要由cpu来调度。并不是我们一启动就会立即回收对象。

解决了这个。我们来正式看我们的多线程问题。

首先来看实现多线程的第一种方法,继承Thread类。

class Demo extends Thread{

之后我们需要重写Thread的run()方法。

在里面写上我们想要在一个独立的线程中运行的代码。

public void run(){
		for(int i = 0 ;i < 5;i++){
			System.out.println(Thread.currentThread().getName()+"<----->"+name+"<----->"+i);
		}
	}

其中的Thread.currentThread().getName()是获取当前对象的名称。

package com.zzu.my.thread.test.thread;
/**
 * Java虚拟机允许并发地执行多个线程
 * @author Administrator
 *
 */
//继承Thread类
//覆盖run方法
//调用子类的时候调用线程对象
//调用start方法启动线程
//run方法里面的代码是启动多线程要执行的方法。

class Demo extends Thread{
	private String name;
	public Demo(String name){
		this.name = name;
	}
	//只有调用start方法时,自定义线程的任务代码都存储在run方法中,这个时候会执行run()方法中的线程任务
	//只调用run()未启动线程时,run方法只是一个普通的方法,只有主线程去运行这个方法。
	public void run(){
		for(int i = 0 ;i < 5;i++){
			System.out.println(Thread.currentThread().getName()+"<----->"+name+"<----->"+i);
		}
	}
	
}
public class ThreadDemo {
	//从打印结果我们会看到三个线程在运行,main(主线程),Thread-1线程,Thread-0线程
	public static void main(String[] args) {
		
		Demo d1 = new Demo("A");//创建之后线程就被创建了
		Demo d2 = new Demo("B");
		//运行start方法会做两件事,开启线程,运行run方法
		d1.start();
		d2.start();
		for(int i = 0;i<10;i++){
			//从打印结果可以看到主线程运行的方法就是main
			System.out.println("打印当前正在运行的线程"+Thread.currentThread().getName());
		}
			
	}

}

这个就是完整的代码。

我们可以看到,当我们调用一个线程的start方法时,它在一个线程中调用run方法里面的代码。如果我们不调用start方法,直接运行run方法。那么实际上是在主线程中运行run方法,而不是两个子线程中分别运行的。

之后我会从内存角度分析一下多线程的执行过程。

你可能感兴趣的:(多线程)