[转帖]_Tomcat, WebLogic及J2EE讨论区_Weblogic技术|Tuxedo技术|中间件技术|Oracle论坛|JAVA论坛|Linux/Unix技术|hadoop论坛_联动北方技术论坛  
网站首页 | 关于我们 | 服务中心 | 经验交流 | 公司荣誉 | 成功案例 | 合作伙伴 | 联系我们 |
联动北方-国内领先的云技术服务提供商
»  游客             当前位置:  论坛首页 »  自由讨论区 »  Tomcat, WebLogic及J2EE讨论区 »
总帖数
1
每页帖数
101/1页1
返回列表
0
发起投票  发起投票 发新帖子
查看: 4187 | 回复: 0   主题: [转帖]        下一篇 
barry
注册用户
等级:中校
经验:1534
发帖:236
精华:2
注册:2012-1-13
状态:离线
发送短消息息给barry 加好友    发送短消息息给barry 发消息
发表于: IP:您无权察看 2012-2-9 9:44:18 | [全部帖] [楼主帖] 楼主

我们在JAVA中 处处都用到了 范型 ,JAVA中的范型是从C++模板继承来的,不过  JAVA的 范型的功能 远远没有 C++那么强大 。

我们知道在C++中 模板可以很方便的代替任意类型的数据 如下 ;

template<class T>
void show(T x)
{
      cout<<x<<endl ;
}


上面的T 可以代表任意类型的数据 ,这样 不是大大减少了 函数的重载次数 ,提高了效率呢。java是从C++过来的,理解了C++,jav也不在话下 。

在java中自定义范型也可以用在 方法上 如下:    

1、

//这样声明的范型 可以代替任意类型数据    我们市场用到的键值对   Map.Entry<K,V>  不就是给予范型的吗  

K  V都可以代替任意类型的值 ,但是在java中 范型的 实际类型 必须是 引用类型 

<K,V> void get(K k,V v)
{
}
2、


Java中的范型 不能像C++那么灵活 

<T> T add(T a,T b)
{
      //return  a+b   ;//很多人以为java也想C++一样可以这样 ,但是不可以 。     
      return null;
}


这个返回的null 也是有类型限制的 ,比如 上面的 a b 分别是 Integer 和 String  那么就会取他们共同的基类 Object做为返回值类型,其他的同理

3、

实现任意类型的数组的 成员值的交换,注意 在 自定义范型中 范型的实际类型 只能是 引用数据类型  不能是基本数据类型

public  static <T> void  swap(T[]a,int x,int y)
{
  T  tem  =a[x]  ;
  a[x]=a[y]  ;
  a[y]=tem ;

}

上面这个方法 如果我  swap(new Integer[]{1,2,3,4,5},1,2);       //这样就会自动交换 下标 1 2 的值    

但是这样调用就错了   swao(new int[]{1,2,3,5,6},2,3) ;  //所以说Java的范型的实际类型 只能是  引用数据类型

4、

<T  extends  String>     表示类型只能是  String 或者  String的 派生类 

<T super  String >   表示范型类型只能是String或者 String的父类    

用法同上

5、

下面这个函数利用范型  来实现 类型自动转换的功能

public static <T> T autoConvert(Object obj) //因为返回值是 T标识任意类型 所哟可以 将返回结果赋值给任意类型对象
{
      return (T)obj;
}
Object obj=="";
String str=autoConvert(obj);


可以完成自动转换 ,因为范型T代表任意类型 ,因此他可以 赋值给 String类型的对象

6、将任意类型的对象填充到任意类型的数组中  ,与是fillArray(new Integer[]{2,3,4},"ddd"); 这样调用是正确的,这样做忽略 类型限制

public static <T> void fillArray(T[] a,T b) //将任意一个对象填充到任意类型的数组
{
      for(int i =0;i<a.length;i++)
      {
            a[i] =b ;
      }
}


7、以自定义范型的形式显示一个集合的数据   ,下面一个是利用自定义范型 一个是利用  通配符来实现 ,但是不同的是 利用通配符操作的集合 不能向集合中插入元素 

但是 自定义范型却可以 。 原因是 通配符代表的集合 我们不知道集合内部具体 元素 是什么类型 所以 不能对集合进行add操作  。

public static  <T> void showCollection(Collection<T> col,T  obj)  //利用范型来输出任意类型集合
 { 
  col.add(obj) ;
  for(T a:col)
  {
   System.out.println(a);
  }
 }

public static void showCollection(Collection<?> col)  //利用范型来输出任意类型集合
{  
  for(Object obj:col)
  {
   System.out.println(obj);
  }
}

8、如果一个类中多个 方法都需要范型那么 就是用类级别的范型   。

例如 class  A<E> 


     public void  add(E obj){}

     public  E  get(){} 

     private E data; 
}

这样声明范型和 在函数前面声明其实 是一样的 只不过是 在类的级别上  作用于整个类而已

    9、  要注意 范型只是给编译器看的  。

也就是说   Vector<Integer>   Vector<String>  他们用到的都是同一份字节码 ,字节码 只有 class文件加载到内存中的时候才有  

所以在一个类中下面2个方法不能同时存在

void show(Vector<Integer>) {}
void show(Vector<String>){}


这两个方法都不是重载 因为编译后要去掉类型信息




赞(0)    操作        顶端 
总帖数
1
每页帖数
101/1页1
返回列表
发新帖子
请输入验证码: 点击刷新验证码
您需要登录后才可以回帖 登录 | 注册
技术讨论