- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
所以我问了this question , 看起来是这个原因
var num:Int! = 0
num++
不起作用是因为 ++
运算符采用 inout
参数,而隐式展开的可选参数则不是。然而,在
var num:Int! = 0
num = num + 1
+
运算符与隐式解包可选一起使用,这意味着二元运算符不需要 需要inout
参数。所以我的问题是,为什么一元和二元运算符有不同的参数要求?对我来说,能够将 Int!
仅用于二元运算符,但将 Int
用于所有内容,这对我来说似乎有点愚蠢。
最佳答案
why do unary and binary operators have different parameter requirements?
好吧,这不是一元与二元的问题。有与 Int!
一起使用的一元运算符。例如:
var i: Int! = 17
var j = -i
-
是一元运算符,它可以工作。问题又回到了inout
的问题上。 Int
的 ++
前缀和后缀运算符不适用于 Int!
,因为该变量作为 inout
传递> (因为 ++
除了返回值之外还修改了原始变量)。 inout
要求类型完全匹配。
请注意,隐式展开的可选值仍然是可选值。
var i: Int! = 17
var k = i // k has the type Int!
var m = i! // m has the type Int
因此,将隐式展开的可选类型作为需要非可选类型的 inout
变量传递是行不通的,因为 inout
变量需要与预期的类型完全匹配并且 Int
和 Int!
是两种截然不同的类型。该变量必须显式解包,或者您需要提供一个采用可选类型的重载函数。
你可能会问,为什么 Swift 不直接为你打开 Int!
并用 Int
调用 ++
?好吧,++
既修改了变量又返回了一个值。如果 Swift 解包 Int!
并用 Int
调用 ++
,那么返回的类型将是 Int
。然后 StackOverflow 上会有人问,“为什么 var i: Int!= 17; var j = i++
使 j
成为 Int
而不是 Int!
?”。要做到这一点,++
需要在给定 Int
时返回一个 Int
,并返回一个 Int!
当它被赋予一个 Int!
时。那么,重载函数需要什么。
可以重载 ++
并为 Int!
创建 ++
前缀和后缀函数:
prefix func ++(inout x: Int!) -> Int! {
return ++x!
}
postfix func ++(inout x: Int!) -> Int! {
return x!++
}
var i: Int! = 17
var j = ++i
print("i = \(i), j = \(j)") // "i = 18, j = 18"
j = i++
print("i = \(i), j = \(j)") // "i = 19, j = 18"
至于为什么 Swift 的设计者没有这样做,只有他们自己知道。
关于具有隐式解包可选的 Swift 一元运算符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31764727/
考虑以下两个应用程序: 1: public partial class MainWindow : Window { public MainWindow() { Init
我写了一些被https://github.com/protobuf-c/protobuf-c/wiki/Examples引用的c代码 Operation msg = OPERATION__INIT;
我在使用 SwiftyJSON 正确解开字符串时遇到问题 output: ["AAPL"] stockData = try Data(contentsOf: url!)
我有一个只包含属性的类,我想对其进行打包/解包。我应该实现什么 collections.abc 才能获得此行为? class Item(object): def __init__(self,
考虑以下表达式。请注意,某些表达式被重复以呈现“上下文”。 (这是一个很长的 list ) a, b = 1, 2 # simple sequence
我正在尝试将变量表作为参数解包到函数调用中。简而言之,我正在考虑通过这样做将依赖项注入(inject)到我的过程中。当我在 https://www.lua.org/cgi-bin/demo 执行此操作
我正在尝试弄清楚如何赋予对象解包值的能力。 我想出的用例如下: 让我们有一个 Interval 类,我们将使用它来评估实值函数。 我们想问 成员资格,因此 __contains__。 通过调用特定步骤
所以我知道有一些库可以为我做到这一点,但我想学习打包/解包。 我的目标是让用户输入 IP 地址/子网掩码,然后验证其是否有效。 我想到的一种方法是“sprintf”并获得一个二进制值,比如说 192.
所以我知道有一些库可以为我做到这一点,但我想学习打包/解包。 我的目标是让用户输入 IP 地址/子网掩码,然后验证其是否有效。 我想到的一种方法是“sprintf”并获得一个二进制值,比如说 192.
我正在通过Go v1.13 Go v1.14中的错误跟踪进行检查。为什么看起来只有errors.Is()才能找到没有参数或带有值接收器的错误实现?这意味着能够包装的错误实现必须具有一个值接收器,以便能
我需要解包由其他开发人员创建的 Oracle 包。我在我的数据库中创建了 Prackage,但采用加密格式。 我需要的原因是,原来的开发人员已经离开了组织,现在包中定义的过程需要重新定义,以更新 DB
我打算在文件中使用 unpack。首先我用一个字符串测试。当我在字符串中嵌入空格时,下面的脚本将其显示为空。当我测试文件空间时,它正在被正确读取。不确定为什么在我处理字符串时将其更改为 null。我可
我在 Perl 中遇到这个问题已经有几天了,在搜索了无数的手册页、perldocs 和谷歌搜索了太多的搜索词之后,希望这里有人能帮助我。 我得到两个表示十六进制值的字符串,即“FFFF”,而不是 Pe
在 Python 中解压 SequenceMatcher 循环结果以便轻松访问和处理值的最佳方法是什么? from difflib import * orig = "1234567890" comme
假设,我有一个列表, [(1,2), (3, 4)]. 如果列表中的所有元素都是元组,我将打印 1 + 2 和 3 + 4。但是,如果任何一个元素也是一个列表,那么我将 1 加到内部列表的每个元素,并
我有这样的字典列表。 rows = [ {'user': staff_user, 'grade': [u'0.0', u'N/A', u'N/A', u'N/A', u'N/A']}, {'user'
我有这个代码... function a(options) { for (var item in options) { if ( ! options.hasOwnProperty
我试图通过 std::tie 解压一个 std::array: #include #include int main() { std::array arr = {1, 2, 3};
我的数据包嗅探器有问题。目标端口和源端口在我的嗅探器中似乎是错误的。在 wireshark 中,端口与我的嗅探器完全不同。没有结果包含预期来自 TLS 的端口 443。 (整个 tcp 片段可能是错误
如何使用 php 以大端字节顺序打包/解包 float ?我通过解包功能走到了这一步,但我不确定这是否可行。 function unpackFloat ($float) { $n = unpa
我是一名优秀的程序员,十分优秀!