1、弄清 Ljava.lang.String;@de6ced
String [] str={"1","2","3"};
System.out.println(str);
结果 :{Ljava.lang.String;@de6ced
左边的"[",可是看成数组的维度,"[["这个就是二维数组
"L"代表这个数组是引用数据类型的数组.基本数据类型的每种类型都有自已对应的标识符.
"java.lang.String"是数组元素的类型,标识这个数组是什么类型的数组.
@后的数值表示此对象的hashCode.
这些信息是从输出结果获得的.调用的方法是String[]类型的toString()方法.
Java中的数组也是一个对象,String[]类型的信息生成由Java虚拟机来完成,同一类型同一维度的数组共享同一个数组类.
自定义的类,如果没有override toString()方法,那么会输出一串好象没多大意义的数据,这时你可以override toString()方法,以返回更有意义的数据格式.但是打印数组你只能得到这些好象没多大意义的数据,普通编程手段你无法override 数组类的toString()方法,因为你手中都没有数组类的定义代码,它是由虚拟机在第一次遇到时生成的数组数据类型.
基本上你:非得做次遍历或者转成list才行
2、假如我现在给你一个任务,用Java分割一段字符串,比如一段IP地址:String IP = 127.0.0.1,让你用”.”作为分隔符分割成四段,如果你没有看完我的这篇文章或者以前没有做过类似的事情或者记性不太好的话,你肯定想都不想直接就这样: String[] items = IP.split(“.”); ,并想这也太简单了吧,事情真的有你想的那么顺利吗?( 哦,忘了说了,运行的JDK环境是1.6),你会发现控制台没有打印出你期望的结果,你开始紧张,心跳加速,开始冒冷汗……
其实String的replace方法实现是通过Pattern这个类来实现的,看一下实现:
return Pattern.compile(target.toString(), Pattern.LITERAL).matcher(
this ).replaceAll(Matcher.quoteReplacement(replacement.toString()));
}
而Pattern是Java中的正则表达式的匹配工具,在正则表达式中”~!@#$%^&*[]”这些字符是特殊字符,比如”.”和”*”是匹配任意字符的字符,所以你想用”.”和”*”直接作为分隔符的话是不会有正确的结果的(=0),解决办法是在前面添加”//”,像这样: String[] items = IP.split(“//.”),这样就OK了