java - 字符串到数字转换的性能问题

标签 java string performance

我有空格分隔的字符串,其中包含中间的数字,例如:

“abc123 ws32wd3 y3tg43 5tga89 a1a”

我必须解析字符串以获取每个标记中的数字,然后总结从标记中提取的所有数字。我写了下面的代码,但我认为,如果有很大的字符串,那么可能会出现性能问题。

所以,我的问题是:

  1. 我们如何提高下面代码的性能?

  2. 我们还有其他方法编写下面的代码来解决这个问题吗?

代码:

public class TestSum {

    public static int doSum(String str){
        String[] sArray = str.split(" ");
        char[] chr = null;
        String temp;
        String number = "";
        int sum=0;
        for(String s : sArray){
            chr = s.toCharArray();
            for(char c : chr){
                temp = String.valueOf(c);
                if(isNum(temp)){
                    number = number + temp;
                }           
            }
            sum = sum + Integer.parseInt(number);
            number="";
        }       
        return sum;
    }

    public static boolean isNum(String nStr){   
        try{
            Integer.parseInt(nStr);
            return true;
        }catch(NumberFormatException nfe){
            return false;
        }       
    }

    public static void main(String[] args) {
        System.out.println("Sum is "+ TestSum.doSum("abc123 ws32wd3 y3tg43 5tga89 a1a"));
    }
} 

最佳答案

这是我能想到的最快的:

public static int getSum(String str) 
{
    int sum = 0;
    int exp = 1;      
    for (int i = str.length() - 1; i >= 0; i--) 
    {
        final char c = str.charAt(i);
        if (c >= '0' && c <= '9')
        {
            sum += (c - '0') * exp;
            exp *= 10;
        }
        else
        {
            exp = 1;
        }
    }
    return sum;
}

它从右到左迭代字符串。因此,当它“看到”一个数字时,它可以添加适当的值,具体取决于数字中“看到”的小数位。

Benchmark使用Caliper

结果与 davecom's benchmark 中的结果不同:

AUTHOR       RUNTIME (NS)   HOW MANY TIMES FASTER THAN JUNS
-----------------------------------------------------------
Adam              66.221                                600
Old              579.873                                 70
Prabhakaran   20,012.750                                  2 (2x faster than Juns)
Juns          39,681.074                                  1

关于java - 字符串到数字转换的性能问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19250888/

相关文章:

java - xs :String in xs:DateTime format to XMLGregorianCalendar

java - 如何为 SBT 设置 Java 版本

javascript - 检查并仅用 javascript 替换 div 字符串

java - 颠覆 NoClassFoundDefError

java - 如何在鼠标退出事件上启动定时器并在鼠标输入事件上停止同一个定时器?

postgresql - 在 PostgreSQL 中增加共享缓冲区的缺点是什么

performance - 在x86汇编中将寄存器设置为零的最佳方法是什么:xor,mov或and?

javascript - 为什么浏览器并不总是在执行 JavaScript 之前完成对前面 HTML 的渲染?

javascript - 如何在 JavaScript 中多个子字符串中的一个第一次出现时拆分字符串?

创建一个用零填充的特定维度的文件