现在代码的水平还是比较的低,对于函数保持的观点是:
1,尽量的短小,3到5行。
2,最好干一件事情。
3,返回值void最好。
这里就说返回值,我一般还是void,除了get。
参考一下ArrayList的实现:
1, add(E):boolean【来自Collection的方法,感觉一直返回true】
2, add(int, E):void【我一般void】
3, addAll(int, Collection<? extends E>):boolean【来自Collection的方法,感觉一直返回true】
4, addAll(Collection<? extends E>):boolean【来自Collection的方法,感觉一直返回true】
5, clear():void【我一般void】
6, clone():Object【Object方法】
7, contains(Object):boolean
8, ensureCapacity(int):void
9, fastRemove(int):void【我的一些方法也可以学习这种提供fast的方法,忽略check和返回值。常常有一些方法运行前要check,方法行数太多】
10,get(int):E
11,indexOf(Object):int
12,isEmpty():boolean
13,lastIndexOf(Object):int
14,RangeCheck(int):void【抛出异常】
15,readObject(ObjectInputStream):void
16,remove(int):E【返回的是被删除位置的对象】
17,remove(Object):boolean
18,removeRange(int, int):void
19,set(int, E):E【返回的是这个位置的本来对象】
20,size():int
21,toArray():Object[]
22,toArray(T[]):T[]
23,trimToSize():void【最小化数组,List中的元素是存在数组中的,每次申请的空间,首选本来空间的1.5倍加1,要是不够就用需要的空间。通常有多的。】
24,writeObject(ObjectOutputStream):void
比较好理解的是:contains(Object):boolean,get(int):E,indexOf(Object):int,isEmpty():boolean,lastIndexOf(Object):int,
size():int。
总结:
1,访问数组下标,大于数组长度。报IndexOutOfBoundsException。
2,访问数组下标是负数。报ArrayIndexOutOfBoundsException。