//HomeBean.class
new HttpResponse() {
…
};
//BannerBean.class
new HttpResponse() {
…
};
这个T可以是HomeBean
也可以是BannerBean
。
2.2 Java泛型类
把泛型定义在类上,如下:
public class 类名<泛型类型> {
}
2.2.1 定义
使用场景:我们用到的地方就更多了。如网络请求返回的data(经常被定义为泛型),如下:
public class ResponseData {
private int errorCode;
private String errorMsg;
private T data;
}
2.2.2使用
@GET(“banner/json”)
Call<ResponseData<List>> homeBannerRetrofit();
@POST(“user/register”)
@FormUrlEncoded
Call<ResponseData> registerRetrofit(@FieldMap Map<String,String> map);
这个T可以是List<HomeBanner>
也可以是RegisterData
。
2.3 Java泛型方法
把泛型定义在类上,如下:
public <泛型类型> 返回类型 方法名<泛型类型 变量名> {
}
2.3.1 定义
使用场景:我们用到的地方就更多了。如网络请求返回的data(经常被定义为泛型),如下:
public class Test {
public T name(T data){
return data;
};
}
2.3.2 使用
Test test = new Test();
HomeBean homeBean = test.name(new HomeBean());
RegisterData registerData = test.name(new RegisterData());
这个T可以是HomeBean
也可以是RegisterData
。
2.4 Java泛型擦除及其相关内容
在编译期间,所有泛型信息都会被擦除掉,在生成的字节码中是不包括泛型中的类型信息的。
2.4.1 ArrayList源码
public class ArrayList extends AbstractList
implements List, RandomAccess, Cloneable, java.io.Serializable
{
}
这明显就是个泛型类。下面咱们看一组实例:
List list = new ArrayList<>();
list.add(“abc”);
List list1 = new ArrayList<>();
list1.add(123);
List list2 = new ArrayList<>();
list2.add(new UserBean(20,“sc”));
MLog.e(String.valueOf(list.getClass()));
MLog.e(String.valueOf(list.getClass() == list1.getClass()));
MLog.e(String.valueOf(list.getClass() == list2.getClass()));
MLog.e(String.valueOf(list1.getClass() == list2.getClass()));
打印结果:
E/—mlog----: class java.util.ArrayList
E/—mlog----: true
E/—mlog----: true
E/—mlog----: true
然后你会发现ArrayList<E>
中的泛型<E>
被擦除。所以add的时候全部以Object的形式添加。
2.5 Java泛型通配符
2.5.1 T,E,K,V
约定俗成的东西:
-
T (type) 表示具体的一个java类型
-
K V (key value) 分别代表java键值中的Key Value
-
E (element) 代表Element
也可以定义为其他字母,但是不推荐,比较你用这几个别人一看就知道什么意思。
2.5.2 <? extends T>
上界通配符
总目录展示
该笔记共八个节点(由浅入深),分为三大模块。
高性能。 秒杀涉及大量的并发读和并发写,因此支持高并发访问这点非常关键。该笔记将从设计数据的动静分离方案、热点的发现与隔离、请求的削峰与分层过滤、服务端的极致优化这4个方面重点介绍。
一致性。 秒杀中商品减库存的实现方式同样关键。可想而知,有限数量的商品在同一时刻被很多倍的请求同时来减库存,减库存又分为“拍下减库存”“付款减库存”以及预扣等几种,在大并发更新的过程中都要保证数据的准确性,其难度可想而知。因此,将用一个节点来专门讲解如何设计秒杀减库存方案。
高可用。 虽然介绍了很多极致的优化思路,但现实中总难免出现一些我们考虑不到的情况,所以要保证系统的高可用和正确性,还要设计一个PlanB来兜底,以便在最坏情况发生时仍然能够从容应对。笔记的最后,将带你思考可以从哪些环节来设计兜底方案。
篇幅有限,无法一个模块一个模块详细的展示(这些要点都收集在了这份《高并发秒杀顶级教程》里),麻烦各位转发一下(可以帮助更多的人看到哟!)
由于内容太多,这里只截取部分的内容。
个节点来专门讲解如何设计秒杀减库存方案。
高可用。 虽然介绍了很多极致的优化思路,但现实中总难免出现一些我们考虑不到的情况,所以要保证系统的高可用和正确性,还要设计一个PlanB来兜底,以便在最坏情况发生时仍然能够从容应对。笔记的最后,将带你思考可以从哪些环节来设计兜底方案。
篇幅有限,无法一个模块一个模块详细的展示(这些要点都收集在了这份《高并发秒杀顶级教程》里),麻烦各位转发一下(可以帮助更多的人看到哟!)
[外链图片转存中…(img-h7W1wrlL-1714315818587)]
[外链图片转存中…(img-eqcvajIl-1714315818588)]
由于内容太多,这里只截取部分的内容。