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

【Kotlin】安全 ④ ( 手动安全管理 | 合并操作 ?: | 合并操作与 let 函数结合使用 )

文章目录 一、合并操作 ?: 二、合并操作与 let 函数结合使用 一、合并操作 ?: ---- 合并操作 ?: 用法 : 表达式 A ?...: "name 变量为" 代码 , 其效果如下 : 合并操作 左侧的 name 表达式如果为 null , 则 取 右边的 表达式 作为该表达式最终的值 , 如果 左侧的 name 表达式 不为...: "name 变量为" 代码时 , name 为 , 整个表达式 name ?...: "name 变量为" 返回的是 "name 变量为" 值 , 打印出来的就是 name 变量为 内容 ; 之后 为 name 变量赋值 "Tom" 字符串值 , 现在 name 变量不为 ,...: "name 变量为") } 执行结果 : name 变量为 Tom 二、合并操作与 let 函数结合使用 ---- 合并操作 ?

86720

【Kotlin】安全 ② ( 手动安全管理 | 安全调用操作 ? | let 函数结合安全调用操作使用 )

文章目录 一、手动安全管理 二、安全调用操作 ?...三、let 函数结合安全调用操作使用 一、手动安全管理 Kotlin 语言中 , 变量类型 分为 可类型 和 非类型 , 默认状态 下 , 变量是 非类型 的 , 如果使用 类型?...二、安全调用操作 ? 在 Kotlin 语言中 , 调用 可类型变量 的 成员 时 , 可以使用 " 安全调用操作 " 也就是 ? 进行调用 , 使用格式如下 : 可类型变量?....成员 使用了 安全调用操作 之后 , 在调用变量成员前 , 会自动进行 值检查 , 如果该变量为 , 则会 跳过后面的 成员调用 , 继续执行下一行代码 ; 代码示例 : 在下面的代码中 , 调用...count() } 三、let 函数结合安全调用操作使用 如果想要在 变量 原有基础上 , 继续执行其它操作 , 可以使用 let 标准函数 ; 安全调用操作 经常与 let 标准函数 一起使用

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

    【Kotlin】安全总结 ( 变量可空性 | 手动安全管理 | 安全调用操作 | 非断言操作 | 合并操作 | 指针异常处理 | 先决条件函数判 )

    五、let 函数结合安全调用操作使用 六、非断言操作 !! 七、使用 if 语句判 八、合并操作 ?...非断言操作 !! 之外 , 还可以使用 Java 语言中的传统判方式 , 即 if 语句判断 变量 是否为 null ; 安全调用操作 ?...与 使用 if 语句判操作 对比 : 安全调用操作 更加 灵活 , 简洁 ; 安全调用操作 可以进行 链式调用 ; 二者的效果是等价的 ; 代码示例 1 : 下面的代码是 使用 if 语句判...count() println(count) } 执行结果 : null 八、合并操作 ?: ---- 合并操作 ?: 用法 : 表达式 A ?...: "name 变量为") } 执行结果 : name 变量为 Tom 九、合并操作与 let 函数结合使用 ---- 合并操作 ?

    1.7K10

    值合并运算(??)

    bug收集:专门解决与收集bug的网站 网址:www.bugshouji.com 今天给大家分享值合并运算(??)...官方在 ES2020 版本里就出了一个叫“值合并运算”的东西,官方的解释是: 值合并操作(??)...rightExpr 应用1:为常量提供默认值 使用值合并运算为常量提供默认值,保证常量不为 null 或者 undefined。...直接与 AND(&&)和 OR(||)运算组合使用是不可取的。(译者注:应当是因为值合并运算和其他逻辑运算之间的运算优先级/运算顺序是未定义的)这种情况下会抛出 SyntaxError 。..."foo"; // 返回 "foo" 应用5:与可选链式运算(?.)的关系 值合并运算针对 undefined 与 null 这两个值,可选链式运算(?.) 也是如此。

    1.4K10

    【Kotlin】安全 ③ ( 手动安全管理 | 非断言操作 !! | 使用 if 语句判 )

    文章目录 一、非断言操作 !! 二、使用 if 语句判 一、非断言操作 !!...---- Kotlin 中的 可类型 变量 , 在运行时 可以选择 不启用 安全调用 操作 , 在调用 可类型 变量 成员 与 方法 时 , 使用 非断言操作 !!...---- 在 Kotlin 中 , 对于 可类型 变量的调用 , 除了使用 安全调用操作 ?...非断言操作 !! 之外 , 还可以使用 Java 语言中的传统判方式 , 即 if 语句判断 变量 是否为 null ; 安全调用操作 ?...与 使用 if 语句判操作 对比 : 安全调用操作 更加 灵活 , 简洁 ; 安全调用操作 可以进行 链式调用 ; 二者的效果是等价的 ; 代码示例 1 : 下面的代码是 使用 if 语句判

    1.9K10

    TypeScript 值合并运算(??)

    答案就是可以使用 TypeScript 3.7 版本提供的值合并运算(??)。 二、值合并运算 值合并运算(??)是一个逻辑运算。..._b : 42; console.log(baz); // 输出:0 通过观察以上代码,我们更加直观的了解到,值合并运算是如何解决前面 || 运算存在的潜在问题。...下面我们来继续介绍值合并运算的特性和使用时的一些注意事项。 三、短路 当空值合并运算的左表达式不为 null 或 undefined 时,不会对右表达式进行求值。..."foo"; // 返回 "foo" 五、与可选链操作 ?. 的关系 值合并操作针对 undefined 与 null 这两个值,可选链式操作(?.) 也是如此。..."Unknown city"; console.log(customerCity); // 输出:Unknown city 前面我们已经介绍了值合并运算的应用场景和使用时的一些注意事项,该运算不仅可以在

    3.5K10

    JavaScript值合并运算

    ❝「目录」 使用 JavaScript 值合并运算 使用实例 值合并运算与逻辑或( ||) 浏览器支持 总结 ❞ 在ES2020中,我们获得了在其他语言中( 如 C# 和 PHP)早已可用的功能...:值合并运算[2]。...❝值合并运算将会遍历列表,并返回第一个不是 null[3] 或 undefined[4] 的值。 ❞ 重要的是要注意,值合并运算仅查找 null 或 null 值。...值合并运算接受虚值(Falsy values[5])。 ? 使用 JavaScript 值合并运算 让我们看一些例子。请记住,JavaScript 的值合并运算将遵循 ??...合并运算与逻辑或(||) 如果要消除虚值,可以用 逻辑或运算[6] (||)。 ❝本质上,它与合并运算的作用相同,只是它消除了虚值。

    1.5K50

    类型及其衍生运算

    在声明和使用中,以下两种情况是不允许的: 以下情况则可以(了解VS的同学会知道,类型颜色变灰说明此处可以简化,这就涉及到它的一个衍生运算,我们后边讲): 可类型,可以像引用类型一样...运算 为了进一步简化处理可类型的代码量,微软引入 ??...运算 ,这个运算结合运算(null coalescing operator) ,这是一个二元运算,目的是为了数据为的情况下,提供默认值 a为,就返回1,用法很简单,a不为,...运算 为了避免可类型或者引用类型在引用时引发的NullReferenceException异常,微软又引入了 ?....空条件运算,请看代码(举个稍微不恰当的例子): 有一 Person 类,我们可能获取到的数据对象(此处直接赋值为),后续直接调用其方法就会引发异常, 下面改用空条件运算,程序正常运行

    39720

    : 值合并运算

    在ECMAScript 2021 (ES12)中,引入了一个新的运算值合并运算(Nullish Coalescing Operator)。...该运算为我们提供了一种更简洁、更清晰的方式来处理这种情况,使代码更加简洁、易读。 值合并运算用两个问号(??)表示。它的工作方式非常直观:它检查第一个操作数是否为null或undefined。...通过一个简单的例子来理解值合并运算: let value1 = null; let value2 = "zhangsan"; let result = value1 ??...value2; console.log(result); // zhangsan 在这个例子中,value1被赋值为null,所以当使用值合并运算时,结果会是value2的值,即"zhangsan"...值得注意的是,值合并运算与逻辑或运算(||)在处理假值方面存在差异。逻辑或运算会检查其操作数是否为假值(如false、0、""等),而值合并运算只关心null和undefined。

    19010

    前端HTML空格转义总结

    HTML提供了5种空格实体(space entity),它们拥有不同的宽度。 非断行空格( )是常规空格的宽度,可运行于所有主流浏览器。...在HTML中,如果你用空格键产生此空格,空格是不会累加的(只算1个)。要使用html实体表示才可累加,该空格占据宽度受字体影响明显而强烈。...名义上是小写字母n的宽度。此空格传承空格家族一贯的特性:透明的,此空格有个相当稳健的特性,就是其占据的宽度正好是1/2个中文宽度,而且基本上不受字体影响。...零宽连字符的Unicode码位是U+200D (HTML: ‍ ‍)。...发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/185933.html原文链接:https://javaforall.cn

    4.2K20

    Python换行问题:rn还是n

    因为不同系统下默认的换行不同。字符处理时候,这样的“不同”会带来很大的问题,例如line[-2]和line.strip()会因为平台不同返回不同的值。...该模式会把所有的换行(\r \n \r\n)替换为\n。只支持读入,但是也足够了。这是Python 提供给我们的最好的选择,没有之一。...\r, or \r\n被默认转换为\n ;写入时,不指定newline,则换行为各系统默认的换行(\n, \r, or \r\n, ),指定为newline=’\n’,则都替换为\n(相当于Universal...It can be None, ”, ‘\n’, ‘\r’, and ‘\r\n’....Built-in Functions 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/125226.html原文链接:https://javaforall.cn

    1.5K20

    ES2020 系列:值合并运算 ??

    值合并运算 '??' 值合并运算 ?? 提供了一种简短的语法,用来获取列表中第一个“已定义”的变量(译注:即值不是 null 或 undefined 的变量)。 a ??..."Anonymous"); // Supercoder 与 || 比较 或运算 || 可以与 ?? 运算以同样的方式使用。正如 上一章[1] 所讲的,我们可以用 || 替换上面示例中的 ??...运算更适合。 优先级 ?? 运算的优先级相当低:在 MDN table[2] 中为 5。 因此,?? 在大多数其他运算之后,但在 = 和 ? 之前进行运算。 如果我们需要在复杂表达式中使用 ??...运算与 && 和 || 运算一起使用。 下面的代码会触发一个语法错误: let x = 1 && 2 ??...3; // 起作用 alert(x); // 2 总结 值合并运算 ?? 提供了一种简洁的方式获取列表中“已定义”的值。

    1.1K10
    领券