泛型简单使用

泛型:是一种把类型明确的工作推迟到创建对象或者调用方法的时候才去明确的类型,参数化类型,把类型当做参数一样传递。

格式:

<数据类型>

此处的数据类型只能是引用

好处:

A:把运行的时期的问题提前到了编译期间

B:避免强制类型转换

C:优化了程序设计,解决了黄色警告线

泛型类

把泛型定义在类上

格式:public class 类名<泛型类型1,....>

注意:泛型类型必须是引用类型

泛型方法

把泛型定义在方法上

格式:public <泛型类型> 返回类型 方法名<泛型类型>

泛型接口

把泛型定义在接口上

格式:public interface 接口名 <泛型类型1,........>

实现类在实现接口的时候

第一种情况:已经知道是什么类型的了

第二种情况:还不知道是什么类型的

泛型高级(通配符)

泛型通配符<?>

任意类型,如果没有明确,那么就是Object以及任意的java类了。

? extends E

向下限定,E及其子类

? super E

向上限定,E及其父类

泛型写的时候前后必须 一致

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在TypeScript中,泛型是一种用于创建可以多种类型上工作的可重用代码的技术。使用泛型可以增强代码的灵活性和类型安全性。 要使用泛型,可以在函数、类或接口的定义中使用尖括号(<>)来指定泛型参数。例如,以下是一个使用泛型简单示例: ```typescript function identity<T>(arg: T): T { return arg; } let result = identity<number>(5); console.log(result); // 输出:5 ``` 在上面的例子中,`identity`函数使用了一个泛型参数`T`,它表示函数的参数和返回值的类型是一致的。我们在调用`identity`函数时,显式指定了泛型参数为`number`,因此返回值的类型为`number`。 另外,还可以使用泛型约束来限制泛型参数的类型。例如,如果希望泛型参数必须具有某种特定属性,可以使用泛型约束来实现: ```typescript interface HasLength { length: number; } function printLength<T extends HasLength>(arg: T): void { console.log(arg.length); } printLength("Hello"); // 输出:5 printLength([1, 2, 3]); // 输出:3 printLength({ length: 10 }); // 输出:10 ``` 在上述示例中,`printLength`函数使用了一个泛型约束`T extends HasLength`,它表示泛型参数`T`必须具有`length`属性。因此,我们可以传递包含`length`属性的字符串、数组或对象作为参数,函数会打印出其长度。 通过使用泛型,我们可以编写更加通用和灵活的代码,可以在多种类型上进行操作而不需要重复编写逻辑。同时,TypeScript的类型检查器也能够在编译时检测出类型错误,提供更高的类型安全性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值