小言_互联网的博客

Java进阶(七)多线程编程,程序员必备技能!

249人阅读  评论(0)

个人主张自学,但是也不能忘记了讨论的重要性,但是由于平时不z怎么看CSDN,所以呢我这边搞了一个小圈子,欢迎大家来哦~可以畅所欲言呀——小圈子

不过CSDN评论区我也会不定时观看的,所以非强制性要求哦


多线程编程

何为多线程,通俗的讲就是让你的代码同时干好几件事。

而我们的一个代码文件或者一个项目就是一个进程,而如果我们想提高效率,我们可以多开几个文件进行多进程,也可以在进程中创建多线程(多写几个方法),但是多进程比较耗费资源,所以一般推荐多线程,在代码里,让代码做几个文件做的事。

多线程编程可以让我们的代码拥有更高效率。

线程的工作过程

犹如上图

使用多线程需要先创建一个或者多个线程

然后让线程调用CPU资源,开始运行

然后运行完毕等待所有线程运行完毕

然后删除资源,结束线程

Java线程拥有优先级

优先级就是系统确定线程的调度顺序,但是不执行顺序,因为多线程的执行是具有无序性的。

调度顺序只是系统分配资源的顺序,不分配资源就无法执行。

创建多线程

如何在Java代码中创建多线程,Java内置了用于多线程的库。

1.继承Thread类,重写run()方法

我们需要写一个类A来继承Thread类,并重写run()方法。

run()方法里面放我们需要进行多线程的代码。

然后再在主类中实例化类A的对象,并且调用strat方法。

public  class TheadText  {
   
    public static void main(String[] args) {
   
        //实例化StartThread,并调用start方法使线程动起来
        StartThread t1 = new StartThread("一  ");
        t1.start();
        StartThread t2 = new StartThread("二  ");
        t2.start();
        StartThread t3 = new StartThread("三  ");
        t3.start();
        StartThread t4 = new StartThread("四  ");
        t4.start();
    }
}

/**
 * 1.继承Thread类并重写run方法
 */
 class StartThread extends Thread{
   

     String name;
     StartThread(String name){
   
         this.name = name;
     }
    @Override
    public void run() {
   

       System.out.println(name+1);
       System.out.println(name+2);
       System.out.println(name+3);
       System.out.println(name+4);
       System.out.println(name+5);
     }
 }

运行结果(还可以体现线程的无序性):

2. 实现接口Runnable接口,实现run方法

使用Runnable接口避免了单继承的局限性,线程类只是实现了 Runnable 接口,还可以继承其他类

public  class TheadText  {
   
    public static void main(String[] args) {
   
		StartRunnable startRunnable1 = new StartRunnable("  一  ");
        Thread te1 = new Thread(startRunnable1);
        te1.start();
        StartRunnable startRunnable2 = new StartRunnable("  二  ");
        Thread te2 = new Thread(startRunnable2);
        te2.start();
        StartRunnable startRunnable3 = new StartRunnable("  三  ");
        Thread te3 = new Thread(startRunnable3);
        te3.start();
        StartRunnable startRunnable4 = new StartRunnable("  四  ");
        Thread te4 = new Thread(startRunnable4);
        te4.start();
	}
}
/**
 * 2. 实现Runnable接口,实现run方法
 */
 class StartRunnable implements Runnable{
   
     String name;
//     重载一下方法,利于区分
     StartRunnable(String name){
   
         this.name = name;
     }
     @Override
     public void run() {
   
         System.out.println(name+1);
         System.out.println(name+2);
         System.out.println(name+3);
         System.out.println(name+4);
         System.out.println(name+5);
     }

 }

运行结果:

3. 实现Callable接口,实现call方法

这个我研究了挺大一会儿。

实现这个接口后,还需要实现call方法

然后通过FutureTask类来对我们实例化对象进行封装

最后还要实例化Thread类进行start操作开启我们的线程

代码演示:

public  class TheadText  {
   
    public static void main(String[] args) {
   
        //先实例化
        StartCallable a = new StartCallable();
        //然后调用FutureTask类
        FutureTask<String> te1 = new FutureTask<>(a);
        //设置我们的name属性
        a.name = "  一  ";
        //开启我们的线程一
        new Thread(te1).start();
        StartCallable b = new StartCallable();
        FutureTask<String> te2 = new FutureTask<>(b);
        b.name = "  二  ";
        new Thread(te2).start();
        StartCallable c = new StartCallable();
        FutureTask<String> te3 = new FutureTask<>(c);
        c.name = "  三  ";
        new Thread(te3).start();
        StartCallable d = new StartCallable();
        FutureTask<String> te4 = new FutureTask<>(d);
        d.name = "  四  ";
        new Thread(te4).start();

    }
}
/**
 * 实现Callable接口,实现call方法
 */
 class StartCallable implements Callable<String>{
   
     String name ;
     public String call() throws Exception{
   
         System.out.println(name+1);
         System.out.println(name+2);
         System.out.println(name+3);
         System.out.println(name+4);
         return name;
     }
 }

运行结果:

线程的生命周期

线程在我们创建后(出生)等待CPU的资源分配,然后开始工作,在工作完我们分配的工作后,就会(死亡)消失

结语

学习的时光总是很快的,我们再见!
个人主张自学,但是也不能忘记了讨论的重要性,我这边搞了一个小圈子,欢迎大家来玩哦~可以畅所欲言呀 ~ ——小圈子


转载:https://blog.csdn.net/m0_52883898/article/details/116723760
查看评论
* 以上用户言论只代表其个人观点,不代表本网站的观点或立场