美团实习| 周记(二)

本周知识清单:

  • 开发小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


      HashMap与HashSet对比
  • 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,交互设计上更胜一筹。

公司里有这样一句开发者的信仰流传在民间,简直振聋发聩,那就是『要么牛逼,要么滚蛋』,小菜鸟不禁浑身颤抖,所以...共勉吧!

随手一拍的工作大楼
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,686评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,668评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,160评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,736评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,847评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,043评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,129评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,872评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,318评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,645评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,777评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,861评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,589评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,687评论 2 351

推荐阅读更多精彩内容