JavaSE学习笔记

‘/t’ 制表符

  • 在打印的时候,把前面的字符长度补齐到8后者8的整数倍数,最少1个空格,最多2个空格

JDK7进制表示

进制

long型数据

  • 定义long型数据需要在数据后面加一个L
// 数据后加入L
long n = 999999999L;

Scanner键盘输入运用

//scanner调用方法nextInt一次就会键盘输入一次.下面代码会键盘输入两次
Scanner sc = new Scanner(System.in);
System.out.println("请输入整数");
sc.nextInt();
int i = sc.nextInt();
System.out.println(i);

IDEA快捷建

  • psvm主函数
  • sout 输出

取值范围

byte->short->int->long->float->double

byte short char 三种类型的数据进行计算的时候,都会直接提升到int类型,再进行计算

在这里插入图片描述

""和’'的区别

""表示内容为字符串
''表示类容为字符即char类型

赋值运算符

+= -= /= %= 四种关系运算符包含强制类型转换

短路运算

++a < 5 $$ ++b < 5;
当左边表达式能得出结果,便不再计算右边的值

隐式转换底层原理

byte类型 : 1个字节
short类型 : 2个字节
int类型 : 4个字节
long类型 : 8个字节

  • 隐式转换 : 前面加入缺少的零
  • 强制转换 : 前面消除多余位数

if和else if 判断

多条件判断.按顺序逐个判断,有一个为true遍退出循环

case穿透

  • 原因:代码中没有写braek结束语句
  • 执行流程:首先拿着小括号里面的值跟每一个case进行匹配,如果匹配上了就执行case语句体,此时若遇到break便会结束switch语句,若是没有break,那么程序就会继续执行下一个case的语句体,直到遇到break或者所有case语句体执行完
  • 注意: switch中按先后顺序执行case

while循环语句条件为true时,下方不能写代码

//while 循环条件为true时是无限循环,无法到达while循环下面的代码
        Scanner scanner = new Scanner(System.in);
        int x = scanner.nextInt();
        int temp = x;
        int num = 0;
        while (true){
            int shu = x % 10;
            x = x / 10;
            num = num * 10 + shu;
        }
        System.out.println(num == temp);//本行代码报错

break 和 switch 的区别

在这里插入图片描述

This的本质

  • this指向的是成员变量, 但其本质是指向调用这的地址值
  • 调用方法的时候默认其方法前有一个this

键盘录入体系

    第一套体系:
    nextInt(); 接收整数
    nextDouble();接收小数
    next();接收字符串
    遇到空格,制表符,回车就停止接受。这些符号后面的数据就不会接受了
    
    第二套体系:
    nextLine();接收字符串
    可以接收空格,制表符,遇到回车才停止接受数据

char类型字符参与计算

char类型字符参与计算的时候,会自动查找ASCII码表,转换为相应的int型数据进行计算

对Srting对象的比较要使用equals方法进行而不是用’==’


String拼接

  • String s1 = “a” + “b” + “c”;
  • String s2 = “abc”;
  • s1 == s2 ? 为true
  • 字符串拼接没有变量时,直接在编译阶段优化,即代码还未运行时s1便已被优化为abc字符串
  • 字符串拼接包含变量时,JDK8以前通过new StringBuilder在该容器内拼接, JDK8版本以后系统通过预估字符串长度创建数组进行存储

StringBuilder

  • StrinBuilder容器的append方法是一直往后添加, 即在原有的基础上往后面添加字符, 所以再使用是无需append(sb).append(“xxx”), 直接append(“xxx”)即可
    在这里插入图片描述

ArrayList

  • 集合底层已处理,返回的数据不是地址值而是其中的内容
  • 集合只可以存储引用数据类型

Util工具类特点

  • 构造方法私有化
  • 成员方法静态化

方法重写

在这里插入图片描述

多态

使用规则:

  • 需要有继承关系
  • 声明父类对象new子类
  • 子类重写父类方法

调用规则

public class Test {
    public static void main(String[] args) {
        //创建对象(多态方式)
        //Fu f = new Zi();
        Animal a = new Dog();
        //调用成员变量:编译看左边,运行也看左边
        //编译看左边:javac编译代码的时候,会看左边的父类中有没有这个变量,如果有,编译成功,如果没有编译失败。
        //运行也看左边:java运行代码的时候,实际获取的就是左边父类中成员变量的值
        System.out.println(a.name);//动物

        //调用成员方法:编译看左边,运行看右边
        //编译看左边:javac编译代码的时候,会看左边的父类中有没有这个方法,如果有,编译成功,如果没有编译失败。
        //运行看右边:java运行代码的时候,实际上运行的是子类中的方法。
        a.show();///Dog --- show方法

        //理解:
        //Animal a = new Dog();
        //现在用a去调用变量和方法的呀?是的
        //而a是Animal类型的,所以默认都会从Animal这个类中去找

        //成员变量:在子类的对象中,会把父类的成员变量也继承下的。父:name  子:name
        //成员方法:如果子类对方法进行了重写,那么在虚方法表中是会把父类的方法进行覆盖的。
    }
}


class Animal{
    String name = "动物";

   public void show(){
        System.out.println("Animal --- show方法");
    }
}

class Dog extends Animal{
    String name = "狗";

    @Override
    public void show() {
        System.out.println("Dog --- show方法");
    }

}

class Cat extends Animal{
    String name = "猫";

   @Override
    public void show() {
        System.out.println("Cat --- show方法");
    }
}

泛型

  • 泛型接口
  • 泛型方法
  • 泛型类
  • E T K V在定义泛型的时候使用
  • ? 通配符在使用泛型的时候使用
    ** ? extends 类名 : 代表泛型上限, ?必须是类的子类或其本身
    ** ? super 类名 : 代表泛型下线限, ?必须是类的父类或其本身

Objects

Objects常用方法

System API

  • arraycopy​(Object src, int srcPos, Object dest, int destPos, int length) 将指定源数组中的数组从指定位置开始复制到目标数组的指定位置。

BigDecimal API

  • 对浮点型数据类型进行一系列操作的保证其精度准确的类
        double a = 0.1;
        double b = 0.2;
        System.out.println(a + b);
        BigDecimal aBig = BigDecimal.valueOf(a);
        BigDecimal bBig = BigDecimal.valueOf(b);

        System.out.println(aBig.add(bBig));

        //转化为double类型
        double rs = aBig.doubleValue();
        System.out.println(rs);

Date API

  • getTime()方法 : 返回自此 Date对象表示的1970年1月1日00:00:00 GMT以来的毫秒数。

SimpleDateFormat API

SimpleDateFormat

  • 字符串时间转换为Date类型的格式化时间
//计算2021年08月06日 11:11:11 后2天 14小时 49分 06秒的时间
        String dataStr = "2021年08月06日 11:11:11";
        //定义时间规格, 必须与需要转换的字符串格式一致
        SimpleDateFormat simpleDateFormat1 = new SimpleDateFormat("yyyy年MM月dd日 HH:mm:ss");
        //将字符串转换为时间
        Date date1 = simpleDateFormat1.parse(dataStr);

        long l = date1.getTime() + 2L * 24 * 60 * 60 * 1000 + 14 * 60 * 60 * 1000 + 49*60*1000 + 6 * 1000;

        String format1 = simpleDateFormat1.format(l);
        String format2 = simpleDateFormat1.format(date1);
        System.out.println(format2);
        System.out.println(format1);

Calendar API

Calendar

LocalDate, LocalTime, LocalDateTime

LocalDate
LocalTime的转换API
LocalDate, LocalTime, LocalDateTime

Period API

Period

Duration API

Duration

Arrays API

Arrays

        Student[] students = new Student[3];
        students[0] = new Student("吴磊", 23, '男');     
        students[1] = new Student("谢鑫", 18, '男');
        students[2] = new Student("王亮", 20, '男');

        Arrays.sort(students, new Comparator<Student>() {
            @Override
            public int compare(Student o1, Student o2) { 
                if (o1.getAge() == 23){
                    System.out.println(o1);
                }else {
                    System.out.println("从第二个开始");
                }
                return o1.getAge() - o2.getAge();
            }
        });

        System.out.println(Arrays.toString(students));

Lambda 表达式

  • Lambda 表达式简化匿名内部类, 且匿名内部类必须是函数式接口
package LambdaDemo1;

import org.jcp.xml.dsig.internal.dom.DOMSubTreeData;

public class LambdaDemo1 {
    public static void main(String[] args) {

        Swimming swimming = new Swimming() {
            @Override
            public void swim() {
                System.out.println("跑的很快");
            }
        };

        Swimming swimming1 = () -> {
            System.out.println("跑的很快");
        };


        go(swimming);
        System.out.println("----------------------");
        go(swimming1);
        System.out.println("----------------------");
        go(() -> {
            System.out.println("跑的很快");
        });

    }

    public static void go(Swimming swimming){
        System.out.println("开始...");
        swimming.swim();
        System.out.println("结束...");
    }
}

@FunctionalInterface
interface Swimming{
    void swim();
}

  • 进一步代码简化规则
    Lambda表达式简化规则

Collection 集合体系

Collection 集合体系

Collection API

Collection API

红黑树规则

红黑树规则

LinkedList API

LinkedList API

集合遍历且在遍历过程中删除元素

  • 使用迭代器删除
Collection<String> arrList = new ArrayList();
        arrList.add("小李");
        arrList.add("小李");
        arrList.add("小李");
        arrList.add("小李");
        arrList.add("小李");
        
Iterator<String> iterator = arrList.iterator();
        while (iterator.hasNext()){
            String next = iterator.next();
            if (Objects.equals(next, "小李")) {
                iterator.remove();
            }
        }
  • 使用for循环删除
for (int i = arrList.size() - 1; i >= 0; i--) {
     String s = arrList.get(i);
     if (Objects.equals(s, "小李")){
         arrList.remove(s);
     }
}

for (int i = 0; i < arrList.size(); i++) {
    String s = arrList.get(i);
    if (Objects.equals(s, "小李")){
        arrList.remove(s);
        i--;
    }
}

循环集合且删除元素

HashSet中Hash表原理

在这里插入图片描述

集合总结和选择标准

在这里插入图片描述

可变参数

可变参数

Collections API

  • 批量添加元素 : addAll() 方法
    Collections API

Map API

MAP API

遍历Map集合

        Map<String, Integer> maps = new HashMap<>();

        maps.put("王五",15);
        maps.put("李四",19);
        maps.put("赵六",25);
        
        //第一种遍历方式, 将键值对作为整体拿出
        Set<Map.Entry<String, Integer>> entries = maps.entrySet();
        for (Map.Entry<String, Integer> entry : entries) {
            String key = entry.getKey();
            int value = entry.getValue();
            System.out.println(key + "---->" + value);
        }

		//第二种遍历方式, 推荐
        Set<String> keys = maps.keySet();

        for (String key : keys) {
            int integer = maps.get(key);
            System.out.println(key + "---->" + integer);
        }

		//第三种遍历方式, 推荐
        maps.forEach(new BiConsumer<String, Integer>() {
            @Override
            public void accept(String s, Integer integer) {
                System.out.println(s + "---->" + integer);
            }
        });

不可变集合

不可变集合

集合和数组获取Steam流

集合和数组获取Steam流

Stream流常用方法

Stream流常用方法

  • 流只能通过一些操作筛选集合中的元素, 而不能改变集合本身, 其本质是将集合拷贝一份到流中进行操作

  • 每个流只能使用一次

自定义异常

  • 自定义运行时异常类, 编译阶段不提示,
public class MyRunTimeException extends RuntimeException {
    public MyRunTimeException() {
    }

    public MyRunTimeException(String message) {
        super(message);
    }
}
  • 自定义编译时异常, 编一阶段强烈提示, 必须抛出或者捕获异常
public class MyOneException extends Exception{
    public MyOneException() {
    }

    public MyOneException(String message) {
        super(message);
    }
}
  • 自定义异常测试类
public class ExceptionTest1 {

    public static void main(String[] args) {

        try {
            chainAge(-19);
        } catch (MyOneException myOneExcetion) {
            myOneExcetion.printStackTrace();
        }

        chainAge1(-59);

    }
    public static void chainAge(int age) throws MyOneException {
        if (age < 0 || age > 200){
            throw new MyOneException(age + " is no!!");
        }else{
            System.out.println("输入合法");
        }
    }

    public static void chainAge1(int age) throws RuntimeException {
        if (age < 0 || age > 200){
            throw new RuntimeException(age + " is no!!");
        }else{
            System.out.println("输入合法");
        }
    }
}

File API

  • 常用方法
    File常用方法

File文件遍历及注意事项

File文件遍历

IO流四大类

IO流四大类

IO流体系

IO流体系
详细IO体系

IO

  • 输出字节流只支持字节的输出, 若想将字符输出需先将字符转换为字节数据, 然后在进行输出
        OutputStream fileOut = new FileOutputStream("day18-File-IO/src/out.txt");
        fileOut.write('a');
        fileOut.write(98);
        fileOut.write("散散啊".getBytes());
        fileOut.flush();
        fileOut.close();

IO流拷贝文档

        try { //通过byte字节流拷贝数据, 已淘汰
            InputStream is = new FileInputStream("day18-File-IO//src//a.txt");
            byte[] bt = new byte[1024];
            int len = 0;

            OutputStream os = new FileOutputStream("D://code//a.txt");
            while ((len = is.read(bt)) != -1){
                os.write(bt, 0, len);
            }

        } catch (Exception e) {
            e.printStackTrace();
        }

注意 : 三种资源释放方式
IO流资源释放

读取输入输出流注意事项

  • 不论是读取字符还是字节输入输出流, 将读取的字符/字节放置在char[]/byte[] 数组中, 都应该定义一个整型变量len获取输入/输出的字符/字节长度, 然后在对获取的流封装成字符串的时候指定其读取从0开始到len, 这样才能避免错误且提高代码效率
        try {
            Reader fileReader = new FileReader("day18-File-IO//src//b.txt");

            char[] flRead = new char[1024];
            int len = 0;
            if ((len = fileReader.read(flRead)) != -1){
                String str = new String(flRead, 0, len);
                System.out.print(str);
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

缓冲流

缓冲流

缓冲流拷贝数据

  • 注意 : 缓冲流读取一行数据后, 再将这一行数据写入到拷贝的文件中, 需要写入换行的命令符
        try (Reader fileReader = new FileReader("day18-File-IO//src//b.txt");
             BufferedReader fr = new BufferedReader(fileReader);
             Writer fileWriter = new FileWriter("day18-File-IO//src//d.txt");
             BufferedWriter fw = new BufferedWriter(fileWriter);
        ) {
            LocalDateTime startTime = LocalDateTime.now();
            String line;
            while ((line = fr.readLine()) != null) {
                fw.write(line);
                fw.newLine();
                //fw.write("\r\n"); 相当于newLine()
            }
            LocalDateTime endTime = LocalDateTime.now();
            System.out.println("文件Copy完成");
            Duration dateTime = Duration.between(startTime,endTime);
            System.out.println(dateTime.toMillis());
        } catch (Exception e) {
            e.printStackTrace();
        }
  • 出师表排序并输出到文件中
        try(
                // 1、创建缓冲字符输入流管道与源文件接通
                BufferedReader br = new BufferedReader(new FileReader("io-app2/src/csb.txt"));

                // 5、定义缓冲字符输出管道与目标文件接通
                BufferedWriter bw = new BufferedWriter(new FileWriter("io-app2/src/new.txt"));
                ) {

            // 2、定义一个List集合存储每行内容
            List<String> data = new ArrayList<>();
            // 3、定义循环,按照行读取文章
            String line;
            while ((line = br.readLine()) != null){
                data.add(line);
            }
            System.out.println(data);

            // 4、排序
            // 自定义排序规则
            List<String> sizes = new ArrayList<>();
            Collections.addAll(sizes, "一","二","三","四","五","陆","柒","八","九","十","十一");

            Collections.sort(data, new Comparator<String>() {
                @Override
                public int compare(String o1, String o2) {
                    // o1   八.,....
                    // o2   柒.,....
                    return sizes.indexOf(o1.substring(0, o1.indexOf(".")))
                            - sizes.indexOf(o2.substring(0, o2.indexOf(".")));
                }
            });
            System.out.println(data);

            // 6、遍历集合中的每行文章写出去,且要换行
            for (String datum : data) {
                bw.write(datum);
                bw.newLine(); // 换行
            }

        } catch (Exception e) {
            e.printStackTrace();
        }
    }

//出师表txt文档
十一.出师未捷身先死,长使英雄泪满襟。
三.侍中、侍郎郭攸之、费祎、董允等,此皆良实,志虑忠纯,是以先帝简拔以遗陛下。愚以为宫中之事,事无大小,悉以咨之,然后施行,必得裨补阙漏,有所广益。
八.愿陛下托臣以讨贼兴复之效,不效,则治臣之罪,以告先帝之灵。若无兴德之言,则责攸之、祎、允等之慢,以彰其咎;陛下亦宜自谋,以咨诹善道,察纳雅言,深追先帝遗诏,臣不胜受恩感激。
四.将军向宠,性行淑均,晓畅军事,试用之于昔日,先帝称之曰能,是以众议举宠为督。愚以为营中之事,悉以咨之,必能使行阵和睦,优劣得所。
二.宫中府中,俱为一体,陟罚臧否,不宜异同。若有作奸犯科及为忠善者,宜付有司论其刑赏,以昭陛下平明之理,不宜偏私,使内外异法也。
一.先帝创业未半而中道崩殂,今天下三分,益州疲弊,此诚危急存亡之秋也。然侍卫之臣不懈于内,忠志之士忘身于外者,盖追先帝之殊遇,欲报之于陛下也。诚宜开张圣听,以光先帝遗德,恢弘志士之气,不宜妄自菲薄,引喻失义,以塞忠谏之路也。
九.今当远离,临表涕零,不知所言。
十.今当远离,临表涕零,不知所言。
陆.臣本布衣,躬耕于南阳,苟全性命于乱世,不求闻达于诸侯。先帝不以臣卑鄙,猥自枉屈,三顾臣于草庐之中,咨臣以当世之事,由是感激,遂许先帝以驱驰。后值倾覆,受任于败军之际,奉命于危难之间,尔来二十有一年矣。
柒.先帝知臣谨慎,故临崩寄臣以大事也。受命以来,夙夜忧叹,恐付托不效,以伤先帝之明,故五月渡泸,深入不毛。今南方已定,兵甲已足,当奖率三军,北定中原,庶竭驽钝,攘除奸凶,兴复汉室,还于旧都。此臣所以报先帝而忠陛下之职分也。至于斟酌损益,进尽忠言,则攸之、祎、允之任也。
五.亲贤臣,远小人,此先汉所以兴隆也;亲小人,远贤臣,此后汉所以倾颓也。先帝在时,每与臣论此事,未尝不叹息痛恨于桓、灵也。侍中、尚书、长史、参军,此悉贞良死节之臣,愿陛下亲之信之,则汉室之隆,可计日而待也。

字符输入转换流 InputStreamReader

InputStreamReader

字符输出转换流 OutputStreamWriter

OutputStreamWriter

对象字节输入流 ObjectInputStream

ObjectInputStream

对象字节输出流 ObjectOutputStream

ObjectOutputStream

  • 对象序列化中被序列化的对象必须实现接口Serializable
  • 成员变量加入transient修饰将不再参与序列化

对象序列化代码

//实体类Student
public class Student implements Serializable {
    private String name;
    private char sex;
    private transient int age;

//对象输出流代码
    public static void main(String[] args) throws Exception {
        Student student = new Student("王五", '男', 19);

        ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream("day18-File-IO//src//e.txt"));

        oos.writeObject(student);

        oos.close();

        System.out.println("序列化成功");

    }

//对象输入流代码
    public static void main(String[] args) throws Exception {

        FileInputStream oi = new FileInputStream("day18-File-IO//src//e.txt");

        ObjectInputStream ois = new ObjectInputStream(oi);

        Student student = (Student) ois.readObject();
    }

字节/字符打印流

PrintStream
PrintWriter
打印流总结

打印流冲定向

  • System.out.println实际是一个打印流, 其指向我们的控制台
    public static void main(String[] args) throws Exception {
        System.out.println("锦瑟无端五十弦");
        System.out.println("一弦一柱思华年");

        // 改变输出语句的位置(重定向)
        PrintStream ps = new PrintStream("io-app2/src/log.txt");
        System.setOut(ps); // 把系统打印流改成我们自己的打印流

        System.out.println("庄生晓梦迷蝴蝶");
        System.out.println("望帝春心托杜鹃");
    }

Properties API

Properties API

commons-io 框架使用

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值