原文地址:
https://weblogs.java.net/blog/pat/archive/2004/10/stupid_scanner_1.html
正则表达式中, \A是指一个字符串的开头,可能大家用惯了 ^,而忽略了这个 \A, 但是^其实是指一行的开始,而不管一个字符串里面包含多少行, \A 都只匹配第一行的开头。
那么我们可以用 \A 做点什么呢?,看下面这个例子:
注意当需要做编码转换时,Scanner是有支持编码参数的构造方法的。
正则表达式中, \A是指一个字符串的开头,可能大家用惯了 ^,而忽略了这个 \A, 但是^其实是指一行的开始,而不管一个字符串里面包含多少行, \A 都只匹配第一行的开头。
那么我们可以用 \A 做点什么呢?,看下面这个例子:
static String convertStreamToString(java.io.InputStream is) {
java.util.Scanner s = new java.util.Scanner(is).useDelimiter("\\A");
return s.hasNext() ? s.next() : "";
}
相信大家都看懂了,用
\A作为分隔符,那么得到的当然就只有一个token,那就是整个字符串了。再配合Scanner,就轻易的将一个输入流转换为一个字符串了。
java.util.Scanner s = new java.util.Scanner(is).useDelimiter("\\A");
return s.hasNext() ? s.next() : "";
}
注意当需要做编码转换时,Scanner是有支持编码参数的构造方法的。