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;
}