1.1 基本类型包装类(共八种,其它自行查看帮助文档)
- 
基本类型包装类的作用
- 
将基本数据类型封装成对象的好处在于可以在对象中定义更多的功能方法操作该数据
 - 
常用的操作之一:用于基本数据类型与字符串之间的转换
 
 - 
 - 
基本类型对应的包装类
 
| 基本数据类型 | 包装类 | 
|---|---|
| byte | Byte | 
| short | Short | 
| int | Integer | 
| long | Long | 
| float | Float | 
| double | Double | 
| char | Character | 
| boolean | Boolean | 
1.2 Integer类
- 
- 
包装一个对象中的原始类型 int 的值
 
 - 
 - 
Integer类构造方法
 
| 方法名 | 说明 | 
|---|---|
| public Integer(int value) | 根据 int 值创建 Integer 对象(过时) | 
| public Integer(String s) | 根据 String 值创建 Integer 对象(过时) | 
| public static Integer valueOf(int i) | 返回表示指定的 int 值的 Integer 实例 | 
| public static Integer valueOf(String s) | 返回一个保存指定值的 Integer 对象 String | 
/*
    构造方法:
        public Integer(int value):根据 int 值创建 Integer 对象(过时)
        public Integer(String s):根据 String 值创建 Integer 对象(过时)
    静态方法获取对象:
        public static Integer valueOf(int i):返回表示指定的 int 值的 Integer 实例
        public static Integer valueOf(String s):返回一个保存指定值的 Integer 对象 String
 */
public class IntegerDemo {
    public static void main(String[] args) {
        //public Integer(int value):根据 int 值创建 Integer 对象(过时)
        Integer i1 = new Integer(100);
        System.out.println(i1);
        //public Integer(String s):根据 String 值创建 Integer 对象(过时)
        Integer i2 = new Integer("100");
//        Integer i2 = new Integer("abc"); //NumberFormatException
        System.out.println(i2);
        System.out.println("--------");
        //public static Integer valueOf(int i):返回表示指定的 int 值的 Integer 实例
        Integer i3 = Integer.valueOf(100);
        System.out.println(i3);
        //public static Integer valueOf(String s):返回一个保存指定值的 Integer 对象 String
        Integer i4 = Integer.valueOf("100");
        System.out.println(i4);
    }
}
1.3 int和String类型的相互转换
- 
int转换为String
- 
转换方式
- 
方式一:直接在数字后加一个空字符串
 - 
方式二:通过String类静态方法valueOf()
 
 - 
 
//int --- String
int number = 100;
//方式1
String s1 = number + "";
System.out.println(s1);
//方式2
//public static String valueOf(int i)
String s2 = String.valueOf(number);
System.out.println(s2);
System.out.println("--------"); - 
 
- 
String转换为int
- 
转换方式
- 
方式一:先将字符串数字转成Integer,再调用valueOf()方法
 - 
方式二:通过Integer静态方法parseInt()进行转换
 
 - 
 
//String --- int
String s = "100";
//方式1:String --- Integer --- int
Integer i = Integer.valueOf(s);
//public int intValue()
int x = i.intValue();
System.out.println(x);
//方式2
//public static int parseInt(String s)
int y = Integer.parseInt(s);
System.out.println(y); - 
 
1.4 字符串数据排序案例
- 
案例需求
- 
有一个字符串:“91 27 46 38 50”,请写程序实现最终输出结果是:“27 38 46 50 91”
 
 - 
 
思路:
    1:定义一个字符串
    2:把字符串中的数字数据存储到一个int类型的数组中
        得到字符串中每一个数字数据?
            public String[] split(String regex)
        定义一个int数组,把 String[] 数组中的每一个元素存储到 int 数组中
            public static int parseInt(String s)
    3:对 int 数组进行排序
    4:把排序后的int数组中的元素进行拼接得到一个字符串,这里拼接采用StringBuilder来实现
    5:输出结果
public class IntegerTest {
    public static void main(String[] args) {
        //定义一个字符串
        String s = "91 27 46 38 50";
        //把字符串中的数字数据存储到一个int类型的数组中
        String[] strArray = s.split(" ");
//        for(int i=0; i<strArray.length; i++) {
//            System.out.println(strArray[i]);
//        }
        //定义一个int数组,把 String[] 数组中的每一个元素存储到 int 数组中
        int[] arr = new int[strArray.length];
        for(int i=0; i<arr.length; i++) {
            arr[i] = Integer.parseInt(strArray[i]);
        }
        //对 int 数组进行排序
        Arrays.sort(arr);
        //把排序后的int数组中的元素进行拼接得到一个字符串,这里拼接采用StringBuilder来实现
        StringBuilder sb = new StringBuilder();
        for(int i=0; i<arr.length; i++) {
            if(i == arr.length - 1) {
                sb.append(arr[i]);
            } else {
                sb.append(arr[i]).append(" ");
            }
        }
        String result = sb.toString();
        //输出结果
        System.out.println(result);
    }
}
1.5 自动拆箱和自动装箱
- 
自动装箱
- 
把基本数据类型转换为对应的包装类类型
 
 - 
 - 
自动拆箱
- 
把包装类类型转换为对应的基本数据类型
 
 - 
 
Integer i = 100; // 自动装箱
i += 200; // i = i + 200; i + 200 自动拆箱;i = i + 200; 是自动装箱
public class IntegerDemo {
    public static void main(String[] args) {
        //装箱:把基本数据类型转换为对应的包装类类型
        Integer i = Integer.valueOf(100);
        Integer ii = 100; //Integer.valueOf(100);
        //ii += 200;
        // ii = ii + 200;
        // ii = ii.intValue() + 200;
        // ii = 300;
        ii += 200;
        System.out.println(ii);
        Integer iii = null;
//        iii += 100; //NullPointerException
        if(iii != null) {
            iii += 100;
        }
    }
}
注意:在使用包装类类型的时候,如果做操作,最好先判断是否为null
我们推荐的是,只要是对象,在使用前就必须进行不为 null 的判断
2. 时间日期类
2.1 Date类
- 
Date类概述
Date 代表了一个特定的时间,精确到毫秒
 - 
Date类构造方法
 
| 方法名 | 说明 | 
|---|---|
| public Date() | 分配一个 Date对象,并初始化,以便它代表它被分配的时间,精确到毫秒 | 
| public Date(long date) | 分配一个 Date对象,并将其初始化为表示从标准基准时间起指定的毫秒数 | 
/*
    public Date():分配一个 Date对象,并初始化,以便它代表它被分配的时间,精确到毫秒
    public Date(long date):分配一个 Date对象,并将其初始化为表示从标准基准时间起指定的毫秒数
 */
public class DateDemo01 {
    public static void main(String[] args) {
        //public Date():分配一个 Date对象,并初始化,以便它代表它被分配的时间,精确到毫秒
        Date d1 = new Date();
        System.out.println(d1);
        //public Date(long date):分配一个 Date对象,并将其初始化为表示从标准基准时间起指定的毫秒数
        long date = 1000*60*60;
        Date d2 = new Date(date);
        System.out.println(d2);
    }
}
2.2 Date类常用方法
| 方法名 | 说明 | 
|---|---|
| public long getTime() | 获取的是日期对象从1970年1月1日 00:00:00到现在的毫秒值 | 
| public void setTime(long time) | 设置时间,给的是毫秒值 | 
/*
public long getTime():获取的是日期对象从1970年1月1日 00:00:00到现在的毫秒值
public void setTime(long time):设置时间,给的是毫秒值
*/
public class DateDemo02 {
public static void main(String[] args) {
//创建日期对象
Date d = new Date();
//public long getTime():获取的是日期对象从1970年1月1日 00:00:00到现在的毫秒值
// System.out.println(d.getTime());
// System.out.println(d.getTime() * 1.0 / 1000 / 60 / 60 / 24 / 365 + "年");
//public void setTime(long time):设置时间,给的是毫秒值
// long time = 1000*60*60;
long time = System.currentTimeMillis();
d.setTime(time);
System.out.println(d);
}
}
2.3 SimpleDateFormat类
- 
SimpleDateFormat类概述
- 
SimpleDateFormat是一个具体的类,用于以区域设置敏感的方式格式化和解析日期。
 - 
我们重点学习日期格式化和解析
 
 - 
 - 
SimpleDateFormat类构造方法
 
| 方法名 | 说明 | 
|---|---|
| public SimpleDateFormat() | 构造一个SimpleDateFormat,使用默认模式和日期格式 | 
| public SimpleDateFormat(String pattern) | 构造一个SimpleDateFormat使用给定的模式和默认的日期 格式 | 
- 
SimpleDateFormat类的常用方法
- 
格式化(从Date到String)
- 
public final String format(Date date):将日期格式化成日期/时间字符串
 
 - 
 - 
解析(从String到Date)
- 
public Date parse(String source):从给定字符串的开始解析文本以生成日期
 
 - 
 
 - 
 
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
/*
构造方法:
public SimpleDateFormat():构造一个SimpleDateFormat,使用默认模式和日期格式
public SimpleDateFormat(String pattern):构造一个SimpleDateFormat使用给定的模式和默认的日期格式
格式化:从 Date 到 String
public final String format(Date date):将日期格式化成日期/时间字符串
解析:从 String 到 Date
public Date parse(String source):从给定字符串的开始解析文本以生成日期
*/
public class SimpleDateFormatDemo {
public static void main(String[] args) throws ParseException {
//格式化:从 Date 到 String
Date d = new Date();
// SimpleDateFormat sdf = new SimpleDateFormat();
SimpleDateFormat sdf = new SimpleDateFormat("yyyy年MM月dd日 HH:mm:ss");
String s = sdf.format(d);
System.out.println(s);
System.out.println("--------");
//从 String 到 Date
String ss = "2048-08-09 11:11:11";
//ParseException
SimpleDateFormat sdf2 = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
Date dd = sdf2.parse(ss);
System.out.println(dd);
}
}
2.4 日期工具类案例
- 
案例需求
- 
定义一个日期工具类(DateUtils),包含两个方法:把日期转换为指定格式的字符串;把字符串解析为指定格式 的日期,然后定义一个测试类(DateDemo),测试日期工具类的方法
 
 - 
 - 
代码实现
 
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
/*
工具类
构造方法私有
成员方法静态
*/
public class DateUtils {
private DateUtils() {}
/*
把日期转为指定格式的字符串
返回值类型:String
参数:Date date, String format
*/
public static String dateToString(Date date, String format) {
SimpleDateFormat sdf = new SimpleDateFormat(format);
String s = sdf.format(date);
return s;
}
/*
把字符串解析为指定格式的日期
返回值类型:Date
参数:String s, String format
*/
public static Date stringToDate(String s, String format) throws ParseException {
SimpleDateFormat sdf = new SimpleDateFormat(format);
Date d = sdf.parse(s);
return d;
}
}
import java.text.ParseException;
import java.util.Date;
/*
测试类
*/
public class DateDemo {
public static void main(String[] args) throws ParseException {
//创建日期对象
Date d = new Date();
String s1 = DateUtils.dateToString(d, "yyyy年MM月dd日 HH:mm:ss");
System.out.println(s1);
String s2 = DateUtils.dateToString(d, "yyyy年MM月dd日");
System.out.println(s2);
String s3 = DateUtils.dateToString(d, "HH:mm:ss");
System.out.println(s3);
System.out.println("--------");
String s = "2048-08-09 12:12:12";
Date dd = DateUtils.stringToDate(s, "yyyy-MM-dd HH:mm:ss");
System.out.println(dd);
}
}
2.5 Calendar类(日历类)
- 
Calendar类概述
- 
Calendar 为特定瞬间与一组日历字段之间的转换提供了一些方法,并为操作日历字段提供了一些方法 Calendar 提供了一个类方法 getInstance 用于获取这种类型的一般有用的对象。 该方法返回一个Calendar 对象。
 - 
其日历字段已使用当前日期和时间初始化:Calendar rightNow = Calendar.getInstance();
 
 - 
 - 
Calendar类常用方法
 
| 方法名 | 说明 | 
|---|---|
| public int get(int field) | 返回给定日历字段的值 | 
| public abstract void add(int field, int amount) | 根据日历的规则,将指定的时间量添加或减去给定的日 历字段 | 
| public final void set(int year,int month,int date) | 设置当前日历的年月日 | 
- 
代码
 
import java.util.Calendar;
/*
public abstract void add(int field, int amount):根据日历的规则,将指定的时间量添加或减去给定的日历字段
public final void set(int year,int month,int date):设置当前日历的年月日
*/
public class CalendarDemo {
public static void main(String[] args) {
//获取日历类对象
Calendar c = Calendar.getInstance();
//public int get(int field):返回给定日历字段的值
int year = c.get(Calendar.YEAR);
int month = c.get(Calendar.MONTH) + 1;
int date = c.get(Calendar.DATE);
System.out.println(year + "年" + month + "月" + date + "日");
//public abstract void add(int field, int amount):根据日历的规则,将指定的时间量添加或减去给定的日历字段
//需求1:3年前的今天
// c.add(Calendar.YEAR,-3);
// year = c.get(Calendar.YEAR);
// month = c.get(Calendar.MONTH) + 1;
// date = c.get(Calendar.DATE);
// System.out.println(year + "年" + month + "月" + date + "日");
//需求2:10年后的10天前
// c.add(Calendar.YEAR,10);
// c.add(Calendar.DATE,-10);
// year = c.get(Calendar.YEAR);
// month = c.get(Calendar.MONTH) + 1;
// date = c.get(Calendar.DATE);
// System.out.println(year + "年" + month + "月" + date + "日");
//public final void set(int year,int month,int date):设置当前日历的年月日
c.set(2050,10,10);
year = c.get(Calendar.YEAR);
month = c.get(Calendar.MONTH) + 1;
date = c.get(Calendar.DATE);
System.out.println(year + "年" + month + "月" + date + "日");
}
}
2.6 二月天案例
- 
案例需
获取任意一年的二月有多少天
 
思路:
1:键盘录入任意的年份
2:设置日历对象的年、月、日
年:来自于键盘录入
月:设置为3月,月份是从0开始的,所以设置的值是2
日:设置为1日
3:3月1日往前推一天,就是2月的最后一天
4:获取这一天输出即可
- 
代码实现
public class CalendarTest {
public static void main(String[] args) {
//键盘录入任意的年份
Scanner sc = new Scanner(System.in);
System.out.println("请输入年:");
int year = sc.nextInt();
//设置日历对象的年、月、日
Calendar c = Calendar.getInstance();
c.set(year, 2, 1);
//3月1日往前推一天,就是2月的最后一天
c.add(Calendar.DATE, -1);
//获取这一天输出即可
int date = c.get(Calendar.DATE);
System.out.println(year + "年的2月份有" + date + "天");
}
} 
3. 异常
3.1 异常
- 
异常的概述
- 
异常就是程序出现了不正常的情况...
 
 - 
 
- 
Error:严重问题,不需要处理
 - 
Exception:成为异常类,它表示程序本身可以处理的问题
- 
RuntimeException:在编译期是不检查的,出现问题后,需要我们回来修改代码
 - 
非RuntimeException:编译期就必须处理的,否则程序不能通过编译,就更不能正常运行了
 
 - 
 
3.2 JVM默认处理异常的方式
- 
如果程序出现了问题,我们没有做任何处理,最终JVM 会做默认的处理,处理方式有如下两个步骤:
- 
把异常的名称,错误原因及异常出现的位置等信息输出在了控制台
 - 
程序停止执行
 
 - 
 
3.3 try-catch处理异常
- 
定义格式
 
try {
    可能出现异常的代码;
} catch(异常类名 变量名) {
    异常的处理代码;
}
- 
执行流程
- 
程序从 try 里面的代码开始执行
 - 
出现异常,就会跳转到对应的 catch 里面去执行
 - 
执行完毕之后,程序还可以继续往下执行
 
 - 
 - 
代码
 
public class ExceptionDemo01 {
    public static void main(String[] args) {
        System.out.println("开始");
        method();
        System.out.println("结束");
    }
    public static void method() {
        try {
            int[] arr = {1, 2, 3};
            System.out.println(arr[3]);
            System.out.println("这里能够访问到吗");
        } catch (ArrayIndexOutOfBoundsException e) {
//            System.out.println("你访问的数组索引不存在,请回去修改为正确的索引");
            e.printStackTrace();
        }
    }
}
3.4 Throwable成员方法
- 
常用方法
 
| 方法名 | 说明 | 
|---|---|
| public String getMessage() | 返回此 throwable 的详细消息字符串 | 
| public String toString() | 返回此可抛出的简短描述 | 
| public void printStackTrace() | 把异常的错误信息输出在控制台 | 
public class ExceptionDemo02 {
    public static void main(String[] args) {
        System.out.println("开始");
        method();
        System.out.println("结束");
    }
    public static void method() {
        try {
            int[] arr = {1, 2, 3};
            System.out.println(arr[3]); //new ArrayIndexOutOfBoundsException();
            System.out.println("这里能够访问到吗");
        } catch (ArrayIndexOutOfBoundsException e) { //new ArrayIndexOutOfBoundsException();
//            e.printStackTrace();
            //public String getMessage():返回此 throwable 的详细消息字符串
//            System.out.println(e.getMessage());
            //Index 3 out of bounds for length 3
            //public String toString():返回此可抛出的简短描述
//            System.out.println(e.toString());
            //java.lang.ArrayIndexOutOfBoundsException: Index 3 out of bounds for length 3
            //public void printStackTrace():把异常的错误信息输出在控制台
            e.printStackTrace();
//            java.lang.ArrayIndexOutOfBoundsException: Index 3 out of bounds for length 3
//            at com.itheima_02.ExceptionDemo02.method(ExceptionDemo02.java:18)
//            at com.itheima_02.ExceptionDemo02.main(ExceptionDemo02.java:11)
        }
    }
}
/*
    public class Throwable {
        private String detailMessage;
        public Throwable(String message) {
            detailMessage = message;
        }
        public String getMessage() {
            return detailMessage;
        }
    }
 */
3.5 编译时异常和运行时异常的区别
Java中的异常被分为两大类:编译时异常和运行时异常,也被称为受检异常和非受检异常所有的RuntimeException类及其子类被称为运行时异常,其他的异常都是编译时异常
- 
编译时异常
- 
都是Exception类及其子类
 - 
必须显示处理,否则程序就会发生错误,无法通过编译
 
 - 
 - 
运行时异常
- 
都是RuntimeException类及其子类
 - 
无需显示处理,也可以和编译时异常一样处理
 
 - 
 
3.6 throws方式处理异常
虽然我们通过 try...catch..可以对异常进行处理,但是并不是所有的情况我们都有权限进行异常的处理也就是说,有些时候可能出现的异常是我们处理不了的,这个时候该怎么办呢?
针对这种情况,Java提供了throws 的处理方案
- 
格式:
public void 方法() throws 异常类名 {
} - 
示例代码
 
public class ExceptionDemo {
    public static void main(String[] args) {
        System.out.println("开始");
//        method();
        try {
            method2();
        }catch (ParseException e) {
            e.printStackTrace();
        }
        System.out.println("结束");
    }
    //编译时异常
    public static void method2() throws ParseException {
        String s = "2048-08-09";
        SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
        Date d = sdf.parse(s);
        System.out.println(d);
    }
    //运行时异常
    public static void method() throws ArrayIndexOutOfBoundsException {
        int[] arr = {1, 2, 3};
        System.out.println(arr[3]);
    }
}
- 
注意事项
- 
这个throws格式是跟在方法的括号后面的
 - 
编译时异常必须要进行处理,两种处理方案:try...catch …或者 throws,如果采用 throws 这种方案, 将来谁调用谁处理
 - 
运行时异常可以不处理,出现问题后,需要我们回来修改代码
 
 - 
 
3.7 throws和throw的区别
3.8 自定义异常
- 
自定义异常类
 
public class ScoreException extends Exception {
    public ScoreException() {}
    public ScoreException(String message) {
        super(message);
    }
}
- 
老师类
 
public class Teacher {
    public void checkScore(int score) throws ScoreException {
        if(score<0 || score>100) {
//            throw new ScoreException();
            throw new ScoreException("你给的分数有误,分数应该在0-100之间");
        } else {
            System.out.println("成绩正常");
        }
    }
}
- 
测试类
 
import java.util.Scanner;
public class Demo {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
System.out.println("请输入分数:");
int score = sc.nextInt();
Teacher t = new Teacher();
try {
t.checkScore(score);
} catch (ScoreException e) {
e.printStackTrace();
}
}
}
                    
                
                
            
        
浙公网安备 33010602011771号