万能的Entry,两个变量的Model/JavaBean再也不用写了!
2016-05-08 00:00
621 查看
摘要: 很多时候传数据需要只含两个变量的Model/JavaBean,但就为了两个变量去写一个Model/JavaBean实在是麻烦,而且类型固定重用性低。而SDK里的几个Entry都不好用,所以我实现了一个Entry<K, V>解决了这个问题。
前言
很多时候传数据需要只含两个变量的Model/JavaBean,但就为了两个变量去写一个Model/JavaBean实在是麻烦,而且类型固定重用性低。比如:
1.网格显示的头像-名称 需要 String-String类型的一个GridBean
2.日期选择器的Item 需要Boolean-String类型的一个GridPickerItemBean
3.Http请求类参数 需要String-Object类型的一个Parameter
。。。
有什么方法可以不用写一大堆这样的自定义Model/JavaBean吗?
用Map<K, V> 或Set<T> ?
很多地方(比如Adapter中的数据列表)都要求序列化,而Map(包括LinkedHashMap) 和 Set(包括LinkedHashSet)都没有get(int index)方法,不能满足需求。
大家知道,List支持序列化,有get(int index)方法,加上Entry<K, V>里面的K, V都是自定义类型,所以用List<Entry<K, V>>既支持序列化,又能储存两个任意类型变量。
用SDK里的Entry?
SDK内提供了3种Entry
DropBoxManager.Entry只有这几种Constructor,明显不能满足需求
KeyStrore.Entry不能存取数据,明显不能满足需求
Map.Entry只有一个构造器,且必须在构造时实现里面几个抽象方法,使用太麻烦,还不能setKey
所以我写了一个Entry<K, V>来解决以上问题。
ZBLibrary万能Entry<K, V> 使用方法
只需要修改Entry<K, V>中的 K 和 V 为任何你需要的类型,其它和普通的Model/JavaBean一样。
以上面3个Model/JavaBean使用场景为例:
先将Entry<K, V>放到工程中,然后
删除GridBean,其它类中的GridBean全部改为Entry<String, String>
删除GridPickerItemBean,其它类中的GridPickerItemBean全部改为Entry<Boolean, String>
删除Parameter,其它类中的Parameter全部改为Entry<String, Object>
如果不想删除原来的Model/JavaBean,还可以通过继承Entry<K, V>来简化原来的Model/JavaBean:
GridBean extends Entry<String, String>
GridPickerItemBean extends Entry<Boolean, String>
Parameter extends Entry<String, Object>
Entry<K, V>下载地址(欢迎Star,欢迎Fork)
https://github.com/TommyLemon/Android-ZBLibrary/blob/master/ZBLibrary(ADT)/ZBLibrary/src/zuo/biao/library/bean/Entry.java
前言
很多时候传数据需要只含两个变量的Model/JavaBean,但就为了两个变量去写一个Model/JavaBean实在是麻烦,而且类型固定重用性低。比如:
1.网格显示的头像-名称 需要 String-String类型的一个GridBean
2.日期选择器的Item 需要Boolean-String类型的一个GridPickerItemBean
3.Http请求类参数 需要String-Object类型的一个Parameter
。。。
有什么方法可以不用写一大堆这样的自定义Model/JavaBean吗?
用Map<K, V> 或Set<T> ?
很多地方(比如Adapter中的数据列表)都要求序列化,而Map(包括LinkedHashMap) 和 Set(包括LinkedHashSet)都没有get(int index)方法,不能满足需求。
大家知道,List支持序列化,有get(int index)方法,加上Entry<K, V>里面的K, V都是自定义类型,所以用List<Entry<K, V>>既支持序列化,又能储存两个任意类型变量。
用SDK里的Entry?
SDK内提供了3种Entry
DropBoxManager.Entry只有这几种Constructor,明显不能满足需求
KeyStrore.Entry不能存取数据,明显不能满足需求
Map.Entry只有一个构造器,且必须在构造时实现里面几个抽象方法,使用太麻烦,还不能setKey
所以我写了一个Entry<K, V>来解决以上问题。
ZBLibrary万能Entry<K, V> 使用方法
只需要修改Entry<K, V>中的 K 和 V 为任何你需要的类型,其它和普通的Model/JavaBean一样。
以上面3个Model/JavaBean使用场景为例:
先将Entry<K, V>放到工程中,然后
删除GridBean,其它类中的GridBean全部改为Entry<String, String>
删除GridPickerItemBean,其它类中的GridPickerItemBean全部改为Entry<Boolean, String>
删除Parameter,其它类中的Parameter全部改为Entry<String, Object>
如果不想删除原来的Model/JavaBean,还可以通过继承Entry<K, V>来简化原来的Model/JavaBean:
GridBean extends Entry<String, String>
GridPickerItemBean extends Entry<Boolean, String>
Parameter extends Entry<String, Object>
Entry<K, V>下载地址(欢迎Star,欢迎Fork)
https://github.com/TommyLemon/Android-ZBLibrary/blob/master/ZBLibrary(ADT)/ZBLibrary/src/zuo/biao/library/bean/Entry.java
相关文章推荐
- 使用C++实现JNI接口需要注意的事项
- Android IPC进程间通讯机制
- Android Manifest 用法
- [转载]Activity中ConfigChanges属性的用法
- Android之获取手机上的图片和视频缩略图thumbnails
- Android之使用Http协议实现文件上传功能
- Android学习笔记(二九):嵌入浏览器
- android string.xml文件中的整型和string型代替
- i-jetty环境搭配与编译
- android之定时器AlarmManager
- android wifi 无线调试
- Android Native 绘图方法
- Android java 与 javascript互访(相互调用)的方法例子
- android 代码实现控件之间的间距
- android FragmentPagerAdapter的“标准”配置
- Android"解决"onTouch和onClick的冲突问题
- android:installLocation简析
- android searchView的关闭事件
- SourceProvider.getJniDirectories