黑马程序员技术交流社区
标题: Collections [打印本页]
作者: 官珺伟 时间: 2014-4-23 08:45
标题: Collections
本帖最后由 官珺伟 于 2014-4-23 21:47 编辑
Collections.reverseOrder();//逆向反转排序。
Collections.shuffle(list);//随机对list中的元素进行位置的置换。
Collections.reverseOrder() 括号里面要加list 吗?
改为Collections.reverseOrder(list);行吗?
reverse(
List<?> list)
反转指定列表中元素的顺序 ,直接上reverse(list); 行吗?
作者: 孙旌棋 时间: 2014-4-23 16:42
本帖最后由 孙旌棋 于 2014-4-23 16:43 编辑
第一个问题: 括号里肯定是不能加list的, Collections.reverseOrder()是返回一个比较器,它强行逆转实现了Comparable 接口的对象 collection 的自然顺序, 比较器是什么我就不多跟你讲了
第二个问题: 反转指定列表中元素的顺序 ,直接上reverse(list); 行吗?答案是必须可以的
同学, 这里给你写了一个小例子, 运行一下就可以看到效果的哦
同时,我还建议你, 遇到似是而非的一定要亲自写代码测试一下
- import java.util.ArrayList;
- import java.util.Collections;
- import java.util.Iterator;
- import java.util.List;
- import java.util.TreeSet;
- public class SunJingQi {
- public static void main(String[] args) {
- List<String> list = new ArrayList<String>();
- list.add("Sun");
- list.add("Jing");
- list.add("Qi");
- // 原来的顺序输出
- for (Iterator<String> it = list.iterator(); it.hasNext();) {
- System.out.println(it.next());
- }
- Collections.reverse(list);// 反转指定列表中元素的顺序
- // 反转后的顺序输出
- for (Iterator<String> it = list.iterator(); it.hasNext();) {
- System.out.println(it.next());
- }
- TreeSet<String> ts = new TreeSet<String>(Collections.reverseOrder());
- ts.add("Sun");
- ts.add("Jing");
- ts.add("Qi");
- /*
- * 同学, 这里最后的结果是 Sun Qi Jing 是不是很疑惑呢?
- * 原因很简单, TreeSet有个默认顺序的就是按照字母的顺序排序
- * 那么原来的顺序就是 Jing Qi Sun
- * Collections.reverseOrder()返回一个比较器,它强行逆转实现了Comparable接口的对象collection 的自然顺序
- * 就是把原来的顺序反过来, 那答案就是 Sun Qi Jing了哦
- * 同学看到这里你明白了吗?
- */
- for (Iterator<String> it = ts.iterator(); it.hasNext();) {
- System.out.println(it.next());
- }
- }
- }
复制代码
| 欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) |
黑马程序员IT技术论坛 X3.2 |