java的泛型之-html
泛型类:java
- public class GenericsFoo<T> {
- private T x;
- public GenericsFoo(T x) {
- this.x = x;
- }
- public T getX() {
- return x;
- }
- public void setX(T x) {
- this.x = x;
- }
- }
- 使用=GenericsFoo<String> strFoo=new GenericsFoo<String>("Hello Generics!");
- System.out.println("strFoo.getX="+strFoo.getX());
泛型方法:web
public <T> void f(T x) {函数
System.out.println(x.getClass().getName()); }this
调用= ea.f(" ");spa
scala泛型之--.net
泛型类:scala
- class Reference[T] {
- private var contents: T = _
- def set(value: T) { contents = value }
- def get: T = contents
- }
Reference类具备一个叫作T的类型参数来表示他说引用的对象的类型。这个类型在Reference中做为了变量和函数的参数或者返回类型。unix
混入trait的限制code
- class EmptySet[A <: Ordered[A]] extends Set[A] {
- def contains(x: A) = false
- def incl(x: A): Set[A] =
- new NonEmptySet(x, new EmptySet[A], new EmptySet[A])
- }
Scala中的array能够取泛型参数(parameterized types)以及类型变量(type variables)来作其元素的类型。这两项在Scala中是可能的,但在Java中是不可能完成的:
- val xs = new Array[List[Int]](leng)
- val ys = new Array[T](len) // 这里的T是类型变量
要实现array的泛型,必要的步骤就是让array变成非变量(non-variant)。Java没法作到这一点,这是由于其向后兼容的关系。可是,Scala能够作到。
富领域对象:
trait JpaPersistable[T] extends JpaDaoSupport { def getEntity:T; def findAll():List[T] = { getJpaTemplate().find("from " + getEntityClass.getName).toList.asInstanceOf[List[T]] } def save():T = { getJpaTemplate().persist(getEntity) getEntity } def remove() = { getJpaTemplate().remove(getEntity); } def findById(id:Serializable):T = { getJpaTemplate().find(getEntityClass, id).asInstanceOf[T]; } //…more code omitted for readability }
使用=
class Person extends JpaPersistable[Person] with java.io.Serializable { def getEntity = this //…more code omitted for readability }
协变的定义:
假设有类G(或者接口和特征) 和类型T1,T2 。 在T1是T2的子类的状况下, 若是G<T1> 也是G2<T2>的子类,则类G是协变的。
例子:
- class Link[+T](val head : T, val tail: Link[T]) {
- def prepend[U >: T](newHead: U): Link[U] = new Link(newHead, this)
- }
- def main(args : Array[String]){
- val ln : Link[Integer]=new Link[Integer](1,null)
- val lnn : Link[Number]=ln
- println(lnn.head)
- }
Integer是Number的子类,Link[Integer]是Link[Number]的子类,这样父类型的Link[Number]也能接受Link[Integer]
连接:http://doc.chinaunix.net/web/200912/213587.shtml