`
ordinary
  • 浏览: 79466 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

检查字符串是否是整数

    博客分类:
  • java
阅读更多
检查字符串是否是整数
   今天在论坛中看见一个贴,讨论用异常检验字符串是否为整数,出处http://www.iteye.com/topic/856221。个人总结了里面的方法。有如下四种:
1、 异常检测法;2、每个字符检测法;3、使用Character中的isDigit法;4、正则表达式法。个人分析比较了下这四种方法。如有错误请指出;
1、 异常检测法
代码如下:
public static boolean validateInteger1(String str) { 
try { 
        Integer.parseInt(str); 
     } catch (Exception ex) { 
         return false; 
     } 
     return true; 

这代码看起来简洁,容易理解,下面仔细分析下parseInt方法:
    public static int parseInt(String s, int radix)
throws NumberFormatException
    {
        if (s == null) {
            throw new NumberFormatException("null");
        }

if (radix < Character.MIN_RADIX) {
    throw new NumberFormatException("radix " + radix +
    " less than Character.MIN_RADIX");
}

if (radix > Character.MAX_RADIX) {
    throw new NumberFormatException("radix " + radix +
    " greater than Character.MAX_RADIX");
}

int result = 0;
boolean negative = false;
int i = 0, max = s.length();
int limit;
int multmin;
int digit;

if (max > 0) {
    if (s.charAt(0) == '-') {
negative = true;
limit = Integer.MIN_VALUE;
i++;
    } else {
limit = -Integer.MAX_VALUE;
    }
    multmin = limit / radix;
    if (i < max) {
digit = Character.digit(s.charAt(i++),radix);
if (digit < 0) {
    throw NumberFormatException.forInputString(s);
} else {
    result = -digit;
}
    }
    while (i < max) {
// Accumulating negatively avoids surprises near MAX_VALUE
digit = Character.digit(s.charAt(i++),radix);
if (digit < 0) {
    throw NumberFormatException.forInputString(s);
}
if (result < multmin) {
    throw NumberFormatException.forInputString(s);
}
result *= radix;
if (result < limit + digit) {
    throw NumberFormatException.forInputString(s);
}
result -= digit;
    }
} else {
    throw NumberFormatException.forInputString(s);
}
if (negative) {
    if (i > 1) {
return result;
    } else { /* Only got "-" */
throw NumberFormatException.forInputString(s);
    }
} else {
    return -result;
}
}
   花性能主要在1、异常中,2、   针对每个字符进行while循环中。
2、 每个字符检测法;
代码如下:
    public static boolean validateInteger2(String str) { 
        char[] chars = str.toCharArray(); 
        for (int i = 0; i < chars.length; i++) { 
            if ((chars[i] > '9' || chars[i] < '0') && !(i == 0 && chars[0] == '-' && chars.length > 1)) { 
                return false; 
            } 
        } 
        return chars.length > 0; 

这种方法就是检测是否满足数字。
3、使用Character中的isDigit法
public static boolean validateInteger3(String str) { 
if (str == null) { 
          return false; 
      } 
        int sz = str.length(); 
       for (int i = 0; i < sz; i++) { 
           if (Character.isDigit(str.charAt(i)) == false) { 
               return false; 
         } 
       } 
      return true; 
   } 
方法3和方法2基本相同,也是遍历每个字符,唯一的区别就是检测字符是否满足数字的条件让我们看看isDigit
    public static boolean isDigit(int codePoint) {
        boolean bDigit = false;

        if (codePoint >= MIN_CODE_POINT && codePoint <= FAST_PATH_MAX) {
            bDigit = CharacterDataLatin1.isDigit(codePoint);
        } else {
            int plane = getPlane(codePoint);
            switch(plane) {
            case(0):
                bDigit = CharacterData00.isDigit(codePoint);
                break;
            case(1):
                bDigit = CharacterData01.isDigit(codePoint);
                break;
            case(2):
                bDigit = CharacterData02.isDigit(codePoint);
                break;
            case(3): // Undefined
            case(4): // Undefined
            case(5): // Undefined
            case(6): // Undefined
            case(7): // Undefined
            case(8): // Undefined
            case(9): // Undefined
            case(10): // Undefined
            case(11): // Undefined
            case(12): // Undefined
            case(13): // Undefined
                bDigit = CharacterDataUndefined.isDigit(codePoint);
                break;
            case(14):
                bDigit = CharacterData0E.isDigit(codePoint);
                break;
            case(15): // Private Use
            case(16): // Private Use
                bDigit = CharacterDataPrivateUse.isDigit(codePoint);
                break;
            default:
                // the argument's plane is invalid, and thus is an invalid codepoint
                // bDigit remains false;
                break;                         
            }
        }
        return bDigit;
}
该方法是通过case的方法进行批判,这样匹配的效率比方法2中的比较要高一些,但测试结果却不如人意,当字符串全为数字并字符长度比较长时,方法2比方法3效率高。
4、正则表达式法
    public static boolean validateInteger4(String str){
    String reg="^(-?)[1-9]+\\d*|0"; 
   boolean tem=false; 
         Pattern pattern = Pattern.compile(reg); 
         Matcher matcher=pattern.matcher(str); 
         tem=matcher.matches(); 
         return tem; 
}
正则表达式就不多讲了。
下面把四种方法进行比较:
代码如下:
import java.util.regex.Matcher;
import java.util.regex.Pattern;



public class Test {
    private static final int TIMES = 1000000;
    /**
     * 单字符时,把long设置为1
     * 当多字符时,把Long设置为100
     */
    private static final int LONG = 10000; 
public static void main(String[] args) {
StringBuffer str= new StringBuffer();
for(int i=1;i<LONG;i++){
str.append("1");//当是数字的时候设置为1当是字母时设置为a
}
Long startTime=System.nanoTime();

for(int i=1;i<TIMES;i++){
validateInteger1(str.toString());
}
System.out.println(System.nanoTime()-startTime);
}
public static boolean validateInteger1(String str) { 
try { 
        Integer.parseInt(str); 
     } catch (Exception ex) { 
         return false; 
     } 
     return true; 


    public static boolean validateInteger2(String str) { 
        char[] chars = str.toCharArray(); 
        for (int i = 0; i < chars.length; i++) { 
            if ((chars[i] > '9' || chars[i] < '0') && !(i == 0 && chars[0] == '-' && chars.length > 1)) { 
                return false; 
            } 
        } 
        return chars.length > 0; 
    } 
    public static boolean validateInteger3(String str) { 
        if (str == null) { 
            return false; 
        } 
        int sz = str.length(); 
        for (int i = 0; i < sz; i++) { 
            if (Character.isDigit(str.charAt(i)) == false) { 
                return false; 
            } 
        } 
        return true; 
    } 
   
    public static boolean validateInteger4(String str){
    String reg="^(-?)[1-9]+\\d*|0"; 
    boolean tem=false; 
         Pattern pattern = Pattern.compile(reg); 
         Matcher matcher=pattern.matcher(str); 
         tem=matcher.matches(); 
         return tem; 
    }
}
测试结果如下:
方法 检查单字符串整数时间 检查多字符串整数时间 检查单字符串非整数时间 检查多字符串非整数时间
异常检测法 2175653571 3096202439 2120862098 2865671699
每个字符检测法 97425542 583244799 43266996 292156840
使用common-lang中的StringUtils法 78209925 1509344837 19438843 184180683
正则表达式法 1862483011 5208720638 1858216885 2075793713

通过测试发现方法3在性能和简洁性上都比较好,因此建议检测字符串是否为整数时,使用方法3。如果谁有更好的方法,请告诉我。
分享到:
评论

相关推荐

    检查字符串是否为整数,C++程序

    本篇文章将详细探讨一个简单的C++程序,该程序用于检测一个给定的字符串是否能够被解释为一个整数。 #### 程序分析 ##### 1. 函数定义 函数`Check_int`接收一个字符数组`Src`作为参数,其目标是判断这个字符串...

    delphi 判断字符串是否为整数.rar

    在实际应用中,我们还可以扩展这个函数,例如添加对负数的支持,或者检查字符串是否为空,甚至可以处理更大的整数类型,如 `Int64`,通过使用 `TryStrToInt64` 函数。 在"Delphi 判断字符串是否为整数.rar"这个...

    C#正则表达式大全, 判断字符串是否为正整数,中文,英文.....

    在上面的代码中,我们可以看到一个名为 IsInt 的方法,该方法可以判断输入字符串是否为正整数。该方法使用了正则表达式 @"^\d+$" 来匹配字符串,如果字符串仅包含数字字符,则返回 true,否则返回 false。 知识点 3...

    从控制台输入一串字符串,筛选整数输出。

    3. **字符串分割与处理**:对输入的字符串进行逐字符处理,并判断是否为整数。 #### 实现步骤详解 ##### 1. 引入必要的包 程序首先引入了必要的Java包: - `java.io.BufferedReader`:用于读取文本文件的便捷类...

    Java判断字符串是否是整数或者浮点数的方法

    这些方法能够有效地检测字符串是否符合整数或浮点数的格式。然而,如果需要将字符串转换为实际的数值类型(例如,`Integer.parseInt()`或`Double.parseDouble()`),还需要额外处理如超出范围等错误情况。在实际应用...

    Delphi中判断字符串是否符合日期格式.pdf

    首先,函数接收一个名为`VarString`的参数,它是一个字符串,我们需要检查这个字符串是否能表示一个日期。函数的返回值是一个布尔值,如果字符串符合日期格式,则返回`True`,否则返回`False`。 函数开始时,通过...

    详解Java判断是否是整数,小数或实数的正则表达式

    在Java中使用正则表达式来判断字符串是否符合整数、小数或实数的格式是一种常见且有效的做法。在编程中,我们经常需要对输入的字符串进行格式验证,以确保它们符合预期的数值格式,尤其是在处理财务数据、用户输入...

    判断一个字符串或字符串中的一个字符是否为数字类型

    在 JavaScript 中,可以使用正则表达式或 `isNaN()` 函数来检测字符串是否为数字。例如: - 正则匹配:`/^\d+$/.test(str)` - `isNaN()`:`!isNaN(parseInt(str))` 注意,`isNaN()` 会将字符串尝试转换成数值,...

    java判断字符串是正整数的实例

    因此,我们的目标是检查字符串是否满足这些条件。 在提供的实例中,我们看到一个名为`isPureDigital`的方法,用于判断输入的字符串是否为正整数。方法的主要步骤如下: 1. **参数检查**:首先,我们需要确保输入的...

    字符串转换整数 使用c#实现MyStoi函数,用于将字符串转换为整数

    在C#编程语言中,字符串转换为整数是常见的操作,尤其在处理用户输入或者解析数据时。这个过程可以通过内置的`int.Parse()`、`int.TryParse()`、`Convert.ToInt32()`等方法来完成。然而,为了更好地理解底层机制和...

    整数转字符串

    - 首先检查输入的整数是否为负数,如果是,则记录下来,并将整数转换为正数。 - 使用循环,每次计算整数除以10后的余数,并将其加上字符'0'(ASCII码为48),得到相应的字符。 - 将字符存入字符数组。 - 循环继续...

    关于字符串相等的比较

    - 缺点:不是用来判断字符串是否完全相等,而是返回一个整数值表示字符串的排序关系。 4. **使用 `String.equals` 静态方法:** - Java 9 及更高版本引入了静态方法 `String.equals`。 - 示例:`String.equals(s...

    字符串转换为整数1

    【字符串转换为整数1】这个问题是LeetCode中的一道编程题目,主要考察的是字符串到整数的转换逻辑。在实现这个功能时,你需要编写一个名为`strToInt`的函数,不能依赖像`atoi`这样的库函数。以下是解决这个问题的...

    vc 16进制字符串转换为10进制的整数

    1. **预处理字符串**:先检查输入的字符串是否符合16进制格式,即只包含0-9和A-F的字符。可以使用`std::all_of()`函数配合自定义的谓词函数进行验证。 2. **计算值**:从字符串的最后一个字符开始,逐个字符取出,...

    递归法将整数转换为字符串.zip

    在编程领域,将整数转换为字符串是一项基本操作,它广泛应用于各种场景,如日志记录、用户界面显示以及网络通信。在C语言中,由于其底层特性,没有内置的直接转换函数,因此程序员需要手动实现这样的功能。本篇文章...

    C语言写字符串函数及任意个数求和

    一个简单的实现可能是遍历字符串,检查每个字符是否与目标字符匹配,如果匹配则替换并继续查找。 3. **字符串比较(strcmp or custom function)**: `strcmp`函数用于比较两个字符串,返回值告诉我们它们是否相等...

    判断CEdit中的字符串是否为一个数

    当我们谈论“判断CEdit中的字符串是否为一个数”时,我们指的是检查`CEdit`控件中用户输入的文本是否可以转换为一个有效的数值类型,比如整数或浮点数。 首先,我们需要理解字符串和`CString`类。`CString`是MFC...

    usart_整数转字符串_

    这时,我们需要自己编写函数将整数转换为字符串,以便通过USART发送。下面我们将详细讨论如何实现这个功能,并探讨其背后的原理和优化方法。 一、整数转字符串的基本原理 整数转字符串的过程主要是将十进制整数...

    pb函数库之字符串操作函数

    返回值为一个长整数,该整数是字符串的长度。 5. Lower()函数:Lower()函数可以将字符串中的大写字母转换为小写字母。其语法为Lower(string),其中string是要将其中的大写字母转换为小写字母的字符串。返回值为一个...

    关于字符串包含的问题

    【字符串包含问题】是计算机科学中常见的字符串处理问题,主要关注如何高效地判断一个较短的字符串(子串)是否完全包含在另一个较长的字符串(主串)中。以下是几种解决此类问题的方法: ### 第一节:基础方法 1....

Global site tag (gtag.js) - Google Analytics