泛型的使用介绍

 一.泛型的介绍

泛型是Java 1.5的新特性,泛型的本质是参数化类型,也就是说所操作的数据类型被指定为一个参数。这种参数类型可以用在类、接口和方法的创建中,分别称为泛型类、泛型接口、泛型方法。

泛型在使用中还有一些规则和限制: 
1、泛型的类型参数只能是类类型(包括自定义类),不能是简单类型。

2、同一种泛型可以对应多个版本(因为参数类型是不确定的),不同版本的泛型类实例是不兼容的。

3、泛型的类型参数可以有多个。

4、泛型的参数类型可以使用extends语句,例如。习惯上成为“有界类型”。

5、泛型的参数类型还可以是通配符类型。

二.泛型的作用: 

(1)、限定类型就已经有很大作用了,特别是写基础架构的时候,不需要以前那样的检查,我们的代码量和开发速度都可以提升一大截; 
(2)、Think IN JAVA : 能够进行编译期间类型检查;(官方) 
(3)、限定类型啊 通俗点比喻 (箱子贴标签)这个箱子是放苹果的 那个箱子是放橘子的 
( 4 )、封装一些共性问题,可以简化很多代码,使代码更加有层次,简单 
(5)、比object类范围明显缩小了,提高了程序运行的效率

三. 泛型高级(通配符)

 <?>  :代表任意类型Object类型,或者任意的Java类 
 <? extends E>:向下限定,E的子类或者E这个类型
 <? super E>:向上限定,E及其他的父类

public class GenericDemo1 {

	public static void main(String[] args) {
		
		//创建集合对象,泛型如果明确的情况下,前后必须保持一致
				Collection<Object> c1 = new ArrayList<Object>() ;
//				Collection<Object> c2 = new ArrayList<Cat>() ;
//				Collection<Object> c3 = new ArrayList<Animal>() ;
				
				
				//<?>  :代表任意类型Object类型,或者任意的Java类 
				Collection<?> c4 = new ArrayList<Object>() ;
				Collection<?> c5 = new ArrayList<Animal>() ;
				Collection<?> c6 = new ArrayList<Dog>() ;
				Collection<?> c7= new ArrayList<Cat>() ;
				
//				<? extends E>:向下限定,E的子类或者E这个类型
				Collection<? extends Object> c8 = new ArrayList<Object>() ;
				Collection<? extends Object> c9 = new ArrayList<Animal>() ;
				Collection<? extends Object> c10 = new ArrayList<Cat>() ;
//				Collection<? extends Aninal> c11 = new ArrayList<Object>() ;
				
//				<? super E>:向上限定,E及其他的父类
//				Collection<? super Animal> c12 = new ArrayList<Cat>() ;
				Collection<? super Animal> c13 = new ArrayList<Animal>() ;
				Collection<? super Animal> c14 = new ArrayList<Object>() ;



	}
	class Animal{
		
	}
	class Cat extends Animal {
		
	}

	class Dog extends Animal{
		
	}
}

<think>好的,用户想了解TypeScript中的用法。首先,我需要回忆一下的基本概念,以及它在TypeScript中的具体应用。主要是用来增强代码的可重用性和类安全,允许在定义函数、接口或类时不预先指定具体类,而是在使用时再指定。 根据用户提供的引用内容,引用[2]提到了如何定义函数,使用<T>来声明,并在函数参数和返回值中使用。引用[1]和引用[3]则涉及接口和类的例子。需要把这些内容整理成用户容易理解的步骤。 首先,应该从函数开始讲解,这是最基础的部分。然后介绍接口,说明如何定义带有的接口,并给出例子。接着是类,展示在类中使用的方法。最后可以提到约束,虽然用户提供的引用中没有直接提到,但这也是的一个重要部分,可以补充说明,比如使用extends关键字限制类范围。 需要注意用户提供的示例代码,确保在回答中正确引用这些例子,比如引用[2]中的identity函数,引用[3]中的Hello接口和HelloNumber类。要检查这些代码是否符合TypeScript的语法,比如函数和接口的定义是否正确。 用户可能对使用场景不太清楚,可能需要解释为什么使用,比如避免any类带来的类信息丢失,提高代码灵活性和安全性。此外,可能还需要提到在数组、Promise等常见场景中的应用,但根据提供的引用,可能需要集中在函数、接口和类上。 最后,生成相关问题时要围绕的其他方面,比如约束、默认类、高级类等,或者与其他语言(如Java、C#)的比较,帮助用户进一步学习。</think>### TypeScript 中使用方法 (Generics)是 TypeScript 中用于增强代码复用性和类安全的重要特性,允许在定义函数、接口或类时**不预先指定具体类**,而是在使用时动态指定。以下是具体用法: --- #### 1. 函数 定义函数时,使用 `<T>` 声明(`T` 是占位符,可替换为其他名称),参数和返回值均可使用该类: ```typescript function identity<T>(arg: T): T { return arg; } // 显式指定类 const strResult = identity<string>("hello"); // 类为 string // 类推断 const numResult = identity(100); // 类自动推断为 number ``` **作用**:避免使用 `any` 导致的类信息丢失,同时支持多种类[^2]。 --- #### 2. 接口 接口中可通过定义灵活的类结构: ```typescript interface Hello<T> { (arg: T): T; } function myHello<T>(arg: T): T { return arg; } // 指定接口为 number const mh: Hello<number> = myHello; console.log(mh(100)); // 输出 100 ``` **用途**:常用于回调函数或对象方法的类约束[^3]。 --- #### 3. 类 类可以通过定义属性或方法的类: ```typescript class HelloNumber<T> { zero: T; add: (x: T, y: T) => T; } // 实例化时指定为 number const myHelloNumber = new HelloNumber<number>(); myHelloNumber.zero = 0; myHelloNumber.add = (x, y) => x + y; console.log(myHelloNumber.add(10, 20)); // 输出 30 ``` **优势**:类的内部逻辑可复用,同时保持类一致性。 --- #### 4. 约束 通过 `extends` 限制的范围: ```typescript interface Lengthwise { length: number; } function logLength<T extends Lengthwise>(arg: T): void { console.log(arg.length); } logLength("hello"); // 输出 5(字符串有 length 属性) logLength([1, 2, 3]); // 输出 3 ``` **适用场景**:需要满足特定条件时(如必须包含某个属性)。 --- #### 典应用场景 - **数据处理函数**:如排序、转换等需支持多种类的工具函数。 - **集合类**:数组、栈、队列等容器类的实现。 - **API 响应封装**:统一处理不同类的数据返回值。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值