为什么idea建议使用“+”拼接字符串

news2024/9/24 15:18:40

今天在敲代码的时候,无意间看到这样一个提示:

英文不太好,先问问ChatGPT,这个啥意思?

IDEA 提示你,可以将代码中的 StringBuilder 替换为简单的字符串连接方式。

提示信息中说明了使用 StringBuilder 进行字符串拼接在现代 JVM 中并不一定比使用 String 连接有显著的性能优势,尤其是对于简单的字符串拼接操作,直接使用 String 连接可能更加简洁明了。

可以被替换为:

String str = "哪吒编程" + "study" + "ChatGPT4o";

这样可以使代码更简洁,同时在大多数情况下不会对性能产生明显的负面影响。

IDEA 提供了自动替换的选项,点击提示框中的 “Replace ‘StringBuilder’ with ‘String’” 即可自动进行替换。

👉 GPT功能:

  1. GPT-4o知识问答:支持1000+token上下文记忆功能
  2. 最强代码大模型Code Copilot:代码自动补全、代码优化建议、代码重构等
  3. DALL-E AI绘画:AI绘画 + 剪辑 = 自媒体新时代
  4. 私信哪吒,直接使用GPT-4o

在这里插入图片描述

实际上,从JDK1.5开始,Java编译器就做了自动优化,使用“+”拼接字符串,编译器编译后自动优化为使用StringBuilder。

做一个小测试,拼接10000个"哪吒编程" + "study" + "ChatGPT4o",看下使用“+”拼接字符串和使用StringBuilder,哪个速度快。

public class StringTest {
    public static void main(String[] args) throws IOException {
//        long timeSum = 0;
//        for (int i = 0; i < 3; i++) {
//            timeSum += spliceStrByAdd();
//        }
//        System.out.println("使用+拼接字符串平均耗时: " + timeSum/3 +"毫秒");

        long timeSum = 0;
        for (int i = 0; i < 3; i++) {
            timeSum += spliceStrByBuilder();
        }
        System.out.println("使用StringBuilder拼接字符串平均耗时: " + timeSum / 3 + "毫秒");
    }

    private static final int n = 10000;

    /**
     * 使用+拼接字符串
     *
     * @return
     */
    private static long spliceStrByAdd() {
        Instant start = Instant.now();
        String ret = "";
        for (int i = 0; i < n; i++) {
            ret += "哪吒编程" + i;
            ret += " study" + i;
            ret += " ChatGPT4o" + i;
        }

        Instant end = Instant.now();
        Duration elapsed = Duration.between(start, end);
        long time = elapsed.toMillis();
        System.out.println("使用+拼接字符串耗时: " + time + "毫秒");
        return time;
    }

    /**
     * 使用StringBuilder拼接字符串
     */
    private static long spliceStrByBuilder() {
        Instant start = Instant.now();
        StringBuilder builder = new StringBuilder();
        for (int i = 0; i < n; i++) {
            builder.append("哪吒编程").append(i);
            builder.append(" study").append(i);
            builder.append(" ChatGPT4o").append(i);
        }

        Instant end = Instant.now();
        Duration elapsed = Duration.between(start, end);
        long time = elapsed.toMillis();
        System.out.println("使用StringBuilder拼接字符串耗时: " + time + "毫秒");
        return time;
    }
}

这差距还真是巨大,相差1000倍,Idea给的提示这不是胡扯嘛?

上面还说,jdk1.5开始,+在编译时自动优化为StringBuilder,现在我用jd-gui对class文件进行反编译,查看编译后的代码差异。

这个时候,很多杠精就该站出来了,你这测试有问题,不能这么干

你这循环拼接10000次,通过+拼接时,你就创建了10000个字符串,你这测试的并不是纯+拼接耗时!!!

好像说的有点道理~

public class StringTest2 {
    public static void main(String[] args) throws IOException {
        long timeSum = 0;
        for (int i = 0; i < 3; i++) {
            timeSum += spliceStrByAdd();
        }
        System.out.println("使用+拼接字符串平均耗时: " + timeSum/3 +"毫秒");

        timeSum = 0;
        for (int i = 0; i < 3; i++) {
            timeSum += spliceStrByBuilder();
        }
        System.out.println("使用StringBuilder拼接字符串平均耗时: " + timeSum / 3 + "毫秒");
    }

    private static final int n = 10000;

    /**
     * 使用+拼接字符串
     *
     * @return
     */
    private static long spliceStrByAdd() {
        Instant start = Instant.now();
        for (int i = 0; i < n; i++) {
            String ret = "哪吒编程" + i + " study" + i+" ChatGPT4o" + i;
        }

        Instant end = Instant.now();
        Duration elapsed = Duration.between(start, end);
        long time = elapsed.toMillis();
        System.out.println("使用+拼接字符串耗时: " + time + "毫秒");
        return time;
    }

    /**
     * 使用StringBuilder拼接字符串
     */
    private static long spliceStrByBuilder() {
        Instant start = Instant.now();
        for (int i = 0; i < n; i++) {
            StringBuilder builder = new StringBuilder();
            builder.append("哪吒编程").append(i);
            builder.append(" study").append(i);
            builder.append(" ChatGPT4o").append(i);
        }

        Instant end = Instant.now();
        Duration elapsed = Duration.between(start, end);
        long time = elapsed.toMillis();
        System.out.println("使用StringBuilder拼接字符串耗时: " + time + "毫秒");
        return time;
    }
}

使用+和StringBuilder单独拼接字符串时,效率上确实差不多少!

也就是说,在拼接少量字符串的时候,使用+也是可以的,Idea的提示还是有点道理的!

我把这两个class和idea提示截图直接传给ChatGPT,看它怎么看待这个问题。

ChatGPT,牛笔!

👉 GPT功能:

  1. GPT-4o知识问答:支持1000+token上下文记忆功能
  2. 最强代码大模型Code Copilot:代码自动补全、代码优化建议、代码重构等
  3. DALL-E AI绘画:AI绘画 + 剪辑 = 自媒体新时代
  4. 私信哪吒,直接使用GPT-4o

在这里插入图片描述

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

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

相关文章

分布式相关理论详解

目录 1.绪论 2.什么是分布式系统&#xff0c;和集群的区别 3.CAP理论 3.1 什么是CAP理论 3.2 一致性 3.2.1 计算机的一致性说明 1.事务中的一致性 2.并发场景下的一致性 3.分布式场景下的一致性 3.2.2 一致性分类 3.2.3 强一致性 1.线性一致性 a) 定义 a) Raft算法…

数据危机!4大硬盘数据恢复工具,教你如何正确挽回珍贵记忆!

在这个数字化的时代&#xff0c;硬盘里的数据对我们来说简直太重要了。但糟糕的是&#xff0c;数据丢失这种事时不时就会发生&#xff0c;可能是因为不小心删了&#xff0c;硬盘坏了&#xff0c;或者中了病毒。遇到这种情况&#xff0c;很多人可能就慌了&#xff0c;不知道怎么…

鸿蒙(HarmonyOS)下拉选择控件

一、操作环境 操作系统: Windows 11 专业版、IDE:DevEco Studio 3.1.1 Release、SDK:HarmonyOS 3.1.0&#xff08;API 9&#xff09; 二、效果图 三、代码 SelectPVComponent.ets Component export default struct SelectPVComponent {Link selection: SelectOption[]priva…

模拟信号介绍

定义&#xff1a; 模拟信号是指用连续变化的物理量表示的信息&#xff0c;其信号的幅度、频率或相位随时间作连续变化&#xff0c;或在一段连续的时间间隔内&#xff0c;其代表信息的特征量可以在任意瞬间呈现为任意数值的信号。我们通常又把模拟信号称为连续信号&#xff0c;它…

挑战房市预测领头羊:KNN vs. 决策树 vs. 线性回归

挑战房市预测领头羊&#xff08;KNN&#xff0c;决策树&#xff0c;线性回归&#xff09; 1. 介绍1.1 K最近邻&#xff08;KNN&#xff09;&#xff1a;与邻居的友谊1.1.1 KNN的基础1.1.2 KNN的运作机制1.1.3 KNN的优缺点 1.2 决策树&#xff1a;解码房价的逻辑树1.2.1 决策树的…

AttributeError: ‘list‘ object has no attribute ‘text‘

AttributeError: ‘list‘ object has no attribute ‘text‘ 目录 AttributeError: ‘list‘ object has no attribute ‘text‘ 【常见模块错误】 【解决方案】 示例代码 欢迎来到英杰社区https://bbs.csdn.net/topics/617804998 欢迎来到我的主页&#xff0c;我是博主英…

前端三大主流框架Vue React Angular有何不同?

前端主流框架&#xff0c;Vue React Angular&#xff0c;大家可能都经常在使用&#xff0c;Vue React&#xff0c;国内用的较多&#xff0c;Angualr相对用的少一点。但是大家有思考过这三大框架的不同吗&#xff1f; 一、项目的选型上 中小型项目&#xff1a;Vue2、React居多…

人工智能AI合集:Ollama部署对话语言大模型-网页访问

目录 &#x1f345;点击这里查看所有博文 随着人工智能技术的飞速发展&#xff0c;AI已经不再是遥不可及的高科技概念&#xff0c;而是逐渐融入到我们的日常生活中。从智能手机的语音助手到家庭中的智能音箱&#xff0c;再到工业自动化和医疗诊断&#xff0c;AI的应用无处不在…

gitee设置ssh公钥密码避免频繁密码验证

gitee中可以创建私有项目&#xff0c;但是在clone或者push都需要输入密码&#xff0c; 比较繁琐。 公钥则可以解决该问题&#xff0c;将私钥放在本地&#xff0c;公钥放在gitee上&#xff0c;当对项目进行操作时带有的私钥会在gitee和公钥进行验证&#xff0c;避免了手动输入密…

港科夜闻 | 香港科大与阿里巴巴合作,计划成立大数据与人工智能联合实验室

关注并星标 每周阅读港科夜闻 建立新视野 开启新思维 1、香港科大与阿里巴巴合作&#xff0c;计划成立大数据与人工智能联合实验室。香港科大7月19日与阿里巴巴集团签署合作备忘录&#xff0c;计划成立「香港科技大学–阿里巴巴大数据与人工智能联合实验室」&#xff0c;就生成…

STM32-寄存器DMA配置指南

配置步骤 在STM32F0xx中文参考手册中的DMA部分在开头给出了配置步骤 每个通道都可以在外设寄存器固定地址和存储器地址之间执行 DMA 传输。DMA 传输的数据 量是可编程的&#xff0c;最大达到 65535。每次传输之后相应的计数寄存器都做一次递减操作&#xff0c;直到 计数为&am…

前后端分离的开发模式+YAPI接口文档

博客主页&#xff1a;音符犹如代码系列专栏&#xff1a;JavaWeb关注博主&#xff0c;后期持续更新系列文章如果有错误感谢请大家批评指出&#xff0c;及时修改感谢大家点赞&#x1f44d;收藏⭐评论✍ 早期的开发模式&#xff1a;前后端混合开发 在这种模式下开发下&#xff0c;…

数组和链表的区别

简介 从定义上讲: 数组和链表都是数据的集合。 1.数组中每个元素都是连续的&#xff0c;通过下标进行访问&#xff0c;当我们获取到下标后&#xff0c;就可以随意访问数组中的值 2.链表中的元素则是不连续的&#xff0c;必须获得链表中某个元素后&#xff0c;才能顺序访问该元…

便携气象站通常用在哪些地方?

推荐型号&#xff1a;TH-PQX5】便携气象站是一种设计轻便、易于携带的气象监测设备&#xff0c;主要用于提供实时气象数据&#xff0c;支持多种领域的应用&#xff0c;包括科研、农业生产、户外活动和应急气象监测等。以下是根据提供的参考资料对便携气象站的详细分析&#xff…

基于k8s快速搭建docker镜像服务的demo

基于k8s快速搭建docker镜像服务的demo 一、环境准备 如标题&#xff0c;你需要环境中有和2个平台&#xff0c;并且服务器上也已经安装好docker服务 接下来我来构建一个docker镜像&#xff0c;然后使用harbork8s来快速部署服务demo 二、部署概述 使用docker构建镜像&#x…

FPGA开发——呼吸灯的设计

一、原理 呼吸灯的原理主要基于‌PWM&#xff08;脉冲宽度调制&#xff09;技术&#xff0c;通过控制LED灯的占空比来实现亮度的逐渐变化。这种技术通过调整PWM信号的占空比&#xff0c;即高电平在一个周期内所占的比例&#xff0c;来控制LED灯的亮度。当占空比从0%逐渐变化到1…

springboot项目从jdk8升级为jdk17过程记录

背景&#xff1a;公司有升级项目jdk的规划&#xff0c;计划从jdk8升级到jdk11 开始 首先配置本地的java_home 参考文档&#xff1a;Mac环境下切换JDK版本及不同的maven-CSDN博客 将pom.xml中jdk1.8相关的版本全部改为jdk17&#xff0c;主要是maven编译插件之类的&#xff0c…

使用 MongoDB 向量搜索和 OpenAI 进行反洗钱和预防欺诈

使用 MongoDB Vector Search 和 OpenAI 进行反洗钱和预防欺诈 欺诈和反洗钱 (AML) 是企业和消费者的主要担忧&#xff0c;影响金融服务和电子商务等行业。解决这些问题的传统方法包括静态、基于规则的系统和预测人工智能 (AI) 方法&#xff0c;这些方法虽然有效&#xff0c;但也…

数据结构--单链表代码(王道书上代码手敲!!!)c++

目录 1.带头结点的初始化以及检查单链表是否为空 2.不带头结点的单链表初始化以及表是否为空检查 3.带头结点按位序插入 4.不带头结点的按位序插入 5.带头结点的后插&#xff0c;前插&#xff0c;按位删除&#xff0c;删除固定节点操作 6 不带头结点的后插&#xff0c;前…

算法 —— 暴力枚举

目录 循环枚举 P2241 统计方形&#xff08;数据加强版&#xff09; P2089 烤鸡 P1618 三连击&#xff08;升级版&#xff09; 子集枚举 P1036 [NOIP2002 普及组] 选数 P1157 组合的输出 排列枚举 P1706 全排列问题 P1088 [NOIP2004 普及组] 火星人 循环枚举 顾名思…