本周知识清单:
- 开发小tips
- Java基础之集合类
- 一些小感悟
1.开发小tips
看项目代码的时候发现了一些不起眼但觉得蛮实用的小tips,在实习随笔|周记(一)写的tools命名空间就是一点,可帮助快速预览布局展示效果。接下来再提一些小技巧。
a .值得收藏的AS插件 ,另推荐可用Statistic插件统计项目代码总行数、Alibaba Java Coding Guidelines插件帮助规范代码。
b.你不知道的TextUtils用法,比如TextUtils.isDigitsOnly(string)
可检查字符串中是否全是数字。
c.TextView属性大全,比如android:drawableXXX
系列配合android:drawablePadding
适合在文字左侧放固定大小的图片。
d.TextView/string.xml冷门小技巧:占位转换符%1$s
、%2$d
等的用法,其中%1$s
表示第一个字符串、%2$d
表示第二个整数。使用示例如下:
- 在string.xml中先定义好格式:
<string name="instance">String.xml占位转换符:我叫%1$s,今年%2$d岁了,身高%3$f厘米。</string>
- 代码实现:
TextView tv=(TextView)findViewById(R.id.tv);
String format = getResources().getString(R.string.instance);
String result= String.format(format ,"minmin", 21 ,164.5);
tv.setText(result);
- 输出结果:
String.xml占位转换符:我叫minmin,今年21岁了,身高164.5厘米。
2.Java基础之集合类
a.作用:负责保存和盛装其他数据,又称容器类。
- 用于存储数量不等的对象,并可实现常用的数据结构,如栈、队列等
- 用于保存具有映射关系的关联数组
和数组的区别:
- 数组元素可以是基本类型,也可以是对象
- 集合元素只能是对象
b.体系结构:大致可分为Set、List、Queue 和Map四种体系。
- Set:代表无序、不可重复的集合
- List:代表有序、可重复的集合
- Map:代表具有映射关系的集合
- Queue:代表一种队列集合
下图给出Java集合类之间的关系。
c.篇幅有限,主要介绍上图中红色标注的几个类/接口(需要了解源码请点击类名)。
(1)Collection接口:
- 是List、Set和Queue接口的父接口,该接口中定义的方法可操作以上三种集合。
- 常用方法:添加对象
add()
、删除对象remove()
、清空容器clear()
、判断容器是否为空isEmpty()
等。
(2)List系列:有序、可重复
-
ArrayList特点:
- 底层结构是数组,可用索引实现快速查找
- 非线程安全,建议在单线程中才使用ArrayList,而在多线程中可以选择Vector或者CopyOnWriteArrayList
- 是动态数组,相比于数组容量可实现动态增长。默认初始容量为10,每次扩容为原来的1.5倍
-
LinkedList特点:
- 底层结构是链表,增删速度快
- 非线程安全
- 是一个双向循环链表,也可以被当作堆栈、队列或双端队列
- 包含一个非常重要的内部类Entry,是双向链表节点所对应的数据结构,其包括的属性有『当前节点所包含的值』、『上一个节点』、『下一个节点』
-
Vector特点:
- 底层结构是数组,可用索引实现快速查找
- 使用了synchronized关键字,是线程安全的,比ArrayList开销更大,访问更慢
- 默认初始容量为10,默认每次扩容为原来的2倍,可通过capacityIncrement属性设置。
(3)Set系列:无序、不可重复
-
HashSet特点:
- 不能保证元素的排列顺序
- 使用Hash算法来存储集合中的元素,有良好的存取和查找性能
- 非同步,多线程并发要注意线程同问题
- 集合元素值可为null
- 通过
equal()
判断两个元素是否相等,并两个元素的hashCode()
返回值也相等
-
TreeSet特点:
- 是SortedSet接口的实现类,根据元素实际值的大小进行排序
- 采用红黑树的数据结构来存储集合元素
- 非同步
- 支持两种排序方法:自然排序(默认情况)和定制排序。前者通过实现Comparable接口中的
compareTo()
比较两个元素之间大小关系,然后按升序排列;后者通过实现Comparator接口中的compare()
比较两个元素之间大小关系,实现定制排列。
(4)Iterator接口:
- 用于遍历Collection中的集合中的元素,又称迭代器。本身并不提供盛装对象的能力。
- 必须依赖于Collection对象,独立存在无意义。
- 常用方法:判断集合是否还有下一个元素
hasNext()
,可通过remove()
删除集合中上一次next()
返回的集合元素。
(5)Map接口:
- 保存具有映射关系的数据。
- Map集合中保存着两组值,一组用于保存Map中的key,一组用于保存Map中的value。
- key和value可以是任何引用类型的数据。
- key不允许重复,key没有顺序。可以把key集合看成一个Set集合,它们的存储形式、子类命名也非常相似。
- value允许重复,value通过索引查找。可以把value集合看成一个List集合。
- 常用方法:成对添加
put()
和删除remove()
key-value对,获取指定key的valueget()
、判断是否包含指定keycontainsKey()
和指定valuecontainsValue()
等。
(6)Map系列
-
HashMap特点:
- 基于AbstractMap类,实现了Map、Cloneable(能被克隆)、Serializable(支持序列化)接口,
- 无序
- 非线程安全
- 允许存在一个为null的key和任意个为null的value
- 采用链表散列的数据结构,即数组和链表的结合
-
初始容量为16,填充因子默认为0.75,扩容时是当前容量翻倍,即2capacity
-
LinkedHashMap特点:
- 继承自HashMap类
- 有序,默认为插入顺序,还可以是访问顺序
- 非线程安全
- 允许存在一个为null的key和任意个为null的value
- 内部通过Entry维护了一个双向链表,负责维护Map的迭代顺序
-
Hashtable特点:
- 基于Map接口和Dictionary类
- 无序
- 线程安全,开销比HashMap大,如果多线程访问一个Map对象,使用Hashtable更好
- 不允许使用null作为key和value
- 底层基于哈希表结构
- 初始容量为11,填充因子默认为0.75,扩容时是容量翻倍+1,即2capacity+1
-
TreeMap特点:
- 是SortedMap接口的实现类
- 有序,根据key对节点进行排序
- 支持两种排序方法:自然排序和定制排序。前者所有key必须实现Comparable接口且所有key应该是一个类的对象;后者通过传入一个Comparator接口对象负责对多有key进行排序。
- 非线程安全
- 采用红黑树的数据结构
推荐阅读:Java7/8 中的 HashMap 和 ConcurrentHashMap 全解析
3.一些小感悟
最近大家都进入了白热化状态,离项目上线的日子越来越近,重心也从需求开发到纠错改Bug,每个人都变得很谨慎。记得下班最晚的上周五,一大早拿到了测试用例文档之后,要对照着用例的每一条每个点,检查要求是否合理、运行后实际结果是否无误。一度以为要周末加班要继续搞(虽然我也一直是加班学习没闲着...),好在团结力量大,在提测之前的deadline终于大功告成。
那天还有个小插曲,承包了一晚上的笑点,就是可爱的田丰前辈,临提测才发现页面UI不对,就像热锅的蚂蚁一样七上八下,在调试的时候一度抓不上包,自乱阵脚以为出了大bug,就在这时,旁边的杨宇前辈很淡定的把数据线从他的电脑拔出来,场面可以说很欢乐了。
自测之后,在测试用例评审会上见到了QA,之前听闻公司QA是很严格的,不由得肃然起敬。其实这和公司价值观的其中一点『追求卓越』是分不开的,非常注重代码质量,对线上事故也是严肃对待,员工入职的第一天就要研读CaseStudy,看看之前事业群研发曾犯过的错以及开发红线。
导师前阵子请了陪产假,他的开发部分也就由我接手了,这两天组里要进行代码review,于我而言算是个大事,毕竟代码不是自己写的。思来想去,觉得用UML图去刻画类组成和逻辑实现流程最好不过了,突然非常感激大三最后一门课程『信息系统分析与设计』让我对UML爱不释手!(毕竟之前总用PhotoShop...)虽然课上用的是Visio作图,不过个人更推荐ProcessOn,交互设计上更胜一筹。
公司里有这样一句开发者的信仰流传在民间,简直振聋发聩,那就是『要么牛逼,要么滚蛋』,小菜鸟不禁浑身颤抖,所以...共勉吧!