isXXX()的方法是很经常见的一类方法,其中,在反射类库中的Class 类就有isArray()这一方法,由下文的代码运行可以得到一个结论:就是ArrayList对象不能通过isArray()的检验,其实很大程度是我先入为主的认为ArrayList是Array,为什么会这样认为呢?一方面是因为类名上有Array的字样,另一方面就是认为ArrayList可能是实现了一个叫Array的接口。查api可以知道,其实并没有这样一个接口,只有反射库里有这么一个类,当然和ArrayList没什么关系啦。明白了这点,就可以知道其实isArray()方法的判断就不是接口了。
结合下面代码的结果可以知道,其实isArray()是以“[]”来判断的,至于怎么实现,小弟能力有限。
事实上,ArrayList对象中有elementData这一Object[]变量,所以,在代码的第一次递归前,利用反身机制获得了这一Field并进入toString递归,并通过了isArray()的检验。
另外:由打印出来的消息可以知道,如果将两个return分成两部分,则,前面的只调用过1次,后面的调用了5次,那是因为数组Object[] elementData在接收了原型数据int后会将int自动封装成java.lang.Integer对象,所以getComponent()获得的是Integer类型,而非原型int,因此递归调用toString()。
第一次写BLOG,哈哈,马马虎虎,请见谅
以下是一段Core Java里的一个例子,加上我自己的调试语句:
import java.lang.reflect.AccessibleObject;
import java.lang.reflect.Array;
import java.lang.reflect.Field;
import java.lang.reflect.Modifier;
import java.util.ArrayList;
import java.util.Date;
import java.util.LinkedList;
public class ObjectAnalyzerTest {
public static void main(String [] args){
ArrayList<Integer> squares=new ArrayList<Integer>();
for(int i=1; i<=5;i++)squares.add(i*i);
System.out.println(new ObjectAnalyzer().toString(squares));
}
}
class ObjectAnalyzer{
public String toString(Object obj){
if(obj==null)return "null";
if(visited.contains(obj))return "...";//************
visited.add(obj);
Class cl=obj.getClass();
if(cl==String.class)return (String)obj;
if(cl.isArray()){
// System.out.println(cl.getName()+"+"+"1+"+re++);
String r = cl.getComponentType()+"[]{";
for (int i = 0;i < Array.getLength(obj);i++){
if (i>0)r+=",";
Object val = Array.get(obj,i);
if (cl.getComponentType().isPrimitive()) r+=val;
else r += toString(val);
}
System.out.println("X+"+r);
return r+"}";
}
String r = cl.getName();
// System.out.println(cl.getName()+"+"+"0+"+re++);
do
{
r+="[";
Field[] fields=cl.getDeclaredFields();
AccessibleObject.setAccessible(fields,true);
for(Field f:fields){
if(!Modifier.isStatic(f.getModifiers())){
if(!r.endsWith("["))r+=",";
r+= f.getName()+"=";
try{
Class t = f.getType();
Object val = f.get(obj);
if(t.isPrimitive()) r+=val;
else r+=toString(val);
}catch(Exception e){
e.printStackTrace();
}
}
}
r+="]";
cl=cl.getSuperclass();
}
while(cl!=null);
System.out.println("X+"+r);
return r;
}
private ArrayList<Object> visited=new ArrayList<Object>();
private int re=0;
}