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

如何查看一个网站是用什么程序做的世界排名前十位

如何查看一个网站是用什么程序做的,世界排名前十位,什么软件可以制作网页封面,怎样在手机上做自己的网站文章目录 定义泛型属性泛型函数泛型类或接口 where 声明多个约束泛型具体化in、out 限制泛型输入输出 定义 有时候我们会有这样的需求:一个类可以操作某一类型的对象,并且限定只有该类型的参数才能执行相关的操作。 如果我们直接指定该类型Int&#xff…

文章目录

  • 定义
    • 泛型属性
    • 泛型函数
    • 泛型类或接口
  • where 声明多个约束
  • 泛型具体化
  • in、out 限制泛型输入输出

定义

有时候我们会有这样的需求:一个类可以操作某一类型的对象,并且限定只有该类型的参数才能执行相关的操作。
如果我们直接指定该类型Int,确实可以实现该操作,但是换一个类型就得再重新定义一个类:

class MyArray {fun add(int: Int) {}fun delete(int: Int) {}
}fun main() {val myArray = MyArray()myArray.add(1)myArray.delete(1)
}

如果我们将类型改为Any,又会导致可操作参数太过笼统,还容易出现各种问题:

class MyArray {fun add(any: Any) {}fun delete(any: Any) {}
}fun main() {val myArray = MyArray()myArray.add(1)myArray.delete("abc")
}

这时候我们需要引入泛型。泛型的定义方式如下:

<泛型名[: 泛型所属类型], ...>

一般情况下,泛型名会是单个的大写字母,很多时候是T,而泛型所属类型可以指定泛型是某个类/接口或者其子类/实现(当然,单独这样写做不了什么,请继续往下看):

<T>
<T: Runnable>
<K, V>

泛型属性

在 Kotlin 中,可以为一个类定义扩展属性:

class MyClassval MyClass.name get() = "MyClass"

如果我们要指定是任何类都有的属性,则可以泛型。
泛型属性只能用在扩展,声明时需要将泛型定义放置在val|var后,变量名前。

val <T> T.name get() = "Any"fun main() {val int = 1print(int.name)
}
Any

也可以限制该泛型是Runnable接口或其实现。

val <T: Runnable> T.name get() = "Runnable"fun main() {val int = 1// print(int.name) 不可访问print(Runnable {  }.name)
}
Runnable

泛型函数

我们也可以为函数泛型,与泛型扩展属性类似,泛型定义需要写在fun和函数名之间(意外发现此时as如果无法转换不会抛出异常,而是返回any):

fun <T> cast(any: Any) = any as Tfun main() {cast<List<Double>>(listOf(1, 2)).forEach { print(it); print(", ") }
}
1.0, 2.0, 

Note:泛型可以作为函数接收者、参数、返回值类型的一部分。如果一个泛型函数在调用时可以通过传入的参数类型或返回值声明确定泛型的类型,则调用时泛型的类型可以缺省,否则需要指明其类型函数名<泛型类型, ...>()(泛型类与此类似)。

声明两个泛型(涉及到的 Kotlin 一些便捷的习语我们将在后续文章学习):

fun <K, V> hashMap(vararg pairs: Pair<K, V>) =HashMap<K, V>().apply { putAll(pairs) }fun main() {print(hashMap("key" to 1))
}
{key=1}

泛型扩展函数:

// List 类是一个泛型类
// 可以将它的泛型指定为函数的泛型
fun <T> List<T>.print() = print(this)fun main() {listOf(1, 2, 3).print()
}
[1, 2, 3]
fun <T: Comparable<Int>> T.isGreaterZero() = this > 0fun <T: Comparable<Int>> T.isGreaterZero() = this > 0fun main() {val int = 1// Int 实现了 Comparable<Int>// 因此可以调用print(int.isGreaterZero())
}
true

作为返回值:

fun <T> Any.toType() = this as Tfun main() {// 没有指定变量类型,无法推断泛型的类型// 因此调用时需要声明泛型类型val doubleList = listOf<String>().toType<List<Double>>()val intList: List<Double> = listOf<String>().toType()
}

泛型类或接口

在定义泛型类或接口时,需要将泛型定义放置在类名之后,括号之前。
泛型函数与接口是类似的,这里以类为例。

class Group<T>(vararg elements: T) {private val value = mutableListOf(*elements)fun add(element: T) = value.add(element)fun remove(element: T) = value.remove(element)// 重写 toString,调用 print 时即可打印出列表override fun toString(): String = value.toString()
}fun main() {val group = Group(1, 2, 3) // Group<Int>(1, 2, 3)println(group)group.remove(2)println(group)group.remove(4)print(group)
}
[1, 2, 3]
[1, 3]
[1, 3]

Note:vararg用于定义数量不定的参数,vararg element: Int表示你可以传入任意数量(0…无限大)的Int类型,在内部访问element会获取到一个数组Array<Int>,而使用*可以将其展开为vararg(也就是原始传入的任意数量的Int),可以用于传入另一个需要vararg的函数。

使用*可以指代所有泛型(下方例子中相当于Any?*无法用在函数调用上):

fun List<*>.print() = print(this)fun main() {listOf(1, 2, 3).print()println()listOf("a", "b", "c").print()
}
[1, 2, 3]
[a, b, c]

where 声明多个约束

我们可以使用<T: 类型>来约束泛型为某一类型或其子类。但有时候我们想要将其约束于多个类型,可以使用where来实现(此时<T: 类型>中的类型也应该一并移到where处):
我们先定义一个接口和一个类,后面的例子会反复用到:

interface MyInterfaceclass MyClass : Runnable, MyInterface {override fun run() {}
}
  1. 泛型扩展属性

    // 只有实现了 Runnable 和 MyInterface 才能拥有此扩展属性
    val <T> T.id where T: Runnable, T: MyInterfaceget() = 123fun main() {MyClass().id
    }
    
  2. 泛型函数

    // 只有实现了 Runnable 和 MyInterface 才能拥有此扩展函数
    fun <T> T.getId() where T : Runnable, T : MyInterface = 123// 只有泛型 T 实现了 Runnable 和 MyInterface 才能使用此函数
    fun <T> getName() where T : Runnable, T : MyInterface ="Runnable&MyInterface"fun main() {MyClass().getId()getName<MyClass>()
    }
    
  3. 泛型类或接口

    // 只有实现了 Runnable 和 MyInterface 才能作为构造参数 value 传入
    class MyContainer<T>(val value: T) where T : Runnable, T : MyInterfacefun main() {MyContainer(MyClass())
    }
    

泛型具体化

有时候我们需要判断泛型的类型,会想到用类型::class获取对应的KClass进行对比。而当该类型为泛型时,我们需要将其具象化reified,通常该声明只能用于函数,并且需要与inline搭配使用:

inline fun <reified T> T.isInt() = T::class == Int::classfun main() {println(1.isInt())print(false.isInt())
}
true
false

in、out 限制泛型输入输出

inout修饰泛型只能用在类或接口。
当一个泛型被in修饰时,表明该类型只能作为对象属性、方法的输入(赋值、传参):

class Group<in T>(vararg elements: T) {// 因为泛型声明为 in,属性类型中包含 T 可见性只能为 privateprivate val value = mutableListOf(*elements)fun add(element: T) {}// 因为泛型声明为 in,不能定义返回 T 类型的方法// fun get(index: Int) = value[index]
}

当一个泛型被in修饰时,表明该类型只能作为对象属性、方法的输出(获取值、函数返回):

class Group<out T>(vararg elements: T) {// 因为泛型声明为 out,而 MutableList<T> 具有 in 和 out// 若将其公开,将会允许 in T,例如 value.add(element: T)// 属性类型中包含 T 可见性只能为 privateprivate val value = mutableListOf(*elements)// 因为泛型声明为 out,不能作为参数类型// fun add(element: T) {}fun get(index: Int) = value.get(index)
}

Note:注意是针对对象而言,如果是一个类声明了out泛型,仍然可以将该泛型作为构造函数中的参数类型。

class Group<out T>(vararg elements: T)
http://www.khdw.cn/news/13242.html

相关文章:

  • 学校网页网站模板免费下载网站开发建设步骤
  • 搬瓦工做网站方法上海搜索引擎关键词优化
  • 深圳企业做网站公西地那非片
  • 电子商务毕业设计网站建设营销系统
  • 做暖暖视频免费视频老司机网站网站seo关键词排名
  • 科技公司名称大全简单大气西安优化外
  • 购物网站怎么运营推广申请网站怎么申请
  • 汽车用品网站建设策划书怎么做app推广
  • 网站平台代理最近的国际新闻大事
  • 微擎怎么做网站地推app
  • 可信网站必须做吗郑州专业seo哪家好
  • 公司找人做的网站到现在还没出来主流网站关键词排名
  • 建搜索引擎网站百度网站权重查询
  • 音乐网站建设目标网络营销渠道有哪些
  • 网站开发 鲁山微信营销平台
  • 如何推广企业网站百度地图疫情实时动态
  • 手机手机网站开发永久免费google搜索引擎
  • dw网站站点建立后怎么做十大接单推广平台
  • WordPress工具站点怎样做网络推广
  • 电商培训靠谱吗商丘seo公司
  • 成都asp网站建设分析网站
  • 个人简历模板word格式免费下载b2b网站推广优化
  • 营销型网站建设是什么竞价推广平台有哪些
  • 有做门窗找活的网站吗南京网站seo
  • 网站建设的er图软件开发培训机构去哪个学校
  • wordpress a赣州seo外包怎么收费
  • 国内做化妆刷的比较好的网站下载地图导航手机版免流量费用
  • 电子商务网站建设文案舆情分析报告案例
  • 农村自建房设计网站高权重友情链接
  • 网页拖拽设计工具简阳seo排名优化课程