三、Java面向对象-集合排序
2019-07-19 本文已影响0人
Lord丶轩莫言弃
List字符串排序顺序如下:
- 默认按照首字母顺序排序
- 首字母相同的情况下,依次比较第二个、直到第n个字母
排序顺序如下:
- 数字:0~9
- 大写字母:A~Z
- 小写字母:a~z
Comparable和Comparator
- Comparable接口——可比较的
- 实现该接口表示:这个类的实例可以比较大小,可以进行自然排序
- 定义了默认的比较规则
- 其实现类需要实现compareTo()方法
- compareTo()方法返回正数表示大,负数表示小,0表示相等
- Comparator接口——比较工具接口
- 用于定义临时比较规则,而不是默认比较规则
- 其实现类需要实现compare()方法
- Comparator和 Comparable都是Java集合框架成员
二进制位运算
运算符 | 运算 | 示例 |
---|---|---|
& | 与运算 | 6 & 3 = 2 |
| | 或运算 | 6 | 3 = 7 |
^ | 异或运算 | 6 ^ 3 = 5 |
~ | 反码 | ~6 = -7 |
<< | 左移 | 3<<2=12 3x2x2 = 12 |
>> | 右移 | 3>>1 = 1 3/2 = 1 |
>>> | 无符号右移 | 3>>>1 = 1 3/2 = 1 |
- 按位与 &
- 两位全为1,结果才为1
- 按位或 |
- 只要有一个为1,结果就为1
- 异或运算 ^
- 两个相应位为“异”(值不同),则该位结果为1,否则为0
- 取反运算 ~
- 对一个二进制数按位取反,即将0变1,1变0
- 左移运算 <<
- 将一个运算对象的各二进制位全部左移若干位(左边的二进制位全丢弃,右边补0)
- 右移运算 >>
- 将一个数的各二进制位全部右移若干位,正数左补0,负数左补1,右边丢弃。操作数每右移一位,相当于该数除以2。
- 无符号右移运算 >>>
- 各个位向右移指定的位数。右移后左边空出的位用零来填充。移出右边的位被丢弃。