BigDataJava基础_多线程

Posted 奔跑的金鱼

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了BigDataJava基础_多线程相关的知识,希望对你有一定的参考价值。

所谓的多线程就像小吃街卖铜锅米线的老板,老板就好比一个操作系统,如果5个顾客同时去买米线,那么,此时老板就会同时准备好5个铜锅,然后同时放上水、调料、米线,同时煮5个人的米线,如果逐个煮的话,那么估计煮了2个人的米线,后面3人就来找老板退款了。

官方解释:多线程(英语:multithreading),是指从软件或者硬件上实现多个线程并发执行的技术

在Java中实现多线程四部曲:

(1)将需要用多线程方式执行的逻辑,写入一个runnable实现类中(run方法中);

(2)创建出这个runnable实现类的对象;

(3)利用这个runnable对象构造出n个thread线程;

(4)将这n个thread启动(thread.start());

1.多线程案例

测试类:Demo1.java
package cn.test.logan.day13;
/**
 * 多线程测试类1
 * @author QIN
 *
 */
public class Demo1 implements Runnable{

    @Override
    public void run() {
        for(int i= 0;i<=2;i++) {
            System.out.println("Demo1中的线程-"+i+"**********");
        }    
    }
    

}

 测试类:Demo2.java

package cn.test.logan.day13;
/**
 * 多线程测试类2
 * @author QIN
 *
 */
public class Demo2 implements Runnable{
        @Override
        public void run() {
            for(int i= 0;i<=5;i++) {
                System.out.println("Demo2中的线程"+i+"----------");
            }    
        }
}

 

测试多线程类:ThreadDemo.java

package cn.test.logan.day13;

public class ThreadDemo {
    
    public static void main(String[] args) {
        Demo1 demo1 = new Demo1();
        Demo2 demo2 = new Demo2();
        // 构造一个线程,指定要执行的逻辑
        Thread thread1 = new Thread(demo1);
        Thread thread2 = new Thread(demo1);
        Thread thread3 = new Thread(demo1);
        Thread thread4 = new Thread(demo2);
        Thread thread5 = new Thread(demo2);
        
        // 将这5个线程以多线程方式启动
        thread1.start();
        thread2.start();
        thread3.start();
        thread4.start();
        thread5.start();
    }
    
}

 

执行结果:

 

 2.将数据传递到Runnable对象中

在实际操作中,我们有时候需要往对象中动态的传递数据,此时可以使用构造函数来完成,以下是具体的代码实现。

多线程测试代码:ThreadDem.java

package cn.test.logan.day13;

public class ThreadDemo {
    
    public static void main(String[] args) {
        Demo1 demo1 = new Demo1("张三");Demo1 demo12 = new Demo1("李四");Demo1 demo13 = new Demo1("王五");
        Demo2 demo2 = new Demo2();
        // 构造一个线程,指定要执行的逻辑
        Thread thread1 = new Thread(demo1);
        Thread thread2 = new Thread(demo12);
        Thread thread3 = new Thread(demo13);
        Thread thread4 = new Thread(demo2);
        Thread thread5 = new Thread(demo2);
        
        // 将这5个线程以多线程方式启动
        thread1.start();
        thread2.start();
        thread3.start();
        thread4.start();
        thread5.start();
    }
    
}

 

 

测试类1:Demo1.java

package cn.test.logan.day13;
/**
 * 多线程测试类1
 * @author QIN
 *
 */
public class Demo1 implements Runnable{
    private String name;
    
    public Demo1(String name) {
        super();
        this.name = name;
    }

    @Override
    public void run() {
        for(int i= 0;i<=2;i++) {
            System.out.println("Demo1中的线程-"+name);
        }    
    }
    

}

 

测试类2:Demo2.java

package cn.test.logan.day13;
/**
 * 多线程测试类2
 * @author QIN
 *
 */
public class Demo2 implements Runnable{
        @Override
        public void run() {
            for(int i= 0;i<=5;i++) {
                System.out.println("Demo2中的线程"+i+"----------");
            }    
        }
}

 

 

测试结果:

以上是关于BigDataJava基础_多线程的主要内容,如果未能解决你的问题,请参考以下文章

BigDataJava基础_冒泡排序

BigDataJava基础_FileInputStream的基本使用

BigDataJava基础_FileOutputStream写入文件

BigDataJava基础_DataOutputStream与DataInputStream

BigDataJava基础_终端输入2个数字并求和

BigDataJava基础_HashMap