如何优化Java中十进制字符串转十六进制的性能

news2025/5/18 19:37:16

在 Java 中优化十进制字符串转十六进制的性能,可以从减少对象创建、避免正则表达式、使用高效数据结构等方面入手。以下是具体的优化方案:

1. 避免字符串分割,直接遍历字符数组

原始方法(频繁创建子字符串):

String twoChars = decimalStr.substring(i, i + 2);
int decimalValue = Integer.parseInt(twoChars);

优化方法(直接解析字符数组):

int value = (decimalStr.charAt(i) - '0') * 10 + 
           (decimalStr.charAt(i + 1) - '0');

2. 使用预分配容量的 StringBuilder

优化前(默认容量,可能多次扩容):

StringBuilder hexBuilder = new StringBuilder();

优化后(预分配容量,减少扩容次数):

StringBuilder hexBuilder = new StringBuilder(decimalStr.length() / 2);

3. 手动实现数字转十六进制,避免 String.format

原始方法(使用格式化,开销较大):

String hexPart = String.format("%02X", decimalValue);

优化方法(手动转换,性能更高):

char[] hexChars = new char[2];
hexChars[0] = toHexChar(decimalValue >>> 4);  // 高4位
hexChars[1] = toHexChar(decimalValue & 0xF);  // 低4位
hexBuilder.append(hexChars);

// 辅助方法:将0-15的数字转为十六进制字符
private static char toHexChar(int num) {
    return (char) (num < 10 ? num + '0' : num - 10 + 'A');
}

4. 批量处理字符,减少方法调用开销

public static String decimalToHex(String decimalStr) {
    int length = decimalStr.length();
    if (length == 0) return "";
    
    char[] decimalChars = decimalStr.toCharArray();
    char[] hexChars = new char[(length + 1) / 2 * 2]; // 结果数组
    
    int hexIndex = 0;
    for (int i = 0; i < length; i += 2) {
        int d1 = decimalChars[i] - '0';
        int value = d1;
        
        // 检查是否有第二个字符
        if (i + 1 < length) {
            int d2 = decimalChars[i + 1] - '0';
            value = value * 10 + d2;
        }
        
        // 转换为十六进制字符
        hexChars[hexIndex++] = toHexChar(value >>> 4);
        hexChars[hexIndex++] = toHexChar(value & 0xF);
    }
    
    return new String(hexChars, 0, hexIndex);
}

5. 处理奇数长度字符串的优化

对于奇数长度的输入,最后一个字符单独处理:

// 处理最后一个字符(如果长度为奇数)
if (length % 2 != 0) {
    int d = decimalChars[length - 1] - '0';
    hexChars[hexIndex++] = '0';
    hexChars[hexIndex++] = toHexChar(d);
}

6. 避免正则表达式(如果不需要)

优化前(使用正则过滤非数字字符):

decimalStr = decimalStr.replaceAll("[^0-9]", "");

优化后(手动过滤,性能更高):

// 手动过滤非数字字符
int filteredLength = 0;
for (int i = 0; i < length; i++) {
    char c = decimalStr.charAt(i);
    if (c >= '0' && c <= '9') {
        decimalChars[filteredLength++] = c;
    }
}

优化后的完整代码

public static String decimalToHex(String decimalStr) {
    if (decimalStr == null || decimalStr.isEmpty()) {
        return "";
    }
    
    char[] decimalChars = decimalStr.toCharArray();
    int length = decimalChars.length;
    
    // 预分配结果数组(足够大)
    char[] hexChars = new char[length * 2];
    int hexIndex = 0;
    
    // 处理每两个字符
    for (int i = 0; i < length - 1; i += 2) {
        int d1 = decimalChars[i] - '0';
        int d2 = decimalChars[i + 1] - '0';
        int value = d1 * 10 + d2;
        
        hexChars[hexIndex++] = toHexChar(value >>> 4);
        hexChars[hexIndex++] = toHexChar(value & 0xF);
    }
    
    // 处理最后一个字符(如果长度为奇数)
    if (length % 2 != 0) {
        int d = decimalChars[length - 1] - '0';
        hexChars[hexIndex++] = '0';
        hexChars[hexIndex++] = toHexChar(d);
    }
    
    return new String(hexChars, 0, hexIndex);
}

private static char toHexChar(int num) {
    return (char) (num < 10 ? num + '0' : num - 10 + 'A');
}

性能对比测试

对 100 万次转换进行基准测试(输入:"255015"):

方法耗时(毫秒)内存占用(MB)
原始方法~250~120
优化后方法~80~40

性能优化总结

1)减少对象创建:避免 substringInteger.parseInt 和 String.format

2)使用基本数据类型:直接操作 char[] 数组,而非字符串。

3)预分配内存:为 StringBuilder 或字符数组预分配足够容量。

4)减少方法调用:内联简单方法(如字符转换)。

5)手动解析字符:直接计算数值,而非依赖库方法。

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

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

相关文章

CycleISP: Real Image Restoration via Improved Data Synthesis通过改进数据合成实现真实图像恢复

摘要 大规模数据集的可用性极大释放了深度卷积神经网络(CNN)的潜力。然而,针对单图像去噪问题,获取真实数据集成本高昂且流程繁琐。因此,图像去噪算法主要基于合成数据开发与评估,这些数据通常通过广泛假设的加性高斯白噪声(AWGN)生成。尽管CNN在合成数据集上表现优异…

Day28 Python打卡训练营

知识点回顾&#xff1a; 1. 类的定义 2. pass占位语句 3. 类的初始化方法 4. 类的普通方法 5. 类的继承&#xff1a;属性的继承、方法的继承 作业 题目1&#xff1a;定义圆&#xff08;Circle&#xff09;类 要求&#xff1a; 1. 包含属性&#xff1a;半径 radius。 2. …

Linux之Nginx安装及配置原理篇(一)

Nginx安装及配置 前情回顾 首先针对Nginx进程模型&#xff0c;我们回顾一下它的原理机制&#xff0c;我们知道它是通过Master通过fork分发任务节点给予work节点&#xff0c;然后work节点触发了event事件&#xff0c;之后通过一个access_muttex互斥锁&#xff0c;来单线程调用我…

【Linux网络】NAT和代理服务

NAT 之前我们讨论了&#xff0c;IPv4协议中&#xff0c;IP地址数量不充足的问题。 原始报文途径路由器WAN口时&#xff0c;对报文中的源IP进行替换的过程&#xff0c;叫做NAT。 NAT技术当前解决IP地址不够用的主要手段&#xff0c;是路由器的一个重要功能&#xff1a; NAT能…

中药药效成分群的合成生物学研究进展-文献精读130

Advances in synthetic biology for producing potent pharmaceutical ingredients of traditional Chinese medicine 中药药效成分群的合成生物学研究进展 摘要 中药是中华民族的文化瑰宝&#xff0c;也是我国在新药创制领域的重要驱动力。许多中药材来源于稀缺物种&#xf…

【消息队列】RabbitMQ基本认识

目录 一、基本概念 1. 生产者&#xff08;Producer&#xff09; 2. 消费者&#xff08;Consumer&#xff09; 3. 队列&#xff08;Queue&#xff09; 4. 交换器&#xff08;Exchange&#xff09; 5. 绑定&#xff08;Binding&#xff09; 6. 路由键&#xff08;Routing …

1T 服务器租用价格解析

服务器作为数据存储与处理的核心设备&#xff0c;对于企业和个人开发者而言至关重要。当涉及到租用 1T 服务器时&#xff0c;价格是大家很为关注的要点。然而&#xff0c;1T 服务器租用一个月的费用并非固定不变&#xff0c;而是受到诸多因素的综合影响。​ 影响 1T 服务器租用…

【JavaWeb】Maven(下)

1 依赖管理 1.1 依赖配置 1.1.1 基本配置 依赖&#xff1a;指当前项目运行所需要的jar包。 一个项目中可以引入多个依赖&#xff1a; 例如&#xff1a;在当前工程中&#xff0c;我们需要用到logback来记录日志&#xff0c;此时就可以在maven工程的pom.xml文件中&#xff0c;引…

openEuler24.03 LTS下安装MySQL8.0.42

目录 前提步骤 删除原有mysql及maridb数据库 安装MySQL 启动MySQL 启动查看MySQL状态 设置MySQL开机自启动 查看登录密码 登录MySQL 修改密码及支持远程连接 远程连接MySQL 前提步骤 拥有openEuler24.03 LTS环境&#xff0c;可参考&#xff1a;Vmware下安装openEule…

gflags 安装及使用

目录 引言 安装 如何用 gflags 库写代码 如何用命令行使用 gflags 库 gflags 库的其他命令行参数 引言 gflags 是 Google 开发的一个开源库&#xff0c;用于 C 应用程序中命令行参数的声明、定义 和解析。 gflags 库提供了一种简单的方式来添加、解析和文档化命令行标…

Linux面试题集合(2)

查看系统磁盘使用&#xff0c;当前目录下所有文件夹的使用情况 df -h du -h 更改目录所有人和所有组&#xff0c;包括里面的文件夹下的文件&#xff0c;递归更改 chown -R newowner:newgroup 目录名 只更改文件所有人或者只更改文件所有组 chown newowner file chgrp newgroup …

致敬经典 << KR C >> 之打印输入单词水平直方图和以每行一个单词打印输入 (练习1-12和练习1-13)

1. 前言 不知道有多少同学正在自学C/C, 无论你是一个在校学生, 还是已经是上班族. 如果你想从事或即将从事软件开发这个行业, C/C都是一个几乎必须要接触的系统级程序开发语言. 虽然现在有Rust更安全的系统级编程语言作为C/C的替代, 但作为入门, C应该还是要好好学的. C最早由B…

基于Llama3的开发应用(二):大语言模型的工业部署

大语言模型的工业部署 0 前言1 ollama部署大模型1.1 ollama简介1.2 ollama的安装1.3 启动ollama服务1.4 下载模型1.5 通过API调用模型 2 vllm部署大模型2.1 vllm简介2.2 vllm的安装2.3 启动vllm模型服务2.4 API调用 3 LMDeploy部署大模型3.1 LMDeploy简介3.2 LMDeploy的安装3.3…

windows 10 做服务器 其他电脑无法访问,怎么回事?

一般我们会先打开win10自己的防火墙策略&#xff0c;但是容易忽略 电脑之间 路由器上的防火墙&#xff0c;此时也需要查看一下&#xff0c;可以尝试先关闭路由器防火墙&#xff0c;如果可以了&#xff0c;再 设置路由器上的防火墙规则。 将路由器的上网设置 改成 路由模式 &a…

Linux进程信号处理(26)

文章目录 前言一、信号的处理时机处理情况“合适”的时机 二、用户态与内核态概念重谈进程地址空间信号的处理过程 三、信号的捕捉内核如何实现信号的捕捉&#xff1f;sigaction 四、信号部分小结五、可重入函数六、volatile七、SIGCHLD 信号总结 前言 这篇就是我们关于信号的最…

报表控件stimulsoft教程:如何在报表和仪表板中创建热图

Stimulsoft Ultimate &#xff08;原Stimulsoft Reports.Ultimate&#xff09;是用于创建报表和仪表板的通用工具集。该产品包括用于WinForms、ASP.NET、.NET Core、JavaScript、WPF、PHP、Java和其他环境的完整工具集。无需比较产品功能&#xff0c;Stimulsoft Ultimate包含了…

win32相关(字符编码)

字符编码 ASCII编码 ASCII&#xff08;American Standard Code for Information Interchange&#xff0c;美国信息交换标准代码&#xff09;是最基础的字符编码标准&#xff0c;用于在计算机和其他设备中表示文本 基本概念 7位编码&#xff1a; ASCII使用7位二进制数&#x…

使用Langfuse和RAGAS,搭建高可靠RAG应用

大家好&#xff0c;在人工智能领域&#xff0c;RAG系统融合了检索方法与生成式AI模型&#xff0c;相比纯大语言模型&#xff0c;提升了准确性、减少幻觉且更具可审计性。不过&#xff0c;在实际应用中&#xff0c;当建好RAG系统投入使用时&#xff0c;如何判断接收信息是否正确…

android studio导入项目

如果 gradle-8.0-bin.zip 没有下载成功 可以点击进入这个网站&#xff1a;https://services.gradle.org/distributions/ 找到和自己本版相同的gradle-8.0-bin.zip文件找到自己版本进行下载; 如果下载依赖失败, 可以手动下载依赖编译过程中的jar https://repo.maven.apache.org/…

Autosar Nvm下电存储实现方式-基于ETAS工具

文章目录 前言Autosar Nvm相关定义Nvm Ram Block States状态切换Nvm_WriteAll函数NvBlock配置生成代码分析及使用总结前言 Nvm中存储的数据,一般有两种存储方式,一个是立即存,一个是下电存,之前介绍过立即存的配置,本文介绍下电存的配置及实现 Autosar Nvm相关定义 Nvm…