当前位置: 首页 > news >正文

公司免费网站搭建多用户建站平台

公司免费网站搭建,多用户建站平台,互联网医疗,佛山网站建设企业目录 泛型的概念 接口是对方面的描述(Aspect),继承其中几个方法。重定义方法 泛型是对共性的提取 泛型(Generics) 泛型的例子 泛型类 推荐写法 泛型约束 keyof操作符 泛型的特化(实例化&#xff…

目录

泛型的概念

接口是对方面的描述(Aspect),继承其中几个方法。重定义方法

泛型是对共性的提取

泛型(Generics)

泛型的例子

泛型类

推荐写法

泛型约束

keyof操作符

泛型的特化(实例化)

小结


泛型的概念

  • 对比这3个概念,思考他们的区别:
    • interface(接口)
      • Car is runnable
    • Extend(继承)
      • Car is machine
    • Generics(泛型)
      • Runnable
// 接口写法
interface Runnable { // 接口run() : number
}
interface Repairable {repaire(): void
}
class Car implements Runnable, Repairable {run() : number {return 1    }repaire(){return    }
}
// 继承写法;不是首选,因为它的祖类可能功能太多了,不一定适应子类
class XXXCar extends Car {run() : number {return 1    }repaire(){return    }
}

接口是对方面的描述(Aspect),继承其中几个方法。重定义方法

  • 小孩可以长大
    • 小孩是Growable
  • 动物可以进化
    • 人是Evolvable

泛型是对共性的提取

  • 木头可以做桌子
    • 木头是:DeskMakable?
    • 木头还可以:burn/wash/play...(耦合)
  • 泛型的表达
    • DeskMaker<Wood>
    • DeslMaler<Iron>
interface Material {getHardness(): number;
}
class DeskMake <T extends Material> { // 做桌子的泛型material : T // 材料make() {const hardness = this.material.getHardness()    }
}
// 泛型的解耦
const maker = new DeskMaker<Wood>()// 做木头桌子
const maker = new DeskMaker<Iron>()// 做铁桌子

泛型(Generics)

  • 对共性的抽象
  • 将类型作为参数
  • 更好的分离关注点

泛型的例子

// 一个identity函数是自己返回自己的函数
// 当然可以声明它是:number =>number
function identity(arg:number): number {return arg;
}
// 为了让identity支持更多类型可以声明它是any
function identity(arg:any):any {return arg;
}
// any会丢失后续的所有检查,因此可以考虑用泛型
function identity<Type>(arg:Type): Type {return arg;
}
let output = identity<string>("MyString")
// 不用显示的指定<>中的类型
// let output = identity("MyString")
output = 100 // Error

泛型类

class GenericNumber<NumType> {zeroValue: NumType;add: (x: NumType, y : NumType) => NumType;
}
let myGenericNumber = new GenericNumber<number>();
myGenericNumber.zeroValue = 0;
// (number, number) -> number
myGenericNumber.add = function (x,y) {return x + y;
}
let stringNumeric = new GenericNumber<string>();
stringNumeric.zeroValue = "";
stringNumeric.add = function (x,y){return x + y;
}

推荐写法

class GenericNumber<T> {zeroValue: Tconstructor(v:T) { // 构造器this.zeroValue = v    }add(x:T,y:T) {return x + y    }
}

泛型约束

type lengthwise = {length: number
}
interface lengthwise {length: number
}
function loggingIdentity<Type extends {length: number
}>(arg: Type): Type {console.log(arg.length);return arg
}

keyof操作符

type Point = { x:number; y: number };
type P = keyof Point;
// P = "x" | "y"
function foo(x: keyof Point) {}

泛型的特化(实例化)

function create<Type>(c: { new(): Type }): Type {return new c();
}
create(Array) // Array的实例 => new Array()
create(Array<string>)// Error,不能完全替代实例化函数 

小结

  • 泛型解决了什么问题?解决了在我们做程序设计的时候,对于很多共性的抽象的问题,同时也解决了很多共性问题类型设计不够严格的问题。
  • 什么时候用接口?什么时候用泛型?当你想约束一个类型,它有哪些成分的时候用接口,当你想提取一类东西共性的时候我们用泛型
  • 下面方法是否成立?不成立
function add<T>(a:T,b:T){return a + b
}

http://www.mmbaike.com/news/37255.html

相关文章:

  • 简洁 手机 导航网站模板下载专业整站优化
  • 湛江宇锋网站建设太原整站优化排名外包
  • 自己做网站商城需要营业执照吗站长之家seo综合查询
  • WordPress首页做成插件百度seo优化技术
  • 企业网站建站免费b站在线观看人数在哪里找到
  • 党政廉风建设网站西安seo全网营销
  • 上海今天死亡新闻seo推广教程
  • 怎么制作网站设计图片成都网站推广哪家专业
  • 网站是用什么编程语言编写的优化设计三年级上册答案
  • 网站建设的相关费用宁德市属于哪个省份
  • 做网站的产品图片百度招聘平台
  • nodejs做的网站网页设计网站
  • 程序员创业做网站做公众号网页模板网站
  • 网站建设创业计划书模板范文淘宝关键词
  • 有没有可以做app的网站整站优化提升排名
  • 网站建设公司的服务公司做网站排名服务热线
  • 素材分享网站源码织梦seo排名优化教程
  • 杭州高端网站制作代发新闻稿最大平台
  • element ui做门户网站注册安全工程师
  • 怎么给网站做开场动画百度贴吧官网app下载
  • wordpress 模板 中文乱码seo优化推广技巧
  • 投资融资理财网站模板促销活动推广语言
  • 领导视察网站建设杭州seo网站推广
  • 凡人网站建设朋友圈营销
  • 网站关键字优化工具晋江怎么交换友情链接
  • 大连承接网站制作百度点击软件名风
  • 杭州设计网站的公司哪家好恢复正常百度
  • 自己建的网站打开的特别慢近期的重大新闻
  • 公司介绍模板ppt宁波专业seo外包
  • 最简单的手机网站制作图们网络推广