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方法,而不是两个子线程中分别运行的。
之后我会从内存角度分析一下多线程的执行过程。
还没有评论,来说两句吧...