01多线程

多线程

简介

创建线程

Thread class

  • 继承Thread类(重点)

1.自定义线程类继承Thread类

2.重写run()方法,编写线程执行体

3.创建线程对象,调用start()方法启动线程

package edu.wzw.Thread;
//创建线程方法:继承Thread类,重写run()方法,调用start开启线程
//总结:注意,线程开启不一定立即执行,由cpu调度执行
public class demo01 extends Thread{
    @Override
    public  void run (){//run()方法线程
        for (int i = 0; i < 20; i++) {
            System.out.println("你说得对"+i);
        }
    }
    public static void main(String[] args) {
        //main线程,主线程
        //创建一个线程对象
        demo01 demo01 = new demo01();
        //使用start()方法开启线程
        demo01.start();
        for (int i = 0; i < 20; i++) {
            System.out.println("你真是个大聪明"+i);
        }
    }
}

举例:下载网上图片

这里使用Maven,不使用Maven的话去导入io的包

<!-- https://mvnrepository.com/artifact/commons-io/commons-io -->
        <dependency>
            <groupId>commons-io</groupId>
            <artifactId>commons-io</artifactId>
            <version>2.9.0</version>
        </dependency>

主函数

package deu.wzw;
import org.apache.commons.io.FileUtils;

import java.io.File;
import java.io.IOException;
import java.net.URL;
//练习Thrad,实现多线程下载图片
public class Threads extends Thread {
    private String url;//网络图片地址
    private String name;//保存的文件名

    public Threads(String url, String name) {
        this.url = url;
        this.name = name;
    }
    //下载图片线程的执行体
    public void run() {
        WebDownLoader webDownLoader = new WebDownLoader();
        webDownLoader.downloder(url, name);
        System.out.println("文件名" + name);

    }

    public static void main(String[] args) {
        Threads t1 = new Threads("https://ss0.baidu.com/-Po3dSag_xI4khGko9WTAnF6hhy/zhidao/wh%3D450%2C600/sign=f491e04833fae6cd0ce1a3653a832312/bd315c6034a85edfee0bff5c4f540923dc5475cd.jpg", "1.jpg");
        t1.start();
    }
}
//下载器
class WebDownLoader{
    //下载方法
        public void downloder(String url,String name){
            try {
                FileUtils.copyURLToFile(new URL(url),new File(name));
            } catch (IOException e) {
                e.printStackTrace();
                System.out.println("IO异常,downloder方法出现异常");
            }
        }
}


unnable接口

  • 实现Runnable接口(核心重点)

1.定义MyRunnable实现Runnanle接口

2.实现Run()方法,编写线程执行体

3.创建线程对象,调用start()方法启动线程

package edu.wzw.Thread;

public class ThreadsRunnable implements Runnable {

    @Override
    public  void run (){//run()方法线程
        for (int i = 0; i < 20; i++) {
            System.out.println("我是你妈"+i);
        }
    }
    public static void main(String[] args) {
        ThreadsRunnable threadsRunnable = new ThreadsRunnable();
//        Thread thread = new Thread(threadsRunnable);
//        thread.start();  可以简写,如下
          new Thread(threadsRunnable).start();
          
        for (int i = 0; i < 20; i++) {
            System.out.println("我是你爹"+i);
        }
    }
}

Callable接口

  • 实现Callable接口
    • 实现Callable接口,需要返回值类型
    • 重写call方法,需要抛出异常
    • 创建目标对象
    • 创建执行服务:ExecutorService ser = Executors.newFixedThreadPool(1);
    • 提交执行:Futureresult1 = ser.submit()
    • 获取结果:boolean r1 = result.get();
    • 关闭服务:ser.shoutdownNow();

小结

  • 继承Thread类
    • 子类继承Thread类具备多线程能力
    • 启动线程:子类对象.start()
    • 不建议使用:避免OOP单继承局限性
  • 实现Runnable接口
    • 实现接口Runnable具有的多线程能力
    • 启动线程:传入目标对象+Thread对象.start()
    • 推荐使用:避免单继承局限性,灵活方便,方便同一个对象被多个线程使用
package edu.wzw.Thread;
//多线程同时操作一个对象
//买动车票的例子
//发现问题:多个线程操作同一个资源的情况下,线程不安全,数据紊乱。线程同步解决
public class Threaddemo02 implements Runnable{
    private int stickNum=10;//票数
    @Override
    public void run(){
        while(true){
            if (stickNum<=0){
                break;
            }//Thread.currentThread().getName()拿到线程的名字
        System.out.println(Thread.currentThread().getName()+"拿到了"+stickNum--+"票");
        }
    }

    public static void main(String[] args) {
        Threaddemo02 stick = new Threaddemo02();
        new Thread(stick,"wzw").start();
        new Thread(stick,"死黄牛").start();
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
CountDownLatch 可以用于多线程场景中获取线程的执行结果。可以通过以下步骤实现: 1. 创建一个 CountDownLatch 对象,并将计数器初始化为线程数量加1,即 latch = new CountDownLatch(n+1),其中 n 为线程的数量。 2. 创建多个线程,并将 CountDownLatch 对象作为参数传递给这些线程。在每个线程中,执行需要返回结果的操作,并将结果保存在相应的变量中。 3. 在每个线程执行完操作后,调用 countDown() 方法通知 CountDownLatch 对象一个线程已经完成。 4. 在主线程中,调用 await() 方法等待所有线程执行完操作。 5. 当所有线程都执行完操作后,主线程就可以通过获取各个线程保存的结果来进行进一步的处理。 示例代码如下所示: ``` // 创建 CountDownLatch 对象并初始化计数器 CountDownLatch latch = new CountDownLatch(n+1); List<Object> results = new ArrayList<>(); for (int i = 0; i < n; i++) { Thread thread = new MyThread(latch, i, results); thread.start(); } try { // 等待所有线程执行完操作 latch.await(); } catch (InterruptedException e) { e.printStackTrace(); } // 在这里可以对结果进行进一步处理 // results 中保存了每个线程执行的结果 ``` 在上面的代码中,MyThread 是一个自定义的线程类,它接受一个 CountDownLatch 对象、线程的编号和一个保存结果的列表作为参数。在 MyThread 的 run() 方法中,执行需要返回结果的操作,并将结果保存在列表中。在操作执行完成后,调用 countDown() 方法通知 CountDownLatch 对象一个线程已经完成。主线程在调用 await() 方法后会等待所有线程执行完操作,然后可以通过获取 results 列表中的结果来进行进一步的处理。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [【多线程笔记01多线程之CountDownLatch介绍及其使用](https://blog.csdn.net/qq_39826207/article/details/127113320)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [java多线程怎么同步返回结果](https://blog.csdn.net/kkevin_zzhang/article/details/129672820)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值