Java常用类概述

news2025/5/11 13:31:50

Java常用类概述

  • 一、字符串三剑客
    • 1. String(不可变字符串)
    • 2. StringBuilder(可变,线程不安全)
    • 3. StringBuffer(可变,线程安全)
  • 二、日期时间类(重点掌握新版API)
    • 1. LocalDateTime(JDK8+推荐)
    • 2. DateTimeFormatter(格式化)
  • 三、集合框架(必须掌握!)
    • 1. List系列
    • 2. Set系列
    • 3. Map系列
    • ​​关键区别​​:
  • 四、数学工具类
    • 1. Math类
    • 2. BigDecimal(精确计算)
  • 五、输入输出类
    • 1. Scanner(控制台输入)
    • 2. File类(文件操作)
  • 六、比较器
    • 1.Java比较器的使用背景
    • 2.自然排序:使用Comparable接口
      • 2.1说明
      • 2.2代码举例
    • 3.定制排序:使用Comparator接口
      • 2.1说明
      • 2.2代码举例
  • 七、记忆要点总结
    • 1.字符串三原则​​:
    • ​​2.日期新老对比​​:
    • 3.​​集合框架核心​​:
    • ​​4.数学计算​​:
    • 5.比较器
  • ​​八、实战技巧​​

一、字符串三剑客

1. String(不可变字符串)

String s = "Hello";
s += " World"; // 实际创建了新的字符串对象

// 常用方法
s.length();          // 长度 → 5
s.charAt(1);         // 获取字符 → 'e'
s.substring(2,4);    // 截取 → "ll"
s.indexOf("e");      // 查找位置 → 1
s.equals("hello");   // 比较内容 → false(区分大小写)

​​重点记忆​​:

  • 每次修改都会产生新对象(适合少量操作)
  • ==比较地址,.equals()比较内容

2. StringBuilder(可变,线程不安全)

StringBuilder sb = new StringBuilder();
sb.append("Hello").append(" World"); // 原对象修改

// 常用方法
sb.reverse();  // 反转字符串 → "dlroW olleH"
sb.delete(5, 7); // 删除指定范围字符

3. StringBuffer(可变,线程安全)

用法与StringBuilder相同,但方法加了synchronized锁

​​对比记忆​​:

  • 单线程用StringBuilder(更快)
  • 多线程用StringBuffer(安全)

二、日期时间类(重点掌握新版API)

1. LocalDateTime(JDK8+推荐)

LocalDateTime now = LocalDateTime.now(); // 当前时间
LocalDate date = now.toLocalDate();      // 2025-05-01
LocalTime time = now.toLocalTime();      // 15:30:45

// 时间计算
LocalDateTime tomorrow = now.plusDays(1);

2. DateTimeFormatter(格式化)

DateTimeFormatter fmt = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm");
String str = now.format(fmt);  // 2025-05-01 15:30

​​对比旧版Date​​:

  • 旧版(Date/Calendar)存在线程安全问题
  • 新版API更清晰易用(LocalDate、LocalTime、LocalDateTime)

三、集合框架(必须掌握!)

在这里插入图片描述

|----Collection接口:单列集合,用来存储一个一个的对象。
      |----List接口:存储有序的、可重复的数据。-->“动态”数组
          |----ArrayList
          |----LinkedLis
          |----Vector
      |----Set接口:存储无序的、不可重复的数据。-->高中讲的“集合”
             |----HashSet
             |----LinkedHashSet
             |----TreeSet
|----Map接口:双列集合,用来存储一对(key-value)一对的数据。-->高中函数:y = f(x)
            |----HashMap
            |----LinkedHashMap
            |----TreeMap
            |----HashTable
            |----Properties

在这里插入图片描述
在这里插入图片描述

1. List系列

// ArrayList(数组实现,查询快)
List<String> list = new ArrayList<>();
list.add("Apple");
list.get(0); // 快速访问

// LinkedList(链表实现,增删快)
LinkedList<String> linked = new LinkedList<>();
linked.addFirst("First"); // 头部插入

2. Set系列

// HashSet(无序唯一)
Set<Integer> set = new HashSet<>();
set.add(5); // 自动去重

// TreeSet(排序唯一)
Set<String> treeSet = new TreeSet<>();
treeSet.add("Banana"); // 自动按字母排序

3. Map系列

// HashMap(键值对,快速查找)
Map<String, Integer> map = new HashMap<>();
map.put("age", 18);
map.get("age"); // → 18

// LinkedHashMap(保持插入顺序)
Map<String, Integer> linkedMap = new LinkedHashMap<>();

​​关键区别​​:

特点使用场景
ArrayList随机访问快,增删慢高频查询操作
LinkedList增删快,查询慢需要频繁插入/删除
HashMap快速查找,无序常规键值存储
TreeMap按键排序需要有序遍历

四、数学工具类

1. Math类

Math.abs(-5);     // 绝对值 →5
Math.ceil(3.2);   // 向上取整 →4.0
Math.floor(3.8);  // 向下取整 →3.0
Math.random();    // 生成0-1随机数

2. BigDecimal(精确计算)

BigDecimal a = new BigDecimal("0.1");
BigDecimal b = new BigDecimal("0.2");
a.add(b); // 0.3(避免double精度丢失问题)

五、输入输出类

1. Scanner(控制台输入)

Scanner sc = new Scanner(System.in);
System.out.print("输入数字:");
int num = sc.nextInt();

2. File类(文件操作)

File file = new File("test.txt");
file.exists();  // 检查文件是否存在
file.length();  // 获取文件大小(字节)

六、比较器

1.Java比较器的使用背景

Java中的对象,正常情况下,只能进行比较:== 或 !=。不能使用>或<
但在开发场景中,需要对多个对象进行排序,言外之意,就需要比较对象的大小。
如何实现?使用两个接口中的任何一个:Comparable(自然排序)或者Comparator(定制排序)

2.自然排序:使用Comparable接口

2.1说明

在这里插入图片描述

在这里插入图片描述

2.2代码举例

package com.holly.java;
/**
 * @author holly
 * @create 2025-05-01 17:18
 */
public class Goods implements Comparable{
    private String name;
    private double price;

    public Goods(){

    }

    public Goods(String name, double price) {
        this.name = name;
        this.price = price;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public double getPrice() {
        return price;
    }

    public void setPrice(double price) {
        this.price = price;
    }

    @Override
    public String toString() {
        return "Goods{" +
                "name='" + name + '\'' +
                ", price=" + price +
                '}';
    }

    //指明商品比较大小的方式:按照价格从低到高排序,再按照产品名称从低到高排序
    @Override
    public int compareTo(Object o) {
        if(o instanceof Goods){
            Goods goods = (Goods) o;
            //方式一
            if(this.price > goods.price){
                return 1;
            }else if(this.price < goods.price){
                return -1;
            }else{
                //return 0;
                //从低到高
                //return this.name.compareTo(goods.name);
                //从高到低
                return -this.name.compareTo(goods.name);
            }
            //方式二
            //return Double.compare(this.price, goods.price);
        }
        //return 0;
        throw new RuntimeException("传入的数据类型不一致");
    }
}
/*
Comparable接口的使用举例:自然排序
1、像String、包装类等实现了Comparable接口,重写了compareTo(obj)方法,给出了比较两个对象大小的方式。
2、像String、包装类等重写了compareTo()方法以后,进行了从小到大的排列
3、重写compareTo(obj)的规则:
    如果当前对象this大于形参对象obj,则返回正整数;
    如果当前对象this小于形参对象obj,则返回负整数;
    如果当前对象this等于形参对象obj,则返回零。
4、对于自定义类来说,如果需要排序,我们可以让自定义类实现Comparable接口,重写compareTo()
在compareTo(obj)方法中指明如何排序。

 */
@Test
public void test1(){
    String[] arr = new String[]{"AA","CC","KK","MM","GG","JJ","DD"};
    //
    Arrays.sort(arr);
    System.out.println(Arrays.toString(arr));
}

@Test
public void test2(){
    Goods[] arr = new Goods[5];
    arr[0] = new Goods("联想", 34);
    arr[1] = new Goods("W软", 43);
    arr[2] = new Goods("小米", 12);
    arr[3] = new Goods("华为", 65);
    arr[4] = new Goods("De尔", 43);
    Arrays.sort(arr);
    System.out.println(Arrays.toString(arr));
}

3.定制排序:使用Comparator接口

2.1说明

在这里插入图片描述

2.2代码举例

/*
Comparator接口的使用:定制使用
1.背景
当元素的类型没有实现java.lang.Comparable接口而又不方便修改代码
或者实现了java.lang.Comparable接口的排序规则不适合当前的操作,
那么可以考感使用 comparator 的对象来排序
2.重写compare(Object o1,Object o2)方法,比较o1种o2的大小:
如果方法返回正整数,则表示o1大于o2;
如果返回0,表示相等;
返回负整数,表示o1小于o2。
 */
@Test
public void test3(){
    String[] arr = new String[]{"AA","CC","KK","MM","GG","JJ","DD"};
    Arrays.sort(arr,new Comparator(){
        @Override
        public int compare(Object o1, Object o2) {
            if(o1 instanceof String && o2 instanceof String){
                String s1 = (String)o1;
                String s2 = (String)o2;
                //从大到小排序
                return -s1.compareTo(s2);
            }
            //return 0;
            throw new RuntimeException("输入的数据类型不一致!");
        }
    });
    System.out.println(Arrays.toString(arr));
}

@Test
public void test4(){
    Goods[] arr = new Goods[6];
    arr[0] = new Goods("L想", 34);
    arr[1] = new Goods("W软", 43);
    arr[2] = new Goods("X米", 12);
    arr[3] = new Goods("H为", 65);
    arr[4] = new Goods("De尔", 43);
    arr[5] = new Goods("H为", 224);
    Arrays.sort(arr,new Comparator(){

        //指明商品比较大小的方式:按照产品名称从低到高排序,再按照价格从高到低排序
        @Override
        public int compare(Object o1, Object o2) {
            if(o1 instanceof Goods && o2 instanceof Goods){
                Goods goods1 = (Goods)o1;
                Goods goods2 = (Goods)o2;
                if(goods1.getName().equals(goods2.getName())){
                    return -Double.compare(goods1.getPrice(),goods2.getPrice());
                }else{
                    return goods1.getName().compareTo(goods2.getName());
                }
            }
            throw new RuntimeException("传入的数据格式不一致!");
        }
    });
    System.out.println(Arrays.toString(arr));
}

七、记忆要点总结

1.字符串三原则​​:

  • 少量修改用String
  • 频繁修改单线程用StringBuilder
  • 多线程用StringBuffer

​​2.日期新老对比​​:

  • 旧版Date易错
  • 新版LocalDateTime更安全

3.​​集合框架核心​​:

  • List:允许重复,有序
  • Set:元素唯一
  • Map:键值对存储

​​4.数学计算​​:

  • 常规计算用Math
  • 精确计算必须用BigDecimal

5.比较器

  • Comparable接口的方式一旦写好,保证Comparable接口实现类的对象在任何位置都可以比较大小。
  • Comparator接口属于临时性的比较。

​​八、实战技巧​​

  • 集合初始化时指定容量(如new ArrayList<>(100))可提升性能
  • 遍历Map推荐使用entrySet:
for (Map.Entry<String, Integer> entry : map.entrySet()) {
    System.out.println(entry.getKey() + ": " + entry.getValue());
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2373154.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

C++STL——priority_queue

优先队列 前言优先队列仿函数头文件 前言 本篇主要讲解优先队列及其底层实现。 优先队列 优先队列的本质就是个堆&#xff0c;其与queue一样&#xff0c;都是容器适配器&#xff0c;不过优先队列是默认为vector实现的。priority_queue的接口优先队列默认为大根堆。 仿函数 …

深入解析WPF中的3D图形编程:材质与光照

引言 在Windows Presentation Foundation (WPF) 中创建三维(3D)图形是一项既有趣又具有挑战性的任务。为了帮助开发者更好地理解如何使用WPF进行3D图形的渲染&#xff0c;本文将深入探讨GeometryModel3D类及其相关的材质和光源设置。 1、GeometryModel3D类简介 GeometryMode…

SolidWork-2023 鼠標工程

地址 https://github.com/MartinxMax/SW2023-Project/tree/main/mouse 鼠標

vscode预览模式(点击文件时默认覆盖当前标签,标签名称显示为斜体,可通过双击该标签取消)覆盖标签、新窗打开

文章目录 VS Code 预览模式如何取消预览模式&#xff08;即“固定”标签页&#xff09;&#xff1f;预览模式有什么用&#xff1f; VS Code 预览模式 在 VS Code 中&#xff0c;当你单击文件浏览器&#xff08;例如&#xff0c;资源管理器侧边栏&#xff09;中的某个文件时&am…

记录踩过的坑-金蝶云苍穹平台-轻分析和轻报表(慢慢更新)

未发现AppIdName(qing rpt)服务或访问服务网络异常 前提是有许可和权限。 去console&#xff08;云基础平台控制台&#xff09;&#xff0c;点击服务管理&#xff0c;编辑mservice-更新升级-环境变量&#xff0c;在appIds里增加qing_rpt 查看数据库 如果是采用公共数据源连接…

每日一题洛谷T534125 合数c++

字符串输入&#xff0c;看所有位数加起来的数是不是3的倍数 是&#xff0c;直接输出&#xff0c;不是&#xff0c;删除1或2 特判全是1和全是2的情况 直接检测末尾数字可以特判2 特判1时&#xff0c;还要特判11和111&#xff0c;其他数字&#xff0c;k是奇数时是质数&#x…

数据链共享:从印巴空战到工业控制的跨越性应用

摘要 本文通过对印巴空战中数据链共享发挥关键作用的分析&#xff0c;引出数据链共享在工业控制领域同样具有重大价值的观点。深入阐述 DIOS 工业控制操作系统作为工业数据链共享基础技术的特点、架构及应用优势&#xff0c;对比空战场景与工业控制场景下数据链共享的相…

图解gpt之Seq2Seq架构与序列到序列模型

今天深入探讨如何构建更强大的序列到序列模型&#xff0c;特别是Seq2Seq架构。序列到序列模型&#xff0c;顾名思义&#xff0c;它的核心任务就是将一个序列映射到另一个序列。这个序列可以是文本&#xff0c;也可以是其他符号序列。最早&#xff0c;人们尝试用一个单一的RNN来…

Linux--JsonCpp

1.JsonCpp 简介 JsonCpp 是一个用于 C 的 JSON 解析和生成库&#xff0c;支持 JSON 数据的读写、解析和序列化。它提供了简单的 API 来操作 JSON 对象、数组、字符串、数字等类型&#xff0c;是 C 开发中处理 JSON 数据的常用工具。 核心功能与类 JsonCpp 主要包含以下核心类…

如何利用 QuickAPI 生成 PostgreSQL 样本测试数据:全面解析与实用指南

目录 一、什么是 QuickAPI&#xff1f; 二、为什么需要生成样本测试数据&#xff1f; 三、如何在 QuickAPI 中生成 PostgreSQL 样本测试数据&#xff1f; 1. 登录 QuickAPI 平台 2. 选择 PostgreSQL 数据库和目标表 3. 配置样本数据生成规则 4. 导出或直接插入数据 四、…

DeepSeek API接口调用示例(开发语言C#,替换其中key值为自己的key值即可)

示例&#xff1a; DeepSeek官方接口说明文档&#xff1a;对话补全 | DeepSeek API Docs 官网暂未提供C#代码实现&#xff1a;&#xff08;以下为根据CURL接口C#代码调用&#xff09; using System; using System.Collections.Generic; using System.Linq; using System.Text; …

远程调试---在电脑上devtools调试运行在手机上的应用

1、启动项目–以vite项目为例:先ipconfig查看ip地址 ,然后在vite中配置host为ip地址 2、手机上查看项目:保证手机和电脑在同一局域网, 在手机浏览器打开我们vite启动的项目地址, 3、使用chii进行远程调试 (1) 安装 npm install chii -g (2)启动 chii start -p 8080 (3)在…

[git]如何关联本地分支和远程分支

主题 本文总结如何关联git本地分支和远程分支的相关知识点。 详情 查看本地分支 git branch 查看远程分支 git branch -r 查看所有分支(本地远程) git branch -a 查看本地分支及其关联的远程分支(如有) git branch -vv 关联本地分支到远程分支&#xff1a; git branch …

跨境电商生死局:动态IP如何重塑数据生态与运营效率

凌晨三点的深圳跨境电商产业园&#xff0c;某品牌独立站运营总监李明&#xff08;化名&#xff09;正盯着突然中断的广告投放系统。后台日志显示&#xff0c;过去24小时内遭遇了17次IP封禁&#xff0c;直接导致黑五促销期间损失23%的预期流量。这并非个案——2023年跨境电商行业…

springboot3+vue3融合项目实战-大事件文章管理系统-更新用户信息

在一下三个代码处进行修改 在UserController里面增加uadate方法 PutMapping ("/update")public Result update(RequestBody Validated User user){userService.update(user);return Result.success();}在userservice中增加update方法 void update(User user); 然…

气象大模型光伏功率预测中的应用:从短期,超短期,中长期的实现与开源代码详解

1. 引言 光伏功率预测对于电力系统调度、能源管理和电网稳定性至关重要。随着深度学习技术的发展,大模型(如Transformer、LSTM等)在时间序列预测领域展现出强大能力。本文将详细介绍基于大模型的光伏功率预测方法,涵盖短期(1-6小时)、超短期(15分钟-1小时)和中长期(1天-1周…

深度学习:智能车牌识别系统(python)

这是一个基于opencv的智能车牌识别系统,有GUI界面。程序能自动识别图片中的车牌号码,并支持中文和英文字符识别,支持选择本地图片文件,支持多种图片格式(jpg、jpeg、png、bmp、gif)。 下面,我将按模块功能对代码进行分段说明: 1. 导入模块部分 import tkinter as tk…

DNS服务实验

该文章将介绍DNS服务的正向和反向解析实验、主从实验、转发服务器实验以及Web解析实验 正向解析实验&#xff1a;将域名解析为对应的IP地址 反向解析实验&#xff1a;将IP地址解析为对应的域名 主从实验&#xff1a;主服务器区域数据文件发送给从服务器&#xff0c;从服务器…

visual studio 2015 安装闪退问题

参考链接&#xff1a; VS2012安装时启动界面一闪而过问题解决办法 visual studio 2015 安装闪退问题

C语言复习--动态内存管理

下面我们来看C语言中的动态内存管理,在之后的数据结构中会运用到C语言中的指针,结构体和动态内存管理,所以这部分还是比较重要的.下面进入正题. 为什么要有动态内存分配 但是上面的两种方式开辟的内存的大小都是固定的.数组也是,在数组开辟之前一定要确定好数组大小,并且数组开…