java集合框架03
Collections工具类的使用
- public class News implements Comparable {
- private int id; //新闻编号
- private String title; //新闻标题
- @Override
- public String toString() {
- return "新闻 [编号=" + id + ", 标题=" + title + "]";
- }
- public News() { //无参构造
- super();
- }
- public News(int id, String title) { //带参构造
- super();
- this.id = id;
- this.title = title;
- }
- public int getId() {
- return id;
- }
- public void setId(int id) {
- this.id = id;
- }
- public String getTitle() {
- return title;
- }
- public void setTitle(String title) {
- this.title = title;
- }
- //重写 排序的规则 升序
- @Override
- public int compareTo(Object o) {
- News news=(News) o;
- if (news.getId()==this.id) {
- return 0;
- }else if (news.getId()<this.id) {
- return 1; // 降序 return -1;
- }else {
- return -1; // 降序 return 1;
- }
- }
- }
创建测试类
- public class CollectionsTest {
- public static void main(String[] args) {
- /*
- * 操作集合的工具类Collections
- *
- */
- //创建一个集合
- List<String> list=new ArrayList<String>();
- list.add("b");
- list.add("d");
- list.add("c");
- list.add("a");
- System.out.println("没有排序====》"+list); //插入时候的顺序
- //对集合进行随机排序
- Collections.shuffle(list);
- //开奖号码 136 顺序必须对 631不对
- System.out.println("随机排序====》"+list);
- //按照字母的升序排列
- Collections.sort(list);
- System.out.println("升序====》"+list);
- //降序 也是必须在升序之后
- Collections.reverse(list);
- System.out.println("降序====》"+list);
- //查询 "b"在集合中的位置 必须先升序 排列之后再查询
- Collections.sort(list);
- System.out.println(Collections.binarySearch(list, "a"));
- System.out.println("****************************");
- List<News> news=new ArrayList<News>(); //想实现对象的排序
- news.add(new News(3, "新闻3"));
- news.add(new News(1, "新闻1"));
- news.add(new News(4, "新闻4"));
- news.add(new News(2, "新闻2"));
- for (News news2 : news) {
- System.out.println(news2);
- }
- /*
- * 如果News没有重写Comparable接口中的compareTo()是编译报错的!
- * 我们必须重写compareTo() 定义规则
- */
- Collections.sort(news);
- System.out.println("对象排序之后.........");
- for (News news2 : news) {
- System.out.println(news2);
- }
- }
- @Test
- public void test1(){
- //通过String类中的split()把字符串转换成字符串数组
- String[] str1="a b c d d d".split(" ");
- //把数组转换成集合
- List<String> asList = Arrays.asList(str1);
- System.out.println(asList);
- String[] str2="c d".split(" ");
- List<String> asList2= Arrays.asList(str2);
- //最后一次出现的位置
- System.out.println(Collections.lastIndexOfSubList(asList, asList2));
- //首次出现的位置
- System.out.println(Collections.indexOfSubList(asList, asList2));
- }
- @Test
- public void test2(){
- String[] str1="a b c d e f".split(" ");
- //把数组转换成集合
- List<String> list = Arrays.asList(str1);
- System.out.println(list);
- //集合中的元素向后移distance个位置,之后被覆盖的元素循环前移
- Collections.rotate(list, 2);
- System.out.println(list);
- }
- }
3.map遍历的效率比较
- @Test
- public void test(){
- Map<String, Object> map=new HashMap<String, Object>();
- for (int i = 0; i <1000000; i++) {
- map.put("key"+i, "value"+i);
- }
- //获取当前毫秒数
- Long a= System.currentTimeMillis();
- //遍历map 首先获取所有key的集合
- Set<String> set = map.keySet();
- for (String key : set) {
- map.get(key); //根据key取得value
- }
- //获取当前毫秒数
- Long b= System.currentTimeMillis();
- System.out.println("使用keySet遍历的时间是:"+(b-a));
- //使用entry遍历 效率最高的
- Set<Entry<String, Object>> entrySet = map.entrySet();
- for (Entry<String, Object> entry : entrySet) {
- entry.getValue();
- }
- //获取当前毫秒数
- Long c= System.currentTimeMillis();
- System.out.println("使用entrySet遍历的时间是:"+(c-b));
- }
汉字的排序
- public class ListTest {
- public static void main(String[] args) {
- //实现都汉字的排序 传入一个语言环境
- Comparator<Object> collator=Collator.getInstance(Locale.CHINA);
- ArrayList<String> list=new ArrayList<String>();
- list.add("你好");
- list.add("好");
- list.add("啊");
- list.add("它好");
- //工具类
- Collections.sort(list, collator);
- for (String string : list) {
- System.out.println(string);
- }
- }
- }
java集合框架03的更多相关文章
- Java 集合框架 03
集合框架·HashSet 和 TreeSet HashSet存储字符串并遍历 * A:Set集合概述及特点 * 通过API查看即可 * 无索引,不可以重复,无序 * B:案例演示 * HashSet存 ...
- java集合框架03——ArrayList和源码分析
最近忙着替公司招人好久没写了,荒废了不好意思. 上一章学习了Collection的架构,并阅读了部分源码,这一章开始,我们将对Collection的具体实现进行详细学习.首先学习List.而Array ...
- Java集合框架面试题
www.cnblogs.com/zhxxcq/archive/2012/03/11/2389611.html 这里的两个图很形象,由于放进图片链接,图片显示不了,所以只能给出该链接. Java集合框架 ...
- Java 集合系列 03 ArrayList详细介绍(源码解析)和使用示例
java 集合系列目录: Java 集合系列 01 总体框架 Java 集合系列 02 Collection架构 Java 集合系列 03 ArrayList详细介绍(源码解析)和使用示例 Java ...
- Java集合框架的知识总结(1)
说明:先从整体介绍了Java集合框架包含的接口和类,然后总结了集合框架中的一些基本知识和关键点,并结合实例进行简单分析. 1.综述 所有集合类都位于java.util包下.集合中只能保存对象(保存对象 ...
- Java集合框架的知识总结
说明:面试准备,写的挺不错的. 转载地址: http://www.cnblogs.com/zhxxcq/archive/2012/03/11/2389611.html 1.综述 所有集合类都位于jav ...
- Java集合框架Collection
转自:http://www.cdtarena.com/javapx/201306/8891.html [plain] view plaincopyprint?01.在 Java2中,有一套设计优良的接 ...
- Java集合框架之四大接口、常用实现类
Java集合框架 <Java集合框架的四大接口> Collection:存储无序的.不唯一的数据:其下有List和Set两大接口. List:存储有序的.不唯一的数据: Set:存储无序的 ...
- 【转载】Java 集合框架
http://wangkuiwu.github.io/2012/02/03/collection-03-arraylist/ 网上比较全的Java集合框架教程. 注:transient是Java语言的 ...
随机推荐
- QQ情侣头像~
- Windows Phone 使用 WriteableBitmap后台生成图片
这几天项目是遇到一个需求,需要后台把几个元素生成到一张图片上,并保存到文件中 private void cutscreen_Click(object sender, EventArgs e) { Gr ...
- Java学习----设计正真的应用程序
import java.util.Scanner; // 输入10位学生的成绩,并且判断他们的成绩是哪个等级,其中90-100是A级,80-89是B级,70-79是C级,60-69是D级,60分以下E ...
- 获取fragment中的控件的写法
package com.example.baoxiu.fragment;import com.example.baoxiu.R;import com.example.baoxiu.Register;i ...
- 使用wrapper将java程序注册程windows服务后不生效
使用wrapper将java程序注册程windows服务后不生效 使用add.bat或test***.bat测试通过了, 然后使用install***.bat注册后cmd显示注册成功. 但是程序到了运 ...
- JS 日常
判断一个字符串是否在另一个字符串里面 var str = 'bblText'; if(str.indexOf("Text") > 0) alert("包含了Tex ...
- Java对象引用
1.对象的强.软.弱和虚引用 在JDK 1.2以前的版本中,若一个对象不被任何变量引用,那么程序就无法再使用这个对象.也就是说,只有对象处于可触及(reachable)状态,程序才能使用它.从JDK ...
- Fedora 19+ 启动顺序调整
首先找到Windows 8的menuentry cat /boot/grub2/grub.cfg | grep Windows 设置Windows 作为默认的启动项 grub2-set-default ...
- UOJ 218 火车管理
http://uoj.ac/problem/218 思路:建立一个可持久化线段树,代表这个位置的火车是哪辆,然后再弄一个线段树维护答案. 如果询问,直接询问线段树. 如果区间压入,直接在主席树上面压入 ...
- 学习Cassandra资料的一些整理
Cassandra note: 依赖:需要java 8 (http://www.oracle.com/technetwork/java/javase/downloads/index.html) 数据模 ...