A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 刘笑 中级黑马   /  2012-6-26 18:45  /  2129 人查看  /  3 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

public class GenericMethods {
public <T> void f(T... x) {
  System.out.println(x.getClass().getName());
}
/**
  * @param args
  */
public static void main(String[] args) {
  // TODO Auto-generated method stub
  GenericMethods gm = new GenericMethods();
  gm.f("123", "234");
  gm.f(123, 2132);
  gm.f(gm, gm);
  gm.f(23, "1232", gm);
  gm.f("123", 12);
}
}
运行的结果如下:
[Ljava.lang.String;
[Ljava.lang.Integer;
[Lcom.test.generic.Method.GenericMethods;
[Ljava.lang.Object;
[Ljava.io.Serializable;//此行为什么不是Object?

评分

参与人数 1技术分 +1 收起 理由
黄奕豪 + 1 赞一个!

查看全部评分

3 个回复

倒序浏览
String、 Interge对象都实现了Serializable接口,所以这两个传进去,就把T自动匹配成Serializable对象了
回复 使用道具 举报
之所以倒数第二行会打印object是因为你传入的参数既有基本类型又有自己定义的引用类型,他们同时是object的子类。
而最后一行打印Serializable,是因为integer和String同时实现了Serializable接口。
一个对象序列化的接口,一个类只有实现了Serializable接口,它的对象才是可序列化的。因此如果要序列化某些类的对象,这些类就必须实现Serializable接口。而实际上,Serializable是一个空接口,没有什么具体内容,它的目的只是简单的标识一个类的对象可以被序列化。

评分

参与人数 1技术分 +1 收起 理由
黄奕豪 + 1 赞一个!

查看全部评分

回复 使用道具 举报
这里牵扯到泛型方法的类型判断,倒数第二个是因为你传进去了三个对象都是不同类型的,所以取他们的最大交集,也就是Object
最后一个是因为两者都实现了Serializable接口所以类型的参数就是Serializable。
这样的结果是没有错的,我有一点疑问是:

gm.f(12,"1313");如果这样的话 返回的就是[Ljava.lang.Comparable; String 和Integer 同样也实现了Comparable<T>接口,为什么字符串在前就返回Serializable 整数在前就返回Comparable
这些通过Debug都能调用方法时候传进去的类型就是你输出的类型

评分

参与人数 1技术分 +1 收起 理由
黄奕豪 + 1 赞一个!

查看全部评分

回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马