这里我们再来测试一个接口,Thread接口,我们先编写一个单例模式,然后模拟多线程来验证单例模式创建的对象是否为同一个对象(即单例模式是否只会创建一个对象),单例的代码我就不放了,网上都能搜到,我们直接上测试类
Thread t2 = new Thread(){
@Override
public void run(){
HungrySingle hungrySingle = HungrySingle.hungrySingle;
System.out.println("t2线程获取对象的hashCode:" + hungrySingle.hashCode());
}
}.start();
如果使用匿名内部类的方法来获取当前线程的hashCode,我们就得像第一个游泳示例一样,通过在new Thread()里面使用匿名内部类来实现对run()方法的重写,最后通过t2.start();方法来启动线程,或者不新建t2对象,直接在后面调用.start();方法来启动线程。这里我们使用lambda表达式来简化代码:
// 使用lambda表达式简化代码
new Thread(() -> System.out.println("t1线程获取对象的hashCode:" +
hungrySingle.hashCode())).start();
这样就很简单
如果总结一下用法的话我觉得这里主要就两种吧:
如果类B调用了接口A里的方法,假设B中调用的方法为methodB(),那么在main函数里面调用形式为:
B.methodB( (根据情况选择是否带参) -> 表达式或代码块 )
那如果是像Thread那样在new后面的括号里面通过匿名内部类来赋不同的值,就直接new Object( (根据情况选择是否带参) -> 表达式或代码块 )
目前就总结到这里,这是一个菜鸟根据目前所写过的Demo来进行的总结,如有不对请各位大佬指正下了,谢谢