且构网

分享程序员开发的那些事...
且构网 - 分享程序员编程开发的那些事

Collections总结

更新时间:2022-08-18 10:29:24

比较器


package aaa;


import java.util.Comparator;


public class ComparatorByLength implements Comparator<String> {


        public int compare(String o1, String o2) {


                 String s1 = (String) o1;


                 String s2 = (String) o2;


                 int temp = s1.length() - s2.length();


                 return temp == 0 ? s1.compareTo(s2) : temp;


        }


}


package aaa;



import java.util.ArrayList;


import java.util.Collections;


import java.util.Comparator;


import java.util.List;


import java.util.TreeSet;


public class ListDemo {


        public static void main(String[] args) {


                 // TODO Auto-generated method stub


                 demo_1();


                 demo_2();


                 demo_3();


                  Demo4();


        }


        public static void Demo4() {


                 List<String> list = new ArrayList<String>();


                 list.add("abcde");


                 list.add("cba");


                 list.add("zhangsan");


                 list.add("zhaoliu");


                 list.add("xiaoqiang");


                 System.out.println(list);


                 Collections.replaceAll(list, "cba", "NBA");// 原理set(indexOf("cba"),"nba");


                 System.out.println(list);


                 Collections.shuffle(list);//使用指定的随机源对指定列表进行置换。


                 System.out.println(list);


                 Collections.fill(list, "cc");//将list中的所有元素替换冲cc,此方法用做集合的初始化


                 System.out.println(list);


        }


        public static void demo_3() {


                 // 通过比较器实现倒序排列


                 TreeSet<String> ts = new TreeSet<String>(new Comparator<String>() {


                         @Override


                         public int compare(String o1, String o2) {


                                  int temp = o2.compareTo(o1);


                                  return temp;


                         }


                 });


                 ts.add("abc");


                 ts.add("hahaha");


                 ts.add("zzz");


                 ts.add("aa");


                 ts.add("cba");


                 System.out.println(ts);


                 // 利用工具类中的方法实现翻转排序,排序规则按照比较器。


                 TreeSet<String> ts1 = new TreeSet<String>(


                                  Collections.reverseOrder(new ComparatorByLength()));


                 ts1.add("abc");


                 ts1.add("hahaha");


                 ts1.add("zzz");


                 ts1.add("aa");


                 ts1.add("cba");


                 System.out.println(ts1);


        }


        /**


         * 集合工具类排序


         */


        public static void demo_1() {


                 List<String> list = new ArrayList<String>();


                 list.add("abcde");


                 list.add("cba");


                 list.add("aa");


                 list.add("zzz");


                 list.add("cba");


                 list.add("nbaa");


                 System.out.println(list);


                 Collections.sort(list);


                 mySort(list);// Collections.sort(list)实现原理


                 System.out.println(list);


                 Collections.sort(list, new ComparatorByLength());


                 mySort(list, new ComparatorByLength());


                 System.out.println(list);


        }


        public static <T> void mySort(List<T> list, Comparator<? super T> comp) {


                 for (int i = 0; i < list.size() - 1; i++) {


                         for (int j = i + 1; j < list.size(); j++) {


                                  if (comp.compare(list.get(i), list.get(j)) > 0) {


                                           Collections.swap(list, i, j);


                                  }


                         }


                 }


        }


        /**


         * @param list


         *            Collections.sort(list)实现的原理, T extends Comparable<? super


         *            T>的意思是,所有实现Comparable的接口的类型或者父类实现Comparable接口的类型


         */


        public static <T extends Comparable<? super T>> void mySort(List<T> list) {


                 for (int i = 0; i < list.size() - 1; i++) {


                         for (int j = i + 1; j < list.size(); j++) {


                                  if (list.get(i).compareTo(list.get(j)) > 0) {


                                           Collections.swap(list, i, j);// 交换位置


                                  }


                         }


                 }


        }


        public static void demo_2() {


                 List<String> list = new ArrayList<String>();


                 list.add("abcde");


                 list.add("cba");


                 list.add("aa");


                 list.add("zzz");


                 list.add("cba");


                 list.add("nbaa");


                 System.out.println(list);


                 Collections.sort(list);


                 int index = Collections.binarySearch(list, "cba");


                 System.out.println("index=" + index);


                 String max = Collections.max(list, new ComparatorByLength());


                 System.out.println("max=" + max);


        }


}









java.util.Arrays类能方便地操作数组,它提供的所有方法都是静态的。具有以下功能:


给数组赋值:通过fill方法。

对数组排序:通过sort方法,按升序。

比较数组:通过equals方法比较数组中元素值是否相等。

查找数组元素:通过binarySearch方法能对排序好的数组进行二分查找法操作。

import java.util.Arrays;


public class TestArrays {


public static void output(int[] array) {


if (array!=null) {


for (int i = 0; i < array.length; i++) {


System.out.print(array[i]+" ");


}


}


System.out.println();


}


public static void main(String[] args) {


int[] array = new int[5];


//填充数组


Arrays.fill(array, 5);


System.out.println("填充数组:Arrays.fill(array, 5):");


TestArrays.output(array);


//将数组的第2和第3个元素赋值为8


Arrays.fill(array, 2, 4, 8);


System.out.println("将数组的第2和第3个元素赋值为8:Arrays.fill(array, 2, 4, 8):");


TestArrays.output(array);


int[] array1 = {7,8,3,2,12,6,3,5,4};


//对数组的第2个到第6个进行排序进行排序


Arrays.sort(array1,2,7);


System.out.println("对数组的第2个到第6个元素进行排序进行排序:Arrays.sort(array,2,7):");


TestArrays.output(array1);


//对整个数组进行排序


Arrays.sort(array1);


System.out.println("对整个数组进行排序:Arrays.sort(array1):");


TestArrays.output(array1);


//比较数组元素是否相等


System.out.println("比较数组元素是否相等:Arrays.equals(array, array1):"+"\n"+Arrays.equals(array, array1));


int[] array2 = array1.clone();


System.out.println("克隆后数组元素是否相等:Arrays.equals(array1, array2):"+"\n"+Arrays.equals(array1, array2));


//使用二分搜索算法查找指定元素所在的下标(必须是排序好的,否则结果不正确)


Arrays.sort(array1);


System.out.println("元素3在array1中的位置:Arrays.binarySearch(array1, 3):"+"\n"+Arrays.binarySearch(array1, 3));


//如果不存在就返回负数


System.out.println("元素9在array1中的位置:Arrays.binarySearch(array1, 9):"+"\n"+Arrays.binarySearch(array1, 9));


}


}


输出结果:


填充数组:Arrays.fill(array, 5):5 5 5 5 5

将数组的第2和第3个元素赋值为8:Arrays.fill(array, 2, 4, 8):5 5 8 8 5

对数组的第2个到第6个元素进行排序进行排序:Arrays.sort(array,2,7):

7 8 2 3 3 6 12 5 4

对整个数组进行排序:Arrays.sort(array1):2 3 3 4 5 6 7 8 12

比较数组元素是否相等:Arrays.equals(array, array1):

false

克隆后数组元素是否相等:Arrays.equals(array1, array2):true

元素3在array1中的位置:Arrays.binarySearch(array1, 3):1

元素9在array1中的位置:Arrays.binarySearch(array1, 9):-9


将数组转成List集合

package aaa;


import java.util.Arrays;


import java.util.List;


public class ArraysDemo {

  public static void main(String[] args) {

          demo_1();


          demo_2();


  }


  /**


   * Arrays.asList方法将数组转化成List集合


   */


  public static void demo_1()


  {/*


           * 重点:List asList(数组)将数组转成集合。


           * 好处:其实可以使用集合的方法操作数组中的元素。


           * 注意:数组的长度是固定的,所以对于集合的增删方法是不可以使用的


           * 否则会发生UnsupportedOperationException


           */


          String[] arrStrings={"abc","haha","xixi"};


          List<String> list=Arrays.asList(arrStrings);


          boolean b1=list.contains("xixi");


          //list.add("hehe");//UnsupportedOperationException


          System.out.println("list contains="+b1);


  }


  public static void demo_2()


  {

          /*


           * 如果数组中的元素是对象,那么转成集合时,直接将数组中的元素作为集合中的元素进行集合存储。


  * 如果数组中的元素是基本类型数值,那么会将该数组作为集合中的元素进行存储。


           */


          Integer[] arrIntegers={12,32,434,55,67,87};//


          List<Integer> list=Arrays.asList(arrIntegers);


          System.out.println(list);//输出结果:[12, 32, 434, 55, 67, 87]


          int[] arr={31,11,51,61};


          List<int[]> list1=Arrays.asList(arr);


          System.out.println(list1.toString());//输出结果:[[I@154ab8e4]


  }


}


集合转成数组

package aaa;


import java.util.ArrayList;


import java.util.Arrays;


import java.util.List;


public class ToArray {

  public static void main(String[] args) {

          /*


           * 集合转成数组呢?


           * 使用的就是Collection接口中的toArray方法。


           * 集合转成数组:可以对集合中的元素操作的方法进行限定。不允许对其进行增删。


           */


          List<String> list = new ArrayList<String>();


          list.add("abc1");


          list.add("abc2");


          list.add("abc3");


          /*


           * toArray方法需要传入一个指定类型的数组。


           * 长度该如何定义呢?


           * 如果长度小于集合的size,那么该方法会创建一个同类型并和集合相同size的数组。


           * 如果长度大于集合的size,那么该方法就会使用指定的数组,存储集合中的元素,其他位置默认为null。


           * 所以建议,最后长度就指定为,集合的size。


           */


          String[] arrStrings=list.toArray(new String[list.size()]);


          System.out.println(Arrays.toString(arrStrings));//输出结果:[abc1, abc2, abc3]


  }


}



1、格式:


for(类型  变量   :Collection集合|数组)


        {      


        }


等同于C#中的foreach


2、传统for和高级for的区别?


 传统for可以完成对语句执行很多次,因为可以定义控制循环的增量和条件。


高级for是一种简化形式。


它必须有被遍历的目标。该目标要是数组,要么是Collection单列集合。


对数数组的遍历如果仅仅是获取数组中的元素,可以使用高级for。


如果要对数组的角标进行操作建议使用传统for。


package aaa;


import java.util.ArrayList;


import java.util.LinkedHashMap;


import java.util.List;


import java.util.Map;


public class ForEachDemo {


   public static void main(String[] args) {


       List<String> list = new ArrayList<String>();


       list.add("abc1");


       list.add("abc2");


       list.add("abc3");


       for (String s:list) {//简化书写


           System.out.println(s);


       }


       int[] arr={2,3,3,4};


       for (int i :arr) {


           System.out.println(i);


       }


       Map<Integer, String> map=new LinkedHashMap<Integer,String>();


       map.put(3, "zhangsan");


       map.put(2,"wangyi");


       map.put(7,"wangwu");


       map.put(4, "zhangsansan");


       for (Integer key:map.keySet()) {


           String valueString=map.get(key);


           System.out.println(key+"::"+valueString);


       }


       for(Map.Entry<Integer, String> me:map.entrySet())


       {


           Integer keyInteger=me.getKey();


           String valString=me.getValue();


           System.out.println(keyInteger+":"+valString);


       }


   }


}


输出结果:


abc1


abc2


abc3


2


3


3


4


3::zhangsan


2::wangyi


7::wangwu


4::zhangsansan


3:zhangsan


2:wangyi


7:wangwu


4:zhangsansan




package cn.itcast.p4.news.demo;


public class ParamterDemo {

   /**


    * @param args


    */


   public static void main(String[] args) {

            int sum = newAdd(5,1,4,7,3);


            System.out.println("sum="+sum);


            int sum1 = newAdd(5,1,2,7,3,9,8,7,6);


            System.out.println("sum1="+sum1);


   }


   /*


    * 函数的可变参数。


    * 其实就是一个数组,但是接收的是数组的元素。


    * 自动将这些元素封装成数组。简化了调用者的书写。


    * 注意:可变参数类型,必须定义在参数列表的结尾。


    */


   public static int newAdd(int a,int...  arr){

            int sum = 0;


            for (int i = 0; i < arr.length; i++) {

                     sum+=arr[i];


            }


            return sum;


   }



package cn.itcast.p4.news.demo;


import java.util.ArrayList;


import java.util.Collections;


import java.util.List;


import static java.util.Collections.*;//静态导入,其实到入的是类中的静态成员。


import static java.lang.System.*;


public class StaticImportDemo {

   /**


    * @param args


    */


   public static void main(String[] args) {

            List<String> list = new ArrayList<String>();


            list.add("abc3");


            list.add("abc7");


            list.add("abc1");


            out.println(list);


            sort(list);//静态导入之后,就不用写Collections


            System.out.println(list);


            String max = max(list);


            System.out.println("max="+max);


   }


}


输出结果:


[abc1, abc3, abc7]


max=abc7



package aaa;


import java.util.Properties;


import java.util.Set;


public class SystemDemo {

        private static final String LINE_SEPARATOR = System


                         .getProperty("line.separator");// 获取换行符,不同的系统,换行符是不一样的。需要根据属性来获取,要不然可能出现不兼容的现象


        public static void main(String[] args) {

                 // TODO Auto-generated method stub


                 demo_1();


                 demo_2();


        }


        private static void demo_2() {

                 /*


                  * System:类中的方法和属性都是静态的。


                  * 常见方法: long currentTimeMillis();获取当前时间的毫秒值。


                  */


                 long l2 = System.currentTimeMillis();


                 System.out.println(l2);// 输出的结果是当前时间的毫秒值


                 System.out.println("hello-"+LINE_SEPARATOR+" world");//换行


        }


        /**


         * 获取所有的属性


         */


        private static void demo_1() {

                 // 获取系统的属性信息,并存储到了Properties集合中。


                 /*


                  * properties集合中存储都是String类型的键和值。 ***使用它自己的存储和取出的方法来完成元素的操作。


                  */


                 Properties properties = System.getProperties();


                 Set<String> namSet = properties.stringPropertyNames();


                 for (String string : namSet) {

                         String valueString = properties.getProperty(string);


                         System.out.println(string + "::" + valueString);


                 }


        }


}





在java中Runtime类表示运行时操作类,是一个封装了JVM进程的类,每一个JVM都对应着一个Runtime类的实例,此实例由JVM运行时为其实例化。所以在JDK文档中读者不会发现任何有关Runtime类中构造方法的定义,这是因为Runtime类本身的构造方法是私有化的(单例设计),如果想要得到一个Runtime实例,只有以下方法:


Runtime run=Runtime.getRuntime();


也就是说在Runtime类中提供了一个静态的getRuntime()方法,此类可以取得Runtime类的实例,然后通过Runtime就可以取得一些系统的信息。如,getRuntime(),取得Runtime实例;freeMemory()返回java虚拟机中的空闲内存量;maxMemory()返回JVM的最大内存量;gc()运行垃圾回收器,释放空间;exec(command)执行本机命令。


package aaa;


import java.io.IOException;


public class RuntimeDemo {

        public static void main(String[] args) throws IOException,


                         InterruptedException {

                 // TODO Auto-generated method stub


                 Runtime runtime = Runtime.getRuntime();


                 Process p = runtime.exec("notepad.exe");


                 Thread.sleep(5000);


                 p.destroy();// 销毁进程


                 runtime.gc();// 垃圾回收


                 runtime.exec("notepad.exe c:\\RuntimeDemo.java");//用notepad.exe打开RuntimeDemo文件


        }


}



package aaa;


import java.util.Random;


public class MathDemo {

   public static void main(String[] args) {

      // TODO Auto-generated method stub


      /*


       * Math:提供了操作数学运算的方法。都是静态的。


       * 常用的方法:


       * ceil():返回大于参数的最小整数。


       * floor():返回小于参数的最大整数。


       * round():返回四舍五入的整数。


       * pow(a,b):a的b次方。


       */


      double d1 = Math.ceil(12.56);


      double d2 = Math.floor(12.56);


      double d3 = Math.round(12.46);


      sop("d1="+d1);


      sop("d2="+d2);


      sop("d3="+d3);


      double d = Math.pow(10, 2);


       sop("d="+d);


       //第一种  输出1到10 的随机数


       for (int i = 0; i < 10; i++) {

          double d4=(int)(Math.random()*10+1);


          System.out.println(d4);


      }


       //第二种  输出1到10 的随机数


       Random random=new Random();              


       for (int i = 0; i < 10; i++) {

      double d5=(int)(random.nextDouble()*10+1);


      System.out.println(d5);


      int d6=random.nextInt(10)+1;


      System.out.println(d6);


      }


   }


   public static void sop(String string) {

      System.out.println(string);


   }


}



package aaa;


import java.text.DateFormat;


import java.text.ParseException;


import java.text.SimpleDateFormat;


import java.util.Date;


public class DateDemo {

        public static void main(String[] args) throws ParseException {

                 // TODO Auto-generated method stub


                 demo_1();


                 demo_2();


                 demo_3();


        }


        /**


         * 将日期格式的字符串-->日期对象。


         *   使用的是DateFormat类中的parse()方法。


         * @throws ParseException


         */


        private static void demo_3() throws ParseException {

                 // TODO Auto-generated method stub


                 String str_Date = "2015年4月12日";


                 DateFormat dateFormat = DateFormat.getDateInstance(DateFormat.LONG);


                 Date date = dateFormat.parse(str_Date);


                 System.out.println(date);


                 //自定义格式转换为日期对象


                 str_Date="2015---08--12";


                 dateFormat=new SimpleDateFormat("yyyy---MM--dd");


                 date=dateFormat.parse(str_Date);


                 System.out.println(date);


        }


        /**


         * 对日期对象进行格式化。 将日期对象-->日期格式的字符串。 使用的是DateFormat类中的format方法。


         */


        private static void demo_2() {

                 // TODO Auto-generated method stub


                 Date date = new Date();


                 DateFormat dateFormat = DateFormat.getDateInstance(DateFormat.LONG);// 格式化日期


                 System.out.println(dateFormat.format(date));


                 dateFormat = DateFormat.getDateTimeInstance(DateFormat.LONG,


                                  DateFormat.LONG);// 格式化日期和时间


                 System.out.println(dateFormat.format(date));


                 // 自定义风格


                 dateFormat = new SimpleDateFormat("yyyy--MM--dd");


                 String stringDate = dateFormat.format(date);


                 System.out.println(stringDate);


        }


        /**


         * 日期对象和毫秒值之间的转换。


         *


         * 毫秒值-->日期对象 : 1,通过Date对象的构造方法 new Date(timeMillis); 2,还可以通过setTime设置。


         * 因为可以通过Date对象的方法对该日期中的各个字段(年月日等)进行操作。 日期对象-->毫秒值: 2,getTime方法。


         * 因为可以通过具体的数值进行运算。


         */


        private static void demo_1() {

                 Date date = new Date();// 将当前日期和时间封装成Date对象。


                 System.out.println(date);// Sun Apr 29 11:48:02 CST 2012


                 long time = System.currentTimeMillis();


                 Date date1 = new Date(time);


                 System.out.println(date1);


        }


}


练习: "2012-3-17"到"2012-4-6"中间有多少天?


import java.text.DateFormat;


import java.text.ParseException;


import java.text.SimpleDateFormat;


import java.util.Date;


/*


* 思路:两个日期相减就哦了。


* 咋减呢?必须要有两个可以进行减法运算的数。


* 能减可以是毫秒值。如何获取毫秒值?通过date对象。


* 如何获取date对象呢?可以将字符串转成date对象。


* 1,将日期格式的字符串转成Date对象。2,将Date对象转成毫秒值。3,相减,在变成天数


*/


public class DateTest {

        public static void main(String[] args) throws ParseException {

                 String str_date1 = "2012-3-17";


                 String str_date2 = "2012-4-18";


                 test(str_date1,str_date2);


        }


        public static void test(String str_date1,String str_date2) throws ParseException {

                 DateFormat dateFormat = DateFormat.getDateInstance();//定义日期格式对象。


                 dateFormat = new SimpleDateFormat("yyyy-MM-dd");


                 Date date1 = dateFormat.parse(str_date1); //1,将日期字符串转成日期对象。


                 Date date2 = dateFormat.parse(str_date2);


                 long time1 = date1.getTime();


                 long time2 = date2.getTime();


                 long time = Math.abs(time1-time2);


                 int day = getDay(time);


                 System.out.println(day);


        }


        private static int getDay(long time) {

                 int day = (int)(time/1000/60/60/24);


                 return day;


        }


}



从JDK1.1版本开始,在处理日期和时间时,系统推荐使用Calendar类进行实现。在设计上,Calendar类的功能要比Date类强大很多,而且在实现方式上也比Date类要复杂一些,下面就介绍一下Calendar类的使用。


Calendar类是一个抽象类,在实际使用时实现特定的子类的对象,创建对象的过程对程序员来说是透明的,只需要使用getInstance方法创建即可。


1、使用Calendar类代表当前时间


                  Calendar c = Calendar.getInstance();


由于Calendar类是抽象类,且Calendar类的构造方法是protected的,所以无法使用Calendar类的构造方法来创建对象,API中提供了getInstance方法用来创建对象。


使用该方法获得的Calendar对象就代表当前的系统时间,由于Calendar类toString实现的没有Date类那么直观,所以直接输出Calendar类的对象意义不大。


2、使用Calendar类代表指定的时间


                  Calendar c1 = Calendar.getInstance();


                  c1.set(2009, 3 - 1, 9);


使用Calendar类代表特定的时间,需要首先创建一个Calendar的对象,然后再设定该对象中的年月日参数来完成。


set方法的声明为:


        public final void set(int year,int month,int date)


以上示例代码设置的时间为2009年3月9日,其参数的结构和Date类不一样。Calendar类中年份的数值直接书写,月份的值为实际的月份值减1,日期的值就是实际的日期值。


如果只设定某个字段,例如日期的值,则可以使用如下set方法:


        public void set(int field,int value)


在该方法中,参数field代表要设置的字段的类型,常见类型如下:


        Calendar.YEAR——年份


        Calendar.MONTH——月份


        Calendar.DATE——日期


        Calendar.DAY_OF_MONTH——日期,和上面的字段完全相同


        Calendar.HOUR——12小时制的小时数


        Calendar.HOUR_OF_DAY——24小时制的小时数


        Calendar.MINUTE——分钟


        Calendar.SECOND——秒


        Calendar.DAY_OF_WEEK——星期几


后续的参数value代表,设置成的值。例如:


        c1.set(Calendar.DATE,10);


该代码的作用是将c1对象代表的时间中日期设置为10号,其它所有的数值会被重新计算,例如星期几以及对应的相对时间数值等。


3、获得Calendar类中的信息


                  Calendar c2 = Calendar.getInstance();


                  int year = c2.get(Calendar.YEAR); //年份


                  int month = c2.get(Calendar.MONTH) + 1; //月份


                  int date = c2.get(Calendar.DATE); //日期


                  int hour = c2.get(Calendar.HOUR_OF_DAY); //小时


                  int minute = c2.get(Calendar.MINUTE); //分钟


                  int second = c2.get(Calendar.SECOND);   //秒


                  int day = c2.get(Calendar.DAY_OF_WEEK); //星期几


                  System.out.println("年份:" + year);


                  System.out.println("月份:" + month);


                  System.out.println("日期:" + date);


                  System.out.println("小时:" + hour);


                  System.out.println("分钟:" + minute);


                  System.out.println("秒:" + second);


                  System.out.println("星期:" + day);


使用Calendar类中的get方法可以获得Calendar对象中对应的信息,get方法的声明如下:public int get(int field)


其中参数field代表需要获得的字段的值,字段说明和上面的set方法保持一致。需要说明的是,获得的月份为实际的月份值减1,获得的星期的值和Date类不一样。在Calendar类中,周日是1,周一是2,周二是3,依次类推。


4、其它方法说明


其实Calendar类中还提供了很多其它有用的方法,下面简单的介绍几个常见方法的使用。


a、add方法:public abstract void add(int field,int amount)


该方法的作用是在Calendar对象中的某个字段上增加或减少一定的数值,增加是amount的值为正,减少时amount的值为负。


        例如在计算一下当前时间100天以后的日期,代码如下:


                  Calendar c3 = Calendar.getInstance();


                  c3.add(Calendar.DATE, 100);


                  int year1 = c3.get(Calendar.YEAR);


                  int month1 = c3.get(Calendar.MONTH) + 1; //月份


                  int date1 = c3.get(Calendar.DATE); //日期


                  System.out.println(year1 + "年" + month1 + "月" + date1 + "日");


这里add方法是指在c3对象的Calendar.DATE,也就是日期字段上增加100,类内部会重新计算该日期对象中其它各字段的值,从而获得100天以后的日期,例如程序的输出结果可能为: 2009年6月17日


b、after方法:public boolean after(Object when)


该方法的作用是判断当前日期对象是否在when对象的后面,如果在when对象的后面则返回true,否则返回false。例如:


                  Calendar c4 = Calendar.getInstance();


                  c4.set(2009, 10 - 1, 10);


                  Calendar c5 = Calendar.getInstance();


                  c5.set(2010, 10 - 1, 10);


                  boolean b = c5.after(c4);


                  System.out.println(b);


在该示例代码中对象c4代表的时间是2009年10月10号,对象c5代表的时间是2010年10月10号,则对象c5代表的日期在c4代表的日期之后,所以after方法的返回值是true。另外一个类似的方法是before,该方法是判断当前日期对象是否位于另外一个日期对象之前。


                  c、getTime方法:public final Date getTime()


该方法的作用是将Calendar类型的对象转换为对应的Date类对象,两者代表相同的时间点。


类似的方法是setTime,该方法的作用是将Date对象转换为对应的Calendar对象,该方法的声明如下:public final void setTime(Date date)


转换的示例代码如下:


                 Date d = new Date();


                  Calendar c6 = Calendar.getInstance();


                   Date d1 = c6.getTime();     //Calendar类型的对象转换为Date对象


                    Calendar c7 = Calendar.getInstance();


                  c7.setTime(d); //Date类型的对象转换为Calendar对象


        5、Calendar对象和相对时间之间的互转


                           Calendar c8 = Calendar.getInstance();


                           long t = 1252785271098L;


                              long t1 = c8.getTimeInMillis();    //将Calendar对象转换为相对时间


                            Calendar c9 = Calendar.getInstance();


                           c9.setTimeInMillis(t1); //将相对时间转换为Calendar对象


在转换时,使用Calendar类中的getTimeInMillis方法可以将Calendar对象转换为相对时间。在将相对时间转换为Calendar对象时,首先创建一个Calendar对象,然后再使用Calendar类的setTimeInMillis方法设置时间即可。


应用示例


        下面以两个简单的示例介绍时间和日期处理的基本使用。


        1、计算两个日期之间相差的天数


例如计算2010年4月1号和2009年3月11号之间相差的天数,则可以使用时间和日期处理进行计算。


该程序实现的原理为:首先代表两个特定的时间点,这里使用Calendar的对象进行代表,然后将两个时间点转换为对应的相对时间,求两个时间点相对时间的差值,然后除以1天的毫秒数(24小时X60分钟X60秒X1000毫秒)即可获得对应的天数。实现该示例的完整代码如下:


        import java.util.*;


/**


* 计算两个日期之间相差的天数


*/


public class DateExample1 {


        public static void main(String[] args) {


                  //设置两个日期


                      Calendar c1 = Calendar.getInstance();


                   c1.set(2009, 3 - 1, 11); //日期:2009年3月11号


                     Calendar c2 = Calendar.getInstance();


                  c2.set(2010, 4 - 1, 1);    //日期:2010年4月1号


                  //转换为相对时间


                  long t1 = c1.getTimeInMillis();


                  long t2 = c2.getTimeInMillis();


                   long days = (t2 - t1)/(24 * 60 * 60 * 1000); //计算天数


                  System.out.println(days);


        }


}


        2、输出当前月的月历


该示例的功能是输出当前系统时间所在月的日历,例如当前系统时间是2009年3月10日,则输出2009年3月的日历。


该程序实现的原理为:首先获得该月1号是星期几,然后获得该月的天数,最后使用流程控制实现按照日历的格式进行输出即可。即如果1号是星期一,则打印一个单位的空格,如果1号是星期二,则打印两个单位的空格,依次类推。打印完星期六的日期以后,进行换行。实现该示例的完整代码如下:


public class DateExample2{


        public static void main(String[] args){


                  //获得当前时间


                  Calendar c = Calendar.getInstance();


                  c.set(Calendar.DATE,1);   //设置代表的日期为1号


                  int start = c.get(Calendar.DAY_OF_WEEK); //获得1号是星期几


      int maxDay = c.getActualMaximum(Calendar.DATE); //获得当前月的最大日期数


                  //输出标题


           System.out.println("星期日 星期一 星期二 星期三 星期四 星期五   星期六");


                  //输出开始的空格


                  for(int i = 1;i < start;i++){


                           System.out.print("      ");


                  }


                  //输出该月中的所有日期


                  for(int i = 1;i <= maxDay;i++){


                             System.out.print(" " + i);    //输出日期数字


                             System.out.print("     "); //输出分隔空格


                           if(i < 10){System.out.print(' ');}


                           //判断是否换行


                           if((start + i - 1) % 7 == 0){  System.out.println();   }


                  }


                   System.out.println();       //换行


        }      


}


package cn.itcast.p1.otherapi;


import java.util.Calendar;


public class CalendarDemo {


        public static void main(String[] args) {


                 Calendar c = Calendar.getInstance();


                 int year = 2012;


                 showDays(year);


        }


//求二月份有多少天,思路:三月份第一天减一得到二月最后一天的天数


        public static void showDays(int year) {


                 Calendar c = Calendar.getInstance();


                 c.set(year, 2, 1);


                 c.add(Calendar.DAY_OF_MONTH, -1);


                 showDate(c);


        }


//获取Calendar对象的时间属性


        public static void showDate(Calendar c) {


                 int year = c.get(Calendar.YEAR);


                 int month = c.get(Calendar.MONTH)+1;


                 int day = c.get(Calendar.DAY_OF_MONTH);


                 int week = c.get(Calendar.DAY_OF_WEEK);


                 System.out.println(year+"年"+month+"月"+day+"日"+getWeek(week));


        }


        public static String getWeek(int i) {


                 String[] weeks = {"","星期日","星期一","星期二","星期三","星期四","星期五","星期六"};


                 return weeks[i];


        }


}