常用的辅助类2(StringBuilder、StringBuffer、处理时间相关的类、对象比较器)

news2025/1/26 14:40:09

Java知识点总结:想看的可以从这里进入

目录

      • 7.7、字符串相关类
      • 7.8、时间处理
        • 7.8.1、JDK8前
        • 7.8.2、JDK8后
          • 1、时间日期类
          • 2、格式化日期
          • 3、其他
      • 7.9、对象比较器

7.7、字符串相关类

  1. String:JDK1.0出现,字符串类,被final修饰其值不可改。实现了Serializable和Comparable接口,可支持序列化和可以比较大小;创建后栈中保存一个地址的引用,每次改变的值都是重新分配一个新的内存地址赋值,而不是在原有的地址内修改。

  2. StringBuilder:JDK 5.0出现,字符串类,其值可修改,线程不安全,但是速度最快。

  3. StringBuffer:JDK1.0:JDK1.0出现,字符串类,其值可修改,线程安全,速度相对StringBuilder慢。

    //三种构造方法
    StringBuffer():初始容量为16的字符串缓冲区
    StringBuffer(int size):构造指定容量的字符串缓冲区
    StringBuffer(String str):将内容初始化为指定字符串内容
    

当三者作为方法参数传递的话,方法内部String不会改变其值,StringBuffer和StringBuilder会改变其值。

StringBuilder和StringBuffder的底层是一个字符数组,根据无参构造创建后的可扩容长度为16个字符(接受字符串的构造长度为字符串长度+16、也可指定初始长度),

image-20230207201907695

如果添加字符串过程中超出数组范围,就会对底层数组进行扩容,首先创建一个新的数组大小为原来的2倍加2,将原数组中的内容复制到新数组中,再将指针指向新创建的数组地址。

  1. jdk16以前的扩容方法:

    image-20230208162243203
  2. jdk16以后的扩容方法

    image-20230208162256706

StringBuilder和StringBuffder提供的方法基本类似:

StringBuilderStringBuffder常用方法:
1、增:拼接字符串   .append("").append("").....;
2、删:删除指定范围的内容[start,end)     .delete(int start,int end)
3、改:替换指定范围的内容[start,end)    .replace(int start, int end, String str)
       修改指定索引处的字符:public void setCharAt(int n ,char ch) 
4、插:在指定位置插入指定的内容      .insert(int offset, "")
5、查:获取指定索引处的字符     public char charAt(int n ) 
6、返回指定子字符串在当前字符串中第一次出现处的索引:public int indexOf(String str) 
7、截取字符串[start,end)public String substring(int start,int end) 
8、返回字符串的长度:public int length() 
9、把当前字符序列逆转:.reverse() 

对比一下使用String和StringBuilder在速度上的区别

计算一下追加 100,000,0次字符所用的时间

  1. 使用String

    public static void main(String[] args) {
        long start = System.currentTimeMillis();
        String str = "";
        for(int i=0; i<1000000; i++){
            str += 1;
        }
        long end = System.currentTimeMillis();
        System.out.printf("使用String用时:%d",end-start);
    }
    
    image-20220226160636737
  2. 换成StringBuilder

    public static void main(String[] args) {
        long start = System.currentTimeMillis();
        StringBuilder builder = new StringBuilder();
        for(int i=0; i<1000000; i++){
            builder.append(1);
        }
        long end = System.currentTimeMillis();
        System.out.printf("使用StringBuilder用时:%d",end-start);
    }
    
    image-20220226160742055
  3. 使用StringBuffder

    public static void main(String[] args) {
        long start = System.currentTimeMillis();
        StringBuffer buffer = new StringBuffer();
        for(int i=0; i<1000000; i++){
            buffer.append(1);
        }
        long end = System.currentTimeMillis();
        System.out.printf("使用StringBuffer用时:%d",end-start);
    }
    
    image-20220226160914216

从上面可以明显的看出来使用String的时候相比较后两种速度慢的不是一点半点的,而是很多倍的差距了,而StringBuilder相比较StringBuffder也快了一些。

7.8、时间处理

7.8.1、JDK8前

  1. 计算时间差:

    System类提供的public static long currentTimeMillis()用来返回当前时间与1970年1月1日0时0分0秒之间以毫秒为单位的时间差。通常用来计算某个程序的运行时间,进行快慢的对比

    image-20230208165114161
  2. java.util.Date类

    image-20230208165852223 image-20230208170328080
  3. SimpleDateFormat类

    image-20230208174253255 image-20230208174323519
  4. Calendar类

    image-20230208183255047

    Calendar类中常用的常量字段如下:

    常量字段说明
    Calendar.ERAget和set的字段号,表示纪元,只能为0或1。0表示BC(“before Christ”,即公元前);1表示AD(拉丁语“Anno Domini”,即公元)。
    Calendar.YEAR用于get和set的字段号,表示年份
    Calendar.MONTH用于get和set的字段号,表示月份,0表示1月,1表示2月………
    Calendar.WEEK_OF_YEAR`用于get和set的字段号,一年中的星期数,即本年中第几个星期
    Calendar.WEEK_OF_MONTH用于get和set的字段号,当前月中的星期数,即本月中第几个星期
    Calendar.DAY_OF_YEAR用于get和set的字段号,一年中第几天
    Calendar.DAY_OF_WEEK用于get和set的字段号,一周中第几天,注意,周日是1,周一是2,…
    Calendar.DAY_OF_WEEK_IN_MONTHget和set的字段号,表示当前月份中的星期几
    Calendar.DATE用于get和set的字段号,一月中第几天,同DAY_OF_MONTH的值是一样的
    Calendar.HOUR小时(12小时制)
    Calendar.AM_PM用于get和set的字段号,用于指示HOUR是在中午之前还是在中午之后。在中午12点之前返回0,在中午12点(包括12点)之后返回1
    Calendar.HOUR_OF_DAY一天中第几个小时(24小时制)
    Calendar.MINUTE分钟
    Calendar.SECOND
    Calendar.MILLISECOND毫秒
    AY_OF_MONTH一月中第几天
    Calendar.DAY_OF_WEEK_IN_MONTH当前月中的第几个星期
    Calendar.JANUARY1月
    Calendar.FEBRUARY2月
    Calendar.MARCH3月
    Calendar.APRIL4月
    Calendar.MAY5月
    Calendar.JUNE6月
    Calendar.JULY7月
    Calendar.AUGUST8月
    Calendar.SEPTEMBER9月
    Calendar.OCTOBER10月
    Calendar.NOVEMBER11月
    Calendar.DECEMBER12月
    public static void main(String[] args) throws ParseException {
        Calendar calendar = Calendar.getInstance();
        //查看是公元前(0)还是公元后(1)
        System.out.println("判断公元:"+calendar.get(Calendar.ERA));
        //获取月份:返回值+1
        System.out.println("获取月份:"+calendar.get(Calendar.MONTH));
        //将年份设置为1999
        calendar.set(Calendar.YEAR,1999);
        System.out.println("修改年份为1999:"+calendar.get(Calendar.YEAR));
        //将年份+1
        calendar.add(Calendar.YEAR,1);
        System.out.println("将年份+1:"+calendar.get(Calendar.YEAR));
        //返回Date格式日期
        System.out.println("获取date格式日期:"+calendar.getTime());
        //设置时间
        calendar.setTime(new Date("Tue Feb 08 18:29:23 CST 2222"));
        System.out.println("设置时间:"+calendar.getTime());;
    }
    
    image-20230208183334281

7.8.2、JDK8后

1、时间日期类

在JDK8以前,不论是Date类、还是Calendar类,都不是特别好用,所以时期时间问题一直都是一个让人头疼的问题。所以在JDK8中第三次引入了关于日期时间的API,新的 java.time 中包含了关于本地日期(LocalDate)、本地时间(LocalTime)、本地日期时间()、时区(ZonedDateTime)和持续时间(Duration)的类。而在 Date 类中新增了 toInstant() 方法,用于把 Date 转换成新的表示形式。

image-20230208190423351

image-20230208190507078

2、格式化日期

java.time.format.DateTimeFormatter 类:该类提供了三种格式化方法:

  1. 预定义的标准格式。如:ISO_LOCAL_DATE_TIME;ISO_LOCAL_DATE;ISO_LOCAL_TIME

    image-20230209095915704
  2. 本地化相关的格式。

    image-20230209101559398 image-20230209095643942
  3. 自定义的格式。如:ofPattern(“yyyy-MM-dd hh:mm:ss“)

//时间
LocalDateTime dateTime2 = LocalDateTime.of(1999, 12, 2, 12, 22, 22);
System.out.println(dateTime2);
//第一种格式化
DateTimeFormatter dateTimeFormatter1 = DateTimeFormatter.ISO_LOCAL_DATE_TIME;
String format1 = dateTimeFormatter1.format(dateTime2);
System.out.println(format1);
//第二种格式化
DateTimeFormatter dateTimeFormatter2 = DateTimeFormatter.ofLocalizedDateTime(FormatStyle.SHORT);
String format2 = dateTimeFormatter2.format(dateTime2);
System.out.println(format2);
//第三种格式化
DateTimeFormatter dateTimeFormatter3 = DateTimeFormatter.ofPattern("yyyy-MM-dd hh:mm:ss");
String format3 = dateTimeFormatter3.format(dateTime2);
System.out.println(format3);

image-20230209101748401

3、其他
  1. ZoneId:包含了所有的时区信息

    image-20230209102625646
  2. ZonedDateTime:根据时区获取时间

    image-20230209102742064
  3. Cloc:使用时区提供对当前即时、日期和时间的访问的时钟。

  4. TemporalAdjuster :时间校正器。

  5. Period:用于计算两个日期的间隔

  6. Duration:计算两个时间的间隔

7.9、对象比较器

在Java中经常会涉及到对象排序问题(比如买东西时,可以选择根据价格排序),这就会涉及到对象之间的比较,Java实现对象排序的方式有两种:

  1. 自然排序:java.lang.Comparable接口,可以对实现它的每个类的对象进行整体排序。默认从小到大。

    像String、包装类等等都实现Comparable接口,其中字符的比较是Unicode值,数值是直接比较数值。数组、对象列表可以通过Collections.sort 或Arrays.sort进行自动排序

    image-20230209104345503

    image-20230209195346962

    我们自定义的类也可以实现Comparable接口,重写compareTo(Object obj)方法,写明比较的规则。

    1. 类实现Comparable接口
    2. 实现接口的compareTo(Object obj) 方法,通过此方法对比两个对象的大小(如果当前对象this大于形参对象,则返回正整数,如果当前对象this小于形参对象,则返回负整数,如果当前对象this等于形参对象,则返回零。)
  2. 定制排序:java.util.Comparator接口,当没有实现java.lang.Comparable接口而又不方便修改代码,或者实现了java.lang.Comparable接口的排序规则不适合当前的操作,那么可以考虑使用Comparator的对象来排序,强行对多个对象进行整体排序的比较。

    重写compare(Object o1,Object o2)方法,比较o1和o2的大小:如果方法返回正整数,则表示o1大于o2;如果返回0,表示相等;返回负整数,表示o1小于o2。

    1. 首先使用匿名内部类的形式创建 Comparator 对象,然后重写compare方法

      image-20230209201040765
    2. 将 Comparator 传递给 sort 方法(如 Collections.sort 或 Arrays.sort),从而允许在排序顺序上实现精确控制。

      image-20230209201316104

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

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

相关文章

30个HTML+CSS前端开发案例(三)

30个HTMLCSS前端开发案例&#xff08;11-15&#xff09;小米上称右侧悬浮菜单实现代码效果图自动轮播图效果实现代码效果图小米商城二级下拉菜单效果实现代码效果图时间轴效果实现代码效果图QQ音乐排行榜效果实现代码效果图资源包获取小米上称右侧悬浮菜单 实现代码 <!DOC…

idea中使用Git

目录 一、在idea中配置Git 1、打开settings&#xff0c;搜索git&#xff0c;找到本地上的git安装目录&#xff0c;选择git.exe 2、本地git安装目录 二、获取Git 1、本地初始化仓库 2、选中项目这层目录&#xff0c;点击确定 2、从远程仓库克隆 三、本地仓库操作 1、将文…

阶段二4_常用API之StringBuilder

一. StringBuilder类概述 概述 : StringBuilder 是一个可变的字符串类&#xff0c;我们可以把它看成是一个容器&#xff0c;这里的可变指的是 StringBuilder 对象中的内容是可变的。 作用&#xff1a; 提高供字符串的操作效率 案例&#xff1a; /**证明StringBuilder提高供字…

api接口详解大全(看这篇就足以了)

api接口详解大全?优秀的设计是产品变得卓越的原因设计API意味着提供有效的接口&#xff0c;可以帮助API使用者更好地了解、使用和集成&#xff0c;同时帮助人们有效地维护它每个产品都需要使用手册&#xff0c;API也不例外在API领域&#xff0c;可以将设计视为服务器和客户端之…

函数/任意波形发生器 DG5072 技术资料

函数/任意波形发生器 DG5072 DG5000人性化的界面设计和键盘布局&#xff0c;给用户带来非凡体验&#xff1b;丰富的标准配置接口&#xff0c;可轻松实现仪器远程控制&#xff0c;为用户提供更多解决方案。 产品特性 4.3英寸16M真彩TFT液晶显示屏 350 MHz、250MHz、100 MHz或70…

Pacemaker详解、pcs命令详解和参数说明、centos8或bclinux8.2离线安装pcs以及搭建pcs、pcs的使用说明

文章目录Pacemaker详解一、前言二、 Pacemaker概述1、Pacemaker介绍2、pacemaker的服务模式。3、Pacemaker的架构4、Pacemake内部组件三、Pacemaker集群管理工具pcspcs说明最为常用的管理命令四、Pacemaker集群资源管理1、集群资源代理常用的命令方法2、集群资源约束3、集群资源…

国家政策鼓励使用电子保函和银行函证,君子签助推函证数字化建设

近日&#xff0c;国家发改委发文&#xff0c;推动电子保函应用&#xff0c;降低电子保函费用&#xff1b;财政部会同银保监会发文&#xff0c;开展数字化函证&#xff0c;有效提升函证效率和效果。政策的出台有助于加快推进普及电子函证应用。 发改委&#xff1a;鼓励使用电子…

PMP考试前两个月开始备考时间足够吗?

简单不代表报名费便宜&#xff0c;但报名费贵是肯定会难的&#xff0c;不然从何而来的含金量一说&#xff1f;花钱就能买到的话估计现在全中国持有pmp的一抓一大把。 时间完全足够的。 相信很多朋友都了解过&#xff0c;pmp的备考时间基本上是在2~3个月&#xff0c;2个月最为…

shell的变量和引用

文章目录二、变量和引用2.1 什么是变量2.2变量的命名2.3 变量的类型2.3.1 根据数据类型分类2.3.2 根据作用域分类2.4 变量的定义2.5 shell中的引用2.6 变量的运算练习&#xff1a;二、变量和引用 在程序设计语言中&#xff0c;变量是一个非常重要的概念。也是初学者在进行Shel…

计讯物联智慧灯杆网关数字赋能智慧公园,点亮城市新未来

方案背景 …… 公园作为城市景观与生态要素的空间载体&#xff0c;是市民远离尘嚣、缓解压力的理想休闲地。随着人们生活水平的提高&#xff0c;公园的信息化与智能化成为公园建设的必然方向。计讯物联依托于物联网技术&#xff0c;以绿色发展理念为指导&#xff0c;充分考虑…

/proc/cpuinfo详解

在分析该文件输出之前&#xff0c;我们先理解下几个重要的概念&#xff1a;物理CPU、CPU核心数、逻辑CPU。 物理CPU数&#xff08;physical id&#xff09;&#xff1a;主板上实际插入的cpu数量&#xff0c;不重复的 physical id 有几个就有多少个物理CPU。 CPU核心数&#xf…

95. 不同的二叉搜索树 II

95. 不同的二叉搜索树 II题目算法设计&#xff1a;深度优先搜索题目 传送门&#xff1a;https://leetcode.cn/problems/unique-binary-search-trees-ii/ 算法设计&#xff1a;深度优先搜索 二叉树子问题分解 根节点 左右子树的子问题。 根节点的子问题&#xff1a;循环历遍…

高压放大器由哪些部分组成?如何验证它性能的好坏?

虽然很多电子工程师经常使用高压放大器&#xff0c;但是对于高压功率放大器的组成和使用都不太清楚&#xff0c;下面由安泰测试给大家介绍高压放大器的组成部分以及如何验证功率放大器的性能好坏。 一、高压放大器的介绍 高压放大器是一种理想的功率放大器&#xff0c;可以放…

企业版快速开发框架源码 Spring Cloud快速开发脚手架源码

一款 Java 语言基于Spring Cloud Alibaba、SpringBoot、Mybatis、Seata、Sentinel、RabbitMQ、FastDFS/MinIO、SkyWalking等主要框架和中间件&#xff0c;精心打造的一款模块化、插件化、高性能的快速开发框架&#xff0c;可用于快速搭建后台管理系统。 私信了解更多&#xff…

(九)docker复杂安装-安装mysql主从复制

目录 前提&#xff1a; 一、新建主服务器容器实例3307 二、进入/mydata/mysql-master/conf目录下新建my.cnf 三、修改完配置后重启master实例 四、进入mysql-master容器并测试 五、master容器实例内创建数据同步用户 六、新建从服务器容器实例3308 七、进入/mydata/mys…

提取接近竖直物体(粗定位)

由于项目的需要提取图像之中的一个接近于竖直的物体&#xff0c;一般的方法是进行图像分割&#xff0c;分割方式使用什么OTSU方式以及hsv方法等等。但是项目中使用的相机是黑白相机&#xff0c;会受到一定的限制。因此想到的是使用线条提取方式。线条提取方式之中最好的方法是使…

102-并发编程详解(中篇)

这里续写上一章博客 Phaser新特性 &#xff1a; 特性1&#xff1a;动态调整线程个数 CyclicBarrier 所要同步的线程个数是在构造方法中指定的&#xff0c;之后不能更改&#xff0c;而 Phaser 可以在运行期间动态地 调整要同步的线程个数&#xff0c;Phaser 提供了下面这些方…

Quantum 构建工具使用新的 TTP 投递 Agent Tesla

Zscaler 的研究人员发现暗网上正在出售名为 Quantum Builder 的构建工具&#xff0c;该工具可以投递 .NET 远控木马 Agent Tesla。与过去的攻击行动相比&#xff0c;本次攻击转向使用 LNK 文件。 Quantum Builder 能够创建恶意文件&#xff0c;如 LNK、HTA 与 PowerShell&…

clickhouse集群安装

单机安装 yum install yum-utilsrpm --import https://repo.clickhouse.com/CLICKHOUSE-KEY.GPGyum-config-manager --add-repo https://repo.clickhouse.com/rpm/clickhouse.reposudo yum install clickhouse-server clickhouse-client 配置文件 vim /etc/clickhouse-serve…

FFmpeg集成qsv的编译安装

文章目录FFmpeg集成qsv的编译安装一、参考二、编译安装流程1. LibVA 和 Media-Driver 的安装2. Intel Media SDK 编译3. ffmpeg的编译安装4. 验证安装FFmpeg集成qsv的编译安装 一、参考 Ubuntu20.04 ffmpeg添加 Intel核显QSV加速支持 视频和视频帧&#xff1a;Intel GPU&…