首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

【Kotlin】标准库函数 ② ( run 标准库函数 | run 函数传入 Lambda 表达式作为参数 | run 函数传入函数引用作为参数 )

文章目录 一、run 标准库函数 1、run 函数传入 Lambda 表达式作为参数 2、run 函数传入函数引用作为参数 Kotlin 语言中 , 在 Standard.kt 源码中 , 为所有类型定义了一批标准库函数..., 所有的 Kotlin 类型都可以调用这些函数 ; 一、run 标准库函数 ---- 1、run 函数传入 Lambda 表达式作为参数 run 标准库函数原型如下 : /** * 调用以' this...Lambda 表达式 作为参数 , 该 run 函数的 返回值 就是 Lambda 表达式 的返回值 ; 代码示例 : 在下面的代码中 , run 函数的 Lambda 表达式参数 返回的是 boolean...(ret) } 执行结果 : true 2、run 函数传入函数引用作为参数 在上述函数原型中 : public inline fun T.run(block: T.() -> R):...R {} run 函数 , 传入 T.() -> R 类型 的 函数参数 , 此处也可以传入 函数引用 ; 利用 run 函数的该用法 , 可以进行链式调用 ; 代码示例 : 在下面的代码中 , "hello

84710

with、run函数使用教程

run 1、run函数使用的一般结构 object.run{ //todo } 2、run函数的inline+lambda结构 @kotlin.internal.InlineOnly public inline...fun T.run(block: T.() -> R): R = block() 3、run函数的inline结构分析 run函数实际上可以说是let和with两个函数的结合体,run...因为run函数是let,with两个函数结合体,准确来说它弥补了let函数函数体内必须使用it参数替代对象,在run函数中可以像with函数一样可以省略,直接访问实例的公有属性和方法,另一方面它弥补了...apply函数run函数很像,唯一不同点就是它们各自返回的值不一样,run函数是以闭包形式返回最后一行代码的值,而apply函数的返回的是传入对象的本身。...整体作用功能和run函数很像,唯一不同点就是它返回的值是对象本身,而run函数是一个闭包形式返回,返回的是最后一行的值。

55600
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    【Kotlin】标准库函数总结 ( apply 函数 | let 函数 | run 函数 | with 函数 | also 函数 | takeIf 函数 | takeUnless 函数 )

    文章目录 一、apply 标准库函数 二、let 标准库函数 三、run 标准库函数 1、run 函数传入 Lambda 表达式作为参数 2、run 函数传入函数引用作为参数 四、with 标准库函数...---- 1、run 函数传入 Lambda 表达式作为参数 run 标准库函数原型如下 : /** * 调用以' this '值为接收者的指定函数[block],并返回结果。...Lambda 表达式 作为参数 , 该 run 函数的 返回值 就是 Lambda 表达式 的返回值 ; 代码示例 : 在下面的代码中 , run 函数的 Lambda 表达式参数 返回的是 boolean...(ret) } 执行结果 : true 2、run 函数传入函数引用作为参数 在上述函数原型中 : public inline fun T.run(block: T.() -> R):...R {} run 函数 , 传入 T.() -> R 类型 的 函数参数 , 此处也可以传入 函数引用 ; 利用 run 函数的该用法 , 可以进行链式调用 ; 代码示例 : 在下面的代码中 , "hello

    2.3K10

    JS函数

    (){ console.log("hello js") } sayHello() 参数 形式参数 : 在函数声明时, 设置的参数。...//带参数的函数声明 function 函数名(形参1, 形参2, 形参...){ //函数体 } //带参数的函数调用 函数名(实参1, 实参2, 实参3); 计算2个数的和 ...函数作用域 :在 函数内的区域 叫做函数作用域,在函数作用域内声明的变量叫做局部变量 ,局部变量只有在当前函数内才能访问到。...预解析 js执行代码分为两个过程: 预解析过程(变量与函数提升) 代码一行一行执行 console.log(num); var num = 1 console.log(num) 预解析过程 把var声明的变量提升到当前作用域最前面...把函数声明提升到当前作用域的最前面。 如果函数同名 , 后者会覆盖前者 。 如果var声明的和函数声明的同名, 函数优先。

    11.1K40

    JS函数

    函数定义        函数是由事件驱动的或者当它被调用时执行的可重复使用的代码块;       函数就是包裹在花括号中的代码块       function 函数名()       {        ...这里是要执行的代码      } 二 函数的声明和调用    函数的声明必须使用关键字function    关键词 function 必须是小写的,并且必须以与函数名称相同的大小写来调用函数    函数本身不会自动运行...,只有当调用该函数时,才会执行函数内的代码    函数可以通过其名字加上括号中的参数进行调用 三 带有返回值的参数      使用return 语句来返回值 可以将返回值赋值给一个变量,然后对变量进行操作...四 arguments对象    在函数代码中,使用特殊对象 arguments存储函数调用传递给该函数的所有参数   可以用 arguments 对象检测函数的参数个数,引用属性 arguments.length...sun+=arguments[i]; } return sun; } var s= sum(2,3,4,5);//虽然sum函数时没有参数的

    5.3K20

    Python run()函数和start()函数的比较和差别介绍

    run() 方法并不启动一个新线程,就是在主线程中调用了一个普通函数而已。 start() 方法是启动一个子线程,线程名就是自己定义的name。...()”) t1 = threading.Thread(target=worker, name=“MyTryThread”) t1.run() print(“run() test end”) 运行结果:...()方法启动,但却是先运行t1.run(),运行完之后才按顺序运行t2.run(),两个线程都工作在主线程,没有启动新线程,thread ID都是一样的,因此,run()方法仅仅是普通函数调用。...() t2.run() print(“run() test end”) 运行结果: Start Test run() thread name = MainThread, thread id = 3920...()函数和start()函数的比较和差别介绍就是小编分享给大家的全部内容了,希望能给大家一个参考。

    2.2K40

    Run():

    中间件分类 ASP.NET Core 中间件的配置方法可以分为以上三种,对应的Helper方法分别是:Run(), Use(), Map()。...Run(),使用Run调用中间件的时候,会直接返回一个响应,所以后续的中间件将不会被执行了。...Run():  这是一个使用Run方法调用的中间件,Run方法会终止整个中间件管道,它应该返回某种类型的响应。 Use():  Use看起来和Run差不多,但是多了一个next参数。...在本例中,我们下面还使用了Run方法注册了另一个中间件。因为中间件会按照它们注册的顺序进行调用,所以在第一个Use方法里执行next.Invoke()的时候,就会执行下面Run所调用的中间件。...中间件的类需要类似这样:  自定义的中间件类需要由这几部分组成: 接受一个RequestDelegate类型的参数next的构造函数。 按约定,还需要定义一个叫做Invoke的方法。

    1.6K31

    JS函数hook

    前言​ 我在阅读《JavaScript 设计模式与开发实践》的第 15 章 装饰者模式,突然发现 JS 逆向中 hook 函数js 中的装饰者模式有点像,仔细阅读完全篇后更是对装饰器与 hook...书中给的例子想说明的,想为某个原函数(比如这里的 add)添加一些功能,但该原函数可能是由其他开发者所编写的,那么直接修改原函数本身将可能导致未知 BUG,于是便可以用上面的方式进行复写原函数的同时,还不破坏原函数...this 指向问题​ 但并不是什么函数都能这样操作,或者说这样操作会导致原本函数可能执行不了,比如 this 指向,虽说没有修改原函数,但是原函数的 this 已经给我们更改成当前环境下(如window...,而后者通过函数原型链将参数与结果通过回调函数的形式进行使用。...在不考虑 this 指向,我个人更偏向第一种写法,而第二种写法也确实让我眼前一亮,很巧妙的使用 js 的原型链,从而避免 this 指向的问题。

    3.5K10

    js中的匿名函数_js匿名函数怎么定义

    定义:匿名函数顾名思义指的是没有名字的函数,在实际开发中使用的频率非常高!也是学好JS的重点。 匿名函数:没有实际名字的函数。...首先我们声明一个普通函数: //声明一个普通函数函数的名字叫fn function fn(){ console.log(“张培跃”); } 然后将函数的名字去掉即是匿名函数: //匿名函数...解决方法只需要给匿名函数包裹一个括号即可: //匿名函数在其它应用场景括号可以省略 (function (){ //由于没有执行该匿名函数,所以不会执行匿名函数体内的语句。...console.log("张培跃"); }) 如果需要执行匿名函数,在匿名函数后面加上一个括号即可立即执行!...在这里简单介绍一下:闭包是可以访问在函数作用域内定义的变量的函数。若要创建一个闭包,往往都需要用到匿名函数。 2、模拟块级作用域,减少全局变量。

    10.3K10

    扫码

    添加站长 进交流群

    领取专属 10元无门槛券

    手把手带您无忧上云

    扫码加入开发者社群

    相关资讯

    热门标签

    活动推荐

      运营活动

      活动名称
      广告关闭
      领券