[转]Java中怎样判断一个字符串能否转成数字
原文地址:http://blog.sina.com.cn/s/blog_7bac470701014mjf.html
判断字符串是否为数字
//1、正则表达式
public static boolean isNumeric1(String
str){
Pattern pattern =
Pattern.compile("[0-9]*");
return
pattern.matcher(str).matches();
}
//2、java自带函数
public static boolean isNumeric2(String
str){
for (int i =
str.length();--i>=0;){
if
(!Character.isDigit(str.charAt(i))){
return
false;
}
}
return
true;
}
//3、正则表达式
public static boolean isNumeric(String
str){
if(str.matches("\\d
*")){
return
true;
}else{
return
false;
}
}
//4、判断ASCII码值
public static boolean isNumeric0(String
str){
for(int
i=str.length();--i>=0;){
int
chr=str.charAt(i);
if(chr<48
|| chr>57)
return
false;
}
return
true;
}
//5、逐个判断str中的字符是否是0-9
public static boolean isNumeric3(String
str){
final String
number = "0123456789";
for(int i =
0;i
if(number.indexOf(str.charAt(i)) ==
-1){
return
false;
}
}
return
true;
}
//6、捕获NumberFormatException异常
public static boolean isNumeric00(String
str){
try{
Integer.parseInt(str);
return
true;
}catch(NumberFormatException
e){
System.out.println("异常:\""
+ str + "\"不是数字/整数...");
return
false;
}
}
ps:不提倡使用方法6,原因如下:
1、NumberFormatException是用来处理异常的,最好不要用来控制流程的。
2、虽然捕捉一次异常很容易,但是创建一次异常会消耗很多的系统资源,因为它要给整个结构作一个快照。
看一下JDK源码:
public static long parseLong(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");
}
long result =
0;
boolean negative = false;
int i = 0,max =
s.length();
long limit;
long
multmin;
int digit;
if(max >
0){
if(s.charAt(0) ==
'-'){
negative =
true;
limit = Long.MIN_VALUE;
i++;
}else{
limit = -Long.MAX_VALUE;
}
multmin = limit / radix;
if(i <
max){
digit =
Character.digit(s.charAt(i++),radix);
if(digit < 0){
throw new
NumberFormatException(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 new
NumberFormatException(s);
}
if(result <
multmin){
throw new
NumberFormatException(s);
}
result *=
radix;
if(result < limit +
digit){
throw new
NumberFormatException(s);
}
result -=
digit;
}
}else{
throw
new
NumberFormatException(s);
}
if(negative){
if(i >
1){
return result;
}else{
throw new
NumberFormatException(s);
}
}else{
return
-result;
}
}
可以看出来jdk里也是一个字符一个字符的判断,如果有一个不是数字就抛出NumberFormatException,所以还不如这个工作由我们自己来做,还省得再抛出一次异常...
[转]Java中怎样判断一个字符串能否转成数字的更多相关文章
- java中如何判断一个字符串是否包含另外一个字符串的方法
indexOf(String s)的使用,如果包含,返回的值是包含该子字符串在父类字符串中起始位置: 如果不包含必定全部返回值为-1 package my_automation; public cla ...
- Java中怎样判断一个字符串是否是数字?
1:正则表达式 public static void main(String[] args) { String str = "123456456456456456"; boolea ...
- Java中如何判断一个字符串是否为数字
方法一:异常处理 public static boolean isInteger(String str){ try { Integer i = Integer.parseInt(str); retur ...
- java中怎么判断一个字符串中包含某个字符或字符串
public static void main(String[] args) { String str="ABC_001"; ){ System.out.println(" ...
- java中判断一个字符串是否“都为数字”和“是否包含数字”和“截取数字”
在javascript中有一个方法isDigit()使用来判断一个字符串是否都是数字,在java的字符串处理方法中没有这样的方法,觉得常常需要用到,于是上网搜了一下,整理出了两个用正则表达式匹配的判断 ...
- Oracle中如何判断一个字符串是否含有汉字
看到网友问,怎么查询表中某个字段数据是不是包含了全角字符啊? 这个问题涉及到几个函数:to_single_byte.length和lengthb,我之前做开发的时候研究的是如何判断一个字符串中是否包含 ...
- js中如何判断一个字符串包含另外一个字符串?
js中判断一个字符串包含另外一个字符串的方式比较多? 比如indexOf()方法,注意O是大写. var test="this is a test"; if(test.indexO ...
- 在Java中用正则表达式判断一个字符串是否是数字的方法
package chengyujia; import java.util.regex.Pattern; public class NumberUtil { /** * 判断一个字符串是否是数字. * ...
- Java中如何判断一个日期字符串是否是指定的格式
判断日期格式是否满足要求 import java.text.ParseException;import java.text.SimpleDateFormat;import java.util.Date ...
随机推荐
- What makes an excellent front-end developer?(for my English speech)
What makes an excellent front-end developer? Let me please start this talking by saying that what is ...
- 第四章 Hibernate入门
1.构建了一个Student实体类 public class Student { private Integer id; //name private String name; //age priva ...
- AC日记——字符串判等 openjudge 1.7 17
17:字符串判等 总时间限制: 1000ms 内存限制: 65536kB 描述 判断两个由大小写字母和空格组成的字符串在忽略大小写,且忽略空格后是否相等. 输入 两行,每行包含一个字符串. 输出 ...
- 使用javascript实现的雪花飞舞的效果
原作者是在body中不停的插入多个小div雪花来向下慢慢飘,一直飘到body的底部后,将雪花移除,于是,将原来的代码稍加修改,让他只是从屏幕的顶部飘落到屏幕底部(不是body的底部)后,就将雪花移除, ...
- C#的匿名方法
匿名方法是在初始化委托时内联声明的方法. 例如下面这两个例子: 不使用匿名方法的委托: using System; using System.Collections.Generic; using Sy ...
- C语言操作文件
#include <stdio.h> struct stu{ ]; int num; int age; ]; }boya[],boyb[]; struct stu *pa,*pb; mai ...
- DLL放在指定目录 以及设置dll调用路径
一.DLL放在指定目录 在编写C# winform程序中,不免一个项目会有多个工程文件,而这些工程文件之间是相互引用的,所以不想将工程的生成结果(exe或者dll)放在当前工程bin目录下的Debug ...
- [转]nodejs npm常用命令
FROM : http://www.cnblogs.com/linjiqin/p/3765772.html npm是一个node包管理和分发工具,已经成为了非官方的发布node模块(包)的标准.有了n ...
- codevs3145 汉诺塔问题
难度等级:白银 3145 汉诺塔问题 题目描述 Description 汉诺塔问题(又称为河内塔问题),是一个大家熟知的问题.在A,B,C三根柱子上,有n个不同大小的圆盘(假设半径分别为1-n吧),一 ...
- logback + slf4j + jboss + spring mvc
logback.log4j.log4j2 全是以同一个人为首的团伙搞出来的(日志专业户!),这几个各有所长,log4j性能相对最差,log4j2性能不错,但是目前跟mybatis有些犯冲(log4j2 ...