第5、8、9章 Java复习

本文详细介绍了Java中的异常处理机制,包括异常的分类、如何使用try-catch-finally处理异常,以及自定义异常。此外,文章还深入探讨了Java中的字符串特性,如不变性和常用方法,并对比了String与StringBuilder的区别。最后,文章提到了Java中包装类、基本类型与字符串之间的转换,以及Date、SimpleDateFormat和Calendar类在处理日期时间上的应用。
摘要由CSDN通过智能技术生成

目录

第1章 异常与异常处理

1-1 Java异常简介

1-2 Java中使用try-catch-finally实现异常处理

1-3 Java中通过案例学习 try-catch-finally

 1-4 Java中的异常抛出以及自定义异常

1-5 Java中的异常链 

1-6 经验总结

第2章 认识Java中的字符串

2-1什么是 Java 中的字符串 

2-2 Java 中字符串的不变性 

 2-3 Java 中 String 类的常用方法1

2-4 Java 中的 String 类常用方法2

 2-5 认识 Java 中的 StringBuilder 类

2-6 Java 中的 StringBuilder 类的常用方法

第3章 Java 中必须了解的常用类

3-1 Java 中的包装类

3-2 Java中基本类型和包装类之间的转换

3-3 Java中基本类型和字符串之间的转换

3-4 使用 Date 和 SimpleDateFormat 类表示时间 

3-5 Calendar 类的应用

3-6 使用 Math 类操作数据


第1章 异常与异常处理

1-1 Java异常简介

        Java异常是Java提供的一种识别及响应错误的一致性机制。
  Java异常机制可以使程序中异常处理代码和正常业务代码分离,保证程序代码更加优雅,并提高程序健壮性。在有效使用异常的情况下,异常能清晰的回答what, where, why这3个问题:异常类型回答了“什么”被抛出,异常堆栈跟踪回答了“在哪“抛出,异常信息回答了“为什么“会抛出。

1.Throwable
  Throwable是 Java 语言中所有错误或异常的超类。
  Throwable包含两个子类: Error 和 Exception。它们通常用于指示发生了异常情况。
  Throwable包含了其线程创建时线程执行堆栈的快照,它提供了printStackTrace()等接口用于获取堆栈跟踪数据等信息。

2. Exception
  Exception及其子类是 Throwable 的一种形式,它指出了合理的应用程序想要捕获的条件。

3. RuntimeException
  RuntimeException是那些可能在 Java 虚拟机正常运行期间抛出的异常的超类。
  编译器不会检查RuntimeException异常。例如,除数为零时,抛出ArithmeticException异常。RuntimeException是ArithmeticException的超类。当代码发生除数为零的情况时,倘若既"没有通过throws声明抛出ArithmeticException异常",也"没有通过try...catch...处理该异常",也能通过编译。这就是我们所说的"编译器不会检查RuntimeException异常"!
  如果代码会产生RuntimeException异常,则需要通过修改代码进行避免。例如,若会发生除数为零的情况,则需要通过代码避免该情况的发生!

4. Error
  和Exception一样,Error也是Throwable的子类。它用于指示合理的应用程序不应该试图捕获的严重问题,大多数这样的错误都是异常条件。
  和RuntimeException一样,编译器也不会检查Error。

        Java将可抛出(Throwable)的结构分为三种类型:被检查的异常(Checked Exception),运行时异常(RuntimeException)和错误(Error)。 

1-2 Java中使用try-catch-finally实现异常处理

 try   用于监听。将要被监听的代码(可能抛出异常的代码)放在try语句块之内,当try语句块内发生异常时,异常就被抛出。 

catch  用于捕获异常。catch用来捕获try语句块中发生的异常。

finally finally语句块总是会被执行。它主要用于回收在try块里打开的物力资源(如数据库连接、网络连接和磁盘文件)。只有finally块,执行完成之后,才会回来执行try或者catch块中的return或者throw语句,如果finally中使用了return或者throw等终止方法的语句,则就不会跳回执行,直接停止。 

使用 try-catch-finally 语句时需注意以下几点:

1.异常处理语法结构中只有 try 块是必需的,也就是说,如果没有 try 块,则不能有后面的 catch 块和 finally 块;

2.catch 块和 finally 块都是可选的,但 catch 块和 finally 块至少出现其中之一,也可以同时出现;

3.可以有多个 catch 块,捕获父类异常的 catch 块必须位于捕获子类异常的后面;

4.不能只有 try 块,既没有 catch 块,也没有 finally 块;

5.多个 catch 块必须位于 try 块之后,finally 块必须位于所有的 catch 块之后。

6.finally 与 try 语句块匹配的语法格式,此种情况会导致异常丢失,所以不常见。

一般情况下,无论是否有异常拋出,都会执行 finally 语句块中的语句,执行流程如图所示。 

try catch finally 语句块的执行情况可以细分为以下 3 种情况:

1.如果 try 代码块中没有拋出异常,则执行完 try 代码块之后直接执行 finally 代码块,然后执行 try catch finally 语句块之后的语句。

2.如果 try 代码块中拋出异常,并被 catch 子句捕捉,那么在拋出异常的地方终止 try 代码块的执行,转而执行相匹配的 catch 代码块,之后执行 finally 代码块。如果 finally 代码块中没有拋出异常,则继续执行 try catch finally 语句块之后的语句;如果 finally 代码块中拋出异常,则把该异常传递给该方法的调用者。

3.如果 try 代码块中拋出的异常没有被任何 catch 子句捕捉到,那么将直接执行 finally 代码块中的语句,并把该异常传递给该方法的调用者。

1-3 Java中通过案例学习 try-catch-finally

try-catch以及try-catch-finally
try{
//一些会抛出的异常
}catch(Exception e){
//处理该异常的代码块
}finally{
//最终要执行的代码
public class TryCatchTest {
            public static void main(String[] args) {
                // TODO Auto-generated method stub
                TryCatchTest tct=new TryCatchTest();
                //	int result=tct.test();
                //System.out.println("test()方法,执行完毕!返回值为:"+result);
                //int result2=tct.test2();
                int result=tct.test3();
                System.out.println("我想大声告诉你!test3()执行完毕!!~返回值为"+result);
            }
            /*
             * divide(除数):
             * result(结果):
             * try-catch捕获while循环
             * 每一次循环,divide减一,result=result+100/divider
             * 如果:捕获异常,打印输出"抛出异常了!!!",返回-1
             * 否则:返回result
             */
            public int test() {
                int divider=10;
                int result=100;
                try {
                    while(divider>-1) {
                        divider--;
                        result=result+100/divider;
                    }
                    return result;
                }catch(Exception e) {
                    e.printStackTrace();
                    System.out.println("循环抛出异常了!!!");
                    return result=999;
                }finally {
                    System.out.println("这是finally!!哈哈!!");
                    System.out.println("test()方法,执行完毕!返回值为:"+result);
                }
            }
            /*
             * divide(除数):
             * result(结果):
             * try-catch捕获while循环
             * 每一次循环,divide减一,result=result+100/divider
             * 如果:捕获异常,打印输出"抛出异常了!!!",返回-1
             * 否则:返回result
             * finally:打印输出"这是finally!!!哈哈!!",同时打印result的值
             */
            public int test2() {
                int divider=10;
                int result=100;
                try {
                    while(divider>-1) {
                        divider--;
                        result=result+100/divider;
                    }return result;
                }catch(Exception e) {
                    e.printStackTrace();
                    System.out.println("循环抛出异常了!!!");
                    return result=999;
                }finally {
                    System.out.println("这是finally!!哈哈!!");
                    System.out.println("我的Result!!!我的值是:"+result);
                }
            }
            /*
             * divide(除数):
             * result(结果):
             * try-catch捕获while循环
             * 每一次循环,divide减一,result=result+100/divider
             * 如果:捕获异常,打印输出"抛出异常了!!!",返回-1
             * 否则:返回result
             * finally:打印输出"这是finally!!!哈哈!!",同时打印result的值
             */
            public int test3() {
                int divider=10;
                int result=100;
                try {
                    while(divider>-1) {
                        divider--;
                        result=result+100/divider;
                    }
                }catch(Exception e) {
                    e.printStackTrace();
                    System.out.println("循环抛出异常了!!!");
                    return result=999;
                }finally {
                    System.out.println("这是finally!!哈哈!!");
                    System.out.println("我的Result!!!我的值是:"+result);
                }
                System.out.println("我是test3!我运行完了!表想我!!!~");
                return 1111;
    }
}

 1-4 Java中的异常抛出以及自定义异常

一、异常的抛出

1、定义 : 一个方法不处理这个异常,而是调用层次向上传递,谁调用这个方法,这个异常就由谁来处理。

2、throw : 将产生的异常抛出(强调的是动作),抛出的既可以是异常的引用,也可以是异常对象。(位置: 方法体内)

3、throws : 如果一个方法可能会出现异常,但没有能力处理这种异常,可以在方法声明处用throws子句来声明抛出异常。用它修饰的方法向调用者表明该方法可能会抛出异常(可以是一种类型,也可以是多种类型,用逗号隔开)(位置: 写在方法名 或方法名列表之后 ,在方法体之前。)

注意 : 调用可能会抛出异常的方法,必须添加try-catch代码块尝试去捕获异常 或者 添加throws 声明 来将异常 抛出给更上一层的调用者进行处理,这里需要注意一个细节:新的异常包含原始异常的所有信息,根据这个我们可以去追溯最初异常发生的位置。

二、自定义异常
        自定义test1()方法,抛出 "我喝酒了"的异常信息,test2()方法调用test1()方法,并将异常包装成RuntimeException类型的异常,继续抛出,在main方法中调用test2()方法,并尝试捕获异常。

        使用Java内置的异常类可以描述在编程时出现的大部分异常情况。除此之外,用户还可以自定义异常。用户自定义异常,只需继承Exception类即可。
在程序中使用自定义异常类,大体可分为以下几个步骤:
1.创建自定义异常类
2.在方法中通过throw关键字抛出异常对象
3.如果在当前抛出异常的方法中处理异常,可以使用try-catch语句捕获并处理                                4.处通过throws 关键字要指明抛出给方法调用者的异常,继续进行下一步操作。
5.在出现异常方法的调用者中捕获并处理异常。

class 自定义异常类 extends 异常类型{
}

1-5 Java中的异常链 

异常链:有时候我们会捕获一个异常后再抛出另一个异常
顾名思义就是将异常发生的原因一个传一个串起来,即把底层的异常信息传给上层,这样逐层抛出。

public class ChainTest {
/*
 * test1():抛出“喝大了”异常
 * test2():调用test1(),“喝大了”异常,并且包换成运行时异常,
 * mian方法中,调用test2(),尝试捕获test2()方法抛出的异常
 */
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		ChainTest ct=new ChainTest();
		try {
			ct.test2();
		}catch(Exception e){
			e.printStackTrace();
		}
	}
	public void test1() throws DrunkException{
		throw new DrunkException("喝车别开酒");
	}
	public void test2() {
		try {
		test1();
	}catch(DrunkException e) {
		RuntimeException newExc=new RuntimeException("司机一滴酒,亲人两行泪~~");
		newExc.initCause(e);
		throw newExc;
	    }
    }
}

1-6 经验总结

第2章 认识Java中的字符串

2-1什么是 Java 中的字符串 

在程序开发中字符串无处不在,如用户登陆时输入的用户名、密码等使用的就是字符串。其实,在前面的章节中我们就已经使用了字符串,例如我们在控制台中输出的 "Hello World" 、 "imooc" 、"爱慕课"等。

在 Java 中,字符串被作为 String 类型的对象处理。 String 类位于 java.lang 包中。默认情况下,该包被自动导入所有的程序。

创建 String 对象的方法:

public class HelloWorld {
    public static void main(String[] args) {
        //定义字符串
	    String hobby =  "爱慕课";        
		String url = "www.imooc.com";         
		System.out.println("hobby:" +  hobby );//输出字符串
		System.out.println("url:" + url);	//输出字符串
	}
}

2-2 Java 中字符串的不变性 

        String 对象创建后则不能被修改,是不可变的,所谓的修改其实是创建了新的对象,所指向的内存空间不同。如下所示:

运行结果:

结合上面的代码,关于字符串必须需要了解:

1、 通过 String s1="爱慕课"; 声明了一个字符串对象, s1 存放了到字符串对象的引用,在内存中的存放引用关系如下图所示:

然后通过 s1="欢迎来到:"+s1; 改变了字符串 s1 ,其实质是创建了新的字符串对象,变量 s1 指向了新创建的字符串对象,如下图所示:

2、 一旦一个字符串在内存中创建,则这个字符串将不可改变。如果需要一个可以改变的字符串,我们可以使用StringBuffer或者StringBuilder(后面章节中会讲到)。

3、 每次 new 一个字符串就是产生一个新的对象,即便两个字符串的内容相同,使用 ”==” 比较时也为 ”false” ,如果只需比较内容是否相同,应使用 ”equals()” 方法

public class HelloWorld {
    public static void main(String[] args) {
    	String s1 = "imooc";
		String s2 = "imooc";
        //定义字符串s3,保存“I love”和s1拼接后的内容
		String s3 = "I love" + s1; 
        // 比较字符串s1和s2
		// imooc为常量字符串,多次出现时会被编译器优化,只创建一个对象
		System.out.println("s1和s2内存地址相同吗?" + (s1 == s2));
        //比较字符串s1和s3
		System.out.println("s1和s3内存地址相同吗?" + (s1 == s3));
		String s4 = "I love " + s1;
         //比较字符串s4和s3
		// s1是变量,s4在运行时才知道具体值,所以s3和s4是不同的对象
		System.out.println("s3和s4内存地址相同吗?" + (s4 == s3));
	}
}

 2-3 Java 中 String 类的常用方法1

        String 类提供了许多用来处理字符串的方法,例如,获取字符串长度、对字符串进行截取、将字符串转换为大写或小写、字符串分割等,下面我们就来领略它的强大之处吧。

String 类的常用方法:

结合代码来熟悉一下方法的使用:

运行结果:

注意:

1. 字符串 str 中字符的索引从0开始,范围为 0 到 str.length()-1

2. 使用 indexOf 进行字符或字符串查找时,如果匹配返回位置索引;如果没有匹配结果,返回 -1

3. 使用 substring(beginIndex , endIndex) 进行字符串截取时,包括 beginIndex 位置的字符,不包括 endIndex 位置的字符。

public class HelloWorld {
    public static void main(String[] args) {
		String fileName = "HelloWorld.java"; 
		String email = "laurenyang@imooc.com";
		int index =fileName.lastIndexOf(".");
		String prefix =fileName.substring(index);
	if (index > 0 && (prefix.equals (".java"))){
			System.out.println("Java文件名正确");
		} else {
			System.out.println("Java文件名无效");
		}
		int index2 = email.indexOf('@');
		int index3 = email.indexOf('.');
		if (index2 != -1 && index3 > index2) {
			System.out.println("邮箱格式正确");
		} else {
			System.out.println("邮箱格式无效");
		}
	}
}

2-4 Java 中的 String 类常用方法2

我们继续来看 String 类常用的方法,如下代码所示:

运行结果:

那么,“==” 和 equals() 有什么区别呢?

==: 判断两个字符串在内存中首地址是否相同,即判断是否是同一个字符串对象

equals(): 比较存储在两个字符串对象中的内容是否一致

注意:字节是计算机存储信息的基本单位,1 个字节等于 8 位, gbk 编码中 1 个汉字字符存储需要 2 个字节,1 个英文字符存储需要 1 个字节。所以我们看到上面的程序运行结果中,每个汉字对应两个字节值,如“学”对应 “-47 -89” ,而英文字母 “J” 对应 “74” 。同时,我们还发现汉字对应的字节值为负数,原因在于每个字节是 8 位,最大值不能超过 127,而汉字转换为字节后超过 127,如果超过就会溢出,以负数的形式显示。

public class HelloWorld {
    public static void main(String[] args) {
		// 定义一个字符串
		String s = "aljlkdsflkjsadjfklhasdkjlflkajdflwoiudsafhaasdasd";
        // 出现次数
		int num = 0;
         // 循环遍历每个字符,判断是否是字符 a ,如果是,累加次数
		for (byte bt:(s.getBytes()))
		{
            // 获取每个字符,判断是否是字符a
			if (bt == 'a') {
                // 累加统计次数
				num++; 
			}
		}
		System.out.println("字符a出现的次数:" + num);
	}
}

 

 2-5 认识 Java 中的 StringBuilder 类

        在Java中,除了可以使用 String 类来存储字符串,还可以使用 StringBuilder 类或 StringBuffer 类存储字符串,那么它们之间有什么区别呢?

String 类具有是不可变性。如

运行结果:  

        从运行结果中我们可以看到,程序运行时会额外创建一个对象,保存 "helloworld"。当频繁操作字符串时,就会额外产生很多临时变量。使用 StringBuilder 或 StringBuffer 就可以避免这个问题。至于 StringBuilder 和StringBuffer ,它们基本相似,不同之处,StringBuffer 是线程安全的,而 StringBuilder 则没有实现线程安全功能,所以性能略高。因此一般情况下,如果需要创建一个内容可变的字符串对象,应优先考虑使用 StringBuilder 类。

那么如何定义 StringBuilder 类的对象呢? 我们来看下面的代码:

运行结果: imooc  

public class HelloWorld {
    public static void main(String[] args) {
       // 创建一个StringBuilder对象,用来存储字符串
		StringBuilder hobby=new StringBuilder("爱慕课");
		System.out.println(hobby);
	}
}

2-6 Java 中的 StringBuilder 类的常用方法

StringBuilder 类提供了很多方法来操作字符串:

例如:在下面的示例代码中,创建了 StringBuilder 对象,用来存储字符串,并对其做了追加和插入操作。这些操作修改了 str 对象的值,而没有创建新的对象,这就是 StringBuilder 和 String 最大的区别。

运行结果: 

public class HelloWorld {
    public static void main(String[] args) {
	StringBuilder str = new StringBuilder();
		// 追加字符串
		str.append("jaewkjldfxmopzdm");
        // 从后往前每隔三位插入逗号
		for(int i = str.length()-3; i >=0 ; i=i-3){
    	 str.insert(i,",");   
		}
        // 将StringBuilder对象转换为String对象并输出
		System.out.print(str.toString());
	}
}

第3章 Java 中必须了解的常用类

3-1 Java 中的包装类

        相信各位小伙伴们对基本数据类型都非常熟悉,例如 int、float、double、boolean、char 等。基本数据类型是不具备对象的特性的,比如基本类型不能调用方法、功能简单。。。,为了让基本数据类型也具备对象的特性, Java 为每个基本数据类型都提供了一个包装类,这样我们就可以像操作对象那样来操作基本数据类型。 

基本类型和包装类之间的对应关系:

包装类主要提供了两大类方法:

1. 将本类型和其他基本类型进行转换的方法

2. 将字符串和本类型及包装类互相转换的方法

public class HelloWorld {
    public static void main(String[] args) {
      int score1 = 86; 
		// 创建Integer包装类对象,表示变量score1的值
		Integer score2=new Integer(score1);
		// 将Integer包装类转换为double类型
		double score3=score2.doubleValue();
		// 将Integer包装类转换为float类型
		float score4=score2.floatValue();
		// 将Integer包装类转换为int类型
		int score5 =score2.intValue();
		System.out.println("Integer包装类:" + score2);
		System.out.println("double类型:" + score3);
		System.out.println("float类型:" + score4);
		System.out.println("int类型:" + score5);
	}
}

 

3-2 Java中基本类型和包装类之间的转换

        基本类型和包装类之间经常需要互相转换,以 Integer 为例(其他几个包装类的操作雷同哦):

        在 JDK1.5 引入自动装箱和拆箱的机制后,包装类和基本类型之间的转换就更加轻松便利了。

那什么是装箱和拆箱呢?我们分别来看下

装箱:把基本类型转换成包装类,使其具有对象的性质,又可分为手动装箱和自动装箱

拆箱:和装箱相反,把包装类对象转换成基本类型的值,又可分为手动拆箱和自动拆箱

public class HelloWorld {
    public static void main(String[] args) {
        	double a = 91.5;
         // 手动装箱
		Double b =    new Double(a);
        // 自动装箱
		Double c = a;      
        System.out.println("装箱后的结果为:" + b + "和" + c);
        // 定义一个Double包装类对象,值为8
		Double d = new Double(87.0);
        // 手动拆箱
		double e =   d.doubleValue(); 
        // 自动拆箱
		double f =   d;
         System.out.println("拆箱后的结果为:" + e + "和" + f);
	}
}

3-3 Java中基本类型和字符串之间的转换

        在程序开发中,我们经常需要在基本数据类型和字符串之间进行转换。

其中,基本类型转换为字符串有三种方法:

1. 使用包装类的 toString() 方法

2. 使用String类的 valueOf() 方法

3. 用一个空字符串加上基本类型,得到的就是基本类型数据对应的字符串

再来看,将字符串转换成基本类型有两种方法:

1. 调用包装类的 parseXxx 静态方法

2. 调用包装类的 valueOf() 方法转换为基本类型的包装类,会自动拆箱

public class HelloWorld {
    public static void main(String[] args) {
        double m = 78.5;
		//将基本类型转换为字符串
		String str1 = String.valueOf(m);       
       //String str1 = String.toString(m); 
		System.out.println("m 转换为String型后与整数20的求和结果为: "+(str1+20));
		String str = "180.20";
	    // 将字符串转换为基本类型
		Double a =  Double.valueOf(str);
        //Double a = Double.parseDouble(str);
		System.out.println("str 转换为double型后与整数20的求和结果为: "+(a+20));
	}
}

3-4 使用 Date 和 SimpleDateFormat 类表示时间 

        在程序开发中,经常需要处理日期和时间的相关数据,此时我们可以使用 java.util 包中的 Date 类。这个类最主要的作用就是获取当前时间,我们来看下 Date 类的使用:

        使用 Date 类的默认无参构造方法创建出的对象就代表当前时间,我们可以直接输出 Date 对象显示当前的时间,显示的结果如下:

        其中, Wed 代表 Wednesday (星期三), Jun 代表 June (六月), 11 代表 11 号, CST 代表 China Standard Time (中国标准时间,也就是北京时间,东八区)。

        从上面的输出结果中,我们发现,默认的时间格式不是很友好,与我们日常看到的日期格式不太一样,如果想要按指定的格式进行显示,如 2014-06-11 09:22:30 ,那该怎么做呢?

        此时就到了 java.text 包中的 SimpleDateFormat 类大显身手的时候了!!可以使用 SimpleDateFormat 来对日期时间进行格式化,如可以将日期转换为指定格式的文本,也可将文本转换为日期。

1. 使用 format() 方法将日期转换为指定格式的文本

        代码中的 “yyyy-MM-dd HH:mm:ss” 为预定义字符串, yyyy 表示四位年, MM 表示两位月份, dd 表示两位日期, HH 表示小时(使用24小时制), mm 表示分钟, ss 表示秒,这样就指定了转换的目标格式,最后调用 format() 方法将时间转换为指定的格式的字符串。

运行结果: 2014-06-11  09:55:48   

2. 使用 parse() 方法将文本转换为日期

        代码中的 “yyyy年MM月dd日 HH:mm:ss” 指定了字符串的日期格式,调用 parse() 方法将文本转换为日期。

运行结果: 

注意:1、 调用 SimpleDateFormat 对象的 parse() 方法时可能会出现转换异常,即 ParseException ,因此需要进行异常处理

2、 使用 Date 类时需要导入 java.util 包,使用 SimpleDateFormat 时需要导入 java.text 包

import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
public class HelloWorld {
    public static void main(String[] args) throws ParseException {
       	SimpleDateFormat sdf1 = new SimpleDateFormat("yyyy年MM月dd日 HH时mm分ss秒");
		SimpleDateFormat sdf2 = new SimpleDateFormat("yyyy/MM/dd HH:mm");
		SimpleDateFormat sdf3 = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
		// 创建Date对象,表示当前时间
        Date now=new Date();
        // 调用format()方法,将日期转换为字符串并输出
		System.out.println(sdf1.format(now));
		System.out.println(sdf2.format(now));
		System.out.println(sdf3.format(now));
		// 使用parse()方法将文本转换为日期
		String d = "2014-6-1 21:05:36";
		SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
         // 调用parse()方法,将字符串转换为日期
		Date date =sdf.parse(d);
		System.out.println(date);
	}
}

3-5 Calendar 类的应用

        Date 类最主要的作用就是获得当前时间,同时这个类里面也具有设置时间以及一些其他的功能,但是由于本身设计的问题,这些方法却遭到众多批评,不建议使用,更推荐使用 Calendar 类进行时间和日期的处理。

        java.util.Calendar 类是一个抽象类,可以通过调用 getInstance() 静态方法获取一个 Calendar 对象,此对象已由当前日期时间初始化,即默认代表当前时间,如 Calendar c = Calendar.getInstance();

        那么如何使用 Calendar 获取年、月、日、时间等信息呢?我们来看下面的代码:

        其中,调用 Calendar 类的 getInstance() 方法获取一个实例,然后通过调用 get() 方法获取日期时间信息,参数为需要获得的字段的值, Calendar.Year 等为 Calendar 类中定义的静态常量。

运行结果: 

        Calendar 类提供了 getTime() 方法,用来获取 Date 对象,完成 Calendar 和 Date 的转换,还可通过 getTimeInMillis() 方法,获取此 Calendar 的时间值,以毫秒为单位。如下所示:

运行结果:

import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.Date;
public class HelloWorld {
    public static void main(String[] args) {
		// 创建Calendar对象
		Calendar c = Calendar.getInstance();
		// 将Calendar对象转换为Date对象
		Date date = c.getTime();
		// 创建SimpleDateFormat对象,指定目标格式
		SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
		// 将日期转换为指定格式的字符串
		String now = sdf.format(date);
		System.out.println("当前时间:" + now);
	}
}

3-6 使用 Math 类操作数据

        Math 类位于 java.lang 包中,包含用于执行基本数学运算的方法, Math 类的所有方法都是静态方法,所以使用该类中的方法时,可以直接使用类名.方法名,如: Math.round();

常用的方法:

运行结果:

public class HelloWorld {
    public static void main(String[] args) {
       	int[] nums = new int [10];
        //通过循环给数组赋值
		for (int i = 0; i < nums.length; i++) {
            // 产生10以内的随机数
			int x = (int) (Math.random() * 10);
			nums[i] = x;// 为元素赋值
		}
		// 使用foreach循环输出数组中的元素
		for ( int num : nums) {
			System.out.print(num + " ");
		}
	}
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值