多线程:Callable接口、静态代理、Lamda表达式、线程状态

Callable

1.实现Callable接口

2.重写call方法,需要抛出异常值

3.创建目标对象

4.创建执行服务:ExecutorService ser = Executors.newFixedThreadPool(1);

5.提交执行:Future<Boolean> result1 = ser.submit(t1);

6.获取结果:boolean r1 = result1.get();

7.关闭服务:ser.shutdownNow();

Callable的好处:

1.可以定义返回值

2.可以抛出异常

静态代理

public class StaticProxy {

    public static void main(String[] args) {
        
        WeddingCompany weddingCompany = new WeddingCompany(new You());
        weddingCompany.HappyMarry();
    }

    interface Marry{
        void HappyMarry();
    }
}
//真实角色,你去结婚
class You implements StaticProxy.Marry{
    @Override
    public void HappyMarry() {
        System.out.println("秦老师要结婚了,高兴!");
    }
}
//代理角色,帮你去结婚
class WeddingCompany implements StaticProxy.Marry{

    private StaticProxy.Marry target;

    public WeddingCompany(StaticProxy.Marry target){
        this.target = target;
    }

    @Override
    public void HappyMarry() {
        before();
        this.target.HappyMarry();
        after();
    }

    public void before(){
        System.out.println("结婚前准备准备");
    }

    public void after(){
        System.out.println("结完婚收拾收拾");
    }
}

静态代理总结:

1.真实对象和代理对象实现同一个接口

2.代理对象代理真实对象,使用target,放入代理对象,对真实对象进行操作,同时在代理对象内写出其他拓展方法。

好处:

//代理对象可以做很多真实对象做不了的事情

//真实对象可以专注做自己的事情

new Thread (()->System.out.println("我爱你")).start();

new WeddingCompany(new You()).HappyMarry();

把多线程和代理模式进行类比,都是同样继承接口。

lamda表达式

为什么要使用lambda表达式??

1.避免内部类过多

2.可以让你的代码看起来更简洁

3.去掉一堆没有用意义的代码,只保留核心的逻辑

函数式接口:

定义:任何接口,如果只包含一个抽象方法,那么他就是一个函数式接口

对于函数式接口,我们可以通过lambada表达式来创建该对象。

public class TestLambda2 {
    public static void main(String[] args) {
        Ilove love = (int a) -> {
            System.out.println("good"+a);
        };
        love.love(2);
        //简化1:参数类型
        love = (a) -> {
            System.out.println("good1"+a);
        }
        love.love(3);
        //简化2:简化括号
        love = a->{
            System.out.println("good"+a);
            System.out.println("good111"+a);
        };
        //简化3:去掉花括号
        love = a -> System.out.println("good"+a);
        //总结:
                //lambda表达式只能有一行代码情况下才能为一行,如果有多行,那么九可以用代码块包裹
                //前提式接口为函数式接口(接口里只有一个方法)
                //多个参数也可以去掉参数类型,要去掉就都去掉,但是必须得加上括号了
                //所以说多线程也可以使用lambda表达式 Thread = ()
        love.love(6);
    }
}

interface Ilove{
    void love(int a);
};

线程状态

五种状态:创建、就绪、阻塞、运行、死亡

setPriority(int newPriority)                         更改线程优先级

static void sleep(long millis)                        在指定的毫秒数内让当前正在执行的线程体休眠

void join()                                                    等待该线程停止(vip中间插入)

static void yield()                                        暂停当前正在执行的线程对象,并执行其他的线程

void interrupt();                                          中断线程,别用这个方法

boolean isAlive();                                        测试线程是否处于活动状态

测试stop方法

//1.建议线程正常停止-->利用次数,不建议死循环
//2.建议使用标志位-->设置一个标志位
//3.不要使用stop或者destory这种过时或者jdk不建议的方法
public class TestStop implements Runnable {

    //1.设置标志位
    private boolean flag = true;

    @Override
    public void run() {
        int i =0;
        while(flag){
            System.out.println("run....Thread"+i++);
        }
    }
    public void stop(){
        this.flag = false;
    }
    public static void main(String[] args) {
        TestStop testStop = new TestStop();
        new Thread(testStop).start();
        for (int i = 0; i < 1000; i++) {
            System.out.println("mian"+i);
            if(i==900){
                //调用stop方法切换标志位,让线程停止
                testStop.stop();
                System.out.println("线程该停止了");
            }
        }
    }
}

  • 8
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值