我正在使用 Swift 3 开发 iOS 应用程序,但遇到了一个问题。我有一个枚举:
enum MapMode: Equatable {
case scenes
case temperature
case editingScene
case editingWaterfall(waterfall: Waterfall, mode: PumpEditorMode, waterfallScene: WaterfallScene?)
case editingWaterfallScenes(waterfall: Waterfall)
case editingTemperature(thermostate: Thermostat)
case editingShutter(shutter: Device, doorDirection: DoorDirection)
case editingDoor
case comfortScenesList
public static func ==(lhs: MapMode, rhs: MapMode) -> Bool {
switch (lhs, rhs) {
case let (.editingTemperature(ther01), .editingTemperature(ther02)):
return ther01.deviceId ?? 0 == ther02.deviceId ?? 0
case let (a, b) where a.rawValue == b.rawValue:
return true
default:
return false
}
}
}
我得到一个错误Value of type 'MapMode' has no member 'rawValue' 所以我意识到我需要为枚举添加原始值所以我编辑了一个代码:
enum MapMode: Int, Equatable {
case scenes = 0
case temperature = 1
case editingScene = 2
case editingWaterfall(waterfall: Waterfall, mode: PumpEditorMode, waterfallScene: WaterfallScene?) = 3
case editingWaterfallScenes(waterfall: Waterfall) = 4
case editingTemperature(thermostate: Thermostat) = 5
case editingShutter(shutter: Device, doorDirection: DoorDirection) = 6
case editingDoor = 7
case comfortScenesList = 8
public static func ==(lhs: MapMode, rhs: MapMode) -> Bool {
switch (lhs, rhs) {
case let (.editingTemperature(ther01), .editingTemperature(ther02)):
return ther01.deviceId ?? 0 == ther02.deviceId ?? 0
case let (a, b) where a.rawValue == b.rawValue:
return true
default:
return false
}
}
}
而且它也不是编译的。 原始类型的枚举不能有带参数的情况
我的问题是:如何使带有参数的枚举成为一个可等价的?
enum MapMode: Equatable {
case scenes
case temperature
case editingScene
case editingWaterfall(waterfall: Waterfall, mode: PumpEditorMode, waterfallScene: WaterfallScene?)
case editingWaterfallScenes(waterfall: Waterfall)
case editingTemperature(thermostate: Thermostat)
case editingShutter(shutter: Device, doorDirection: DoorDirection)
case editingDoor
case comfortScenesList
public static func ==(lhs: MapMode, rhs: MapMode) -> Bool {
switch (lhs, rhs) {
case (.scenes, .scenes), (.temperature, .temperature), (.editingScene, .editingScene), (.editingDoor, .editingDoor), (.comfortScenesList, .comfortScenesList):
return true
case let (.editingTemperature(ther01), .editingTemperature(ther02)):
return ther01.deviceId ?? 0 == ther02.deviceId ?? 0
case let (.editingWaterfall(waterfall01, _, _), .editingWaterfall(waterfall02, _, _)):
return waterfall01.deviceId == waterfall02.deviceId
case let (.editingWaterfallScenes(waterfall01), .editingWaterfallScenes(waterfall02)):
return waterfall01.deviceId == waterfall02.deviceId
case let (.editingShutter(shutter01, _), .editingShutter(shutter02, _)):
return shutter01.deviceId == shutter02.deviceId
default:
return false
}
}
}
我决定中止 rawValues 并扩展了 == 函数。这个解决方案有一个缺陷。每当我添加新的 case 时,我都需要记住扩展 == 函数。
我正在寻找更通用的解决方案。
最佳答案
您可能希望将它们分成两个枚举:
enum MapMode: Equatable {
case mapMode(mode:ModeType)
case editingWaterfall(waterfall: Waterfall, mode: PumpEditorMode, waterfallScene: WaterfallScene?)
case editingWaterfallScenes(waterfall: Waterfall)
case editingTemperature(thermostate: Thermostat)
case editingShutter(shutter: Device, doorDirection: DoorDirection)
public static func ==(lhs: MapMode, rhs: MapMode) -> Bool {
switch (lhs, rhs) {
case let (.editingTemperature(ther01), .editingTemperature(ther02)):
return ther01.deviceId ?? 0 == ther02.deviceId ?? 0
case let (mapMode(a), mapMode(b)) where a.rawValue == b.rawValue:
return true
default:
return false
}
}
}
enum ModeType: Int, Equatable {
case scenes = 0
case temperature
case editingScene
case editingWaterfall
case editingWaterfallScenes
case editingTemperature
case editingShutter
case editingDoor
case comfortScenesList
public static func ==(lhs: ModeType, rhs: ModeType) -> Bool {
switch (lhs, rhs) {
case let (a, b) where a.rawValue == b.rawValue:
return true
default:
return false
}
}
}
关于ios - 将枚举案例与参数进行比较,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42067281/
很好奇,就使用rubyonrails自动化单元测试而言,你们正在做什么?您是否创建了一个脚本来在cron中运行rake作业并将结果邮寄给您?git中的预提交Hook?只是手动调用?我完全理解测试,但想知道在错误发生之前捕获错误的最佳实践是什么。让我们理所当然地认为测试本身是完美无缺的,并且可以正常工作。下一步是什么以确保他们在正确的时间将可能有害的结果传达给您? 最佳答案 不确定您到底想听什么,但是有几个级别的自动代码库控制:在处理某项功能时,您可以使用类似autotest的内容获得关于哪些有效,哪些无效的即时反馈。要确保您的提
在控制台中反复尝试之后,我想到了这种方法,可以按发生日期对类似activerecord的(Mongoid)对象进行分组。我不确定这是完成此任务的最佳方法,但它确实有效。有没有人有更好的建议,或者这是一个很好的方法?#eventsisanarrayofactiverecord-likeobjectsthatincludeatimeattributeevents.map{|event|#converteventsarrayintoanarrayofhasheswiththedayofthemonthandtheevent{:number=>event.time.day,:event=>ev
我正在编写一个包含C扩展的gem。通常当我写一个gem时,我会遵循TDD的过程,我会写一个失败的规范,然后处理代码直到它通过,等等......在“ext/mygem/mygem.c”中我的C扩展和在gemspec的“扩展”中配置的有效extconf.rb,如何运行我的规范并仍然加载我的C扩展?当我更改C代码时,我需要采取哪些步骤来重新编译代码?这可能是个愚蠢的问题,但是从我的gem的开发源代码树中输入“bundleinstall”不会构建任何native扩展。当我手动运行rubyext/mygem/extconf.rb时,我确实得到了一个Makefile(在整个项目的根目录中),然后当
exe应该在我打开页面时运行。异步进程需要运行。有什么方法可以在ruby中使用两个参数异步运行exe吗?我已经尝试过ruby命令-system()、exec()但它正在等待过程完成。我需要用参数启动exe,无需等待进程完成是否有任何rubygems会支持我的问题? 最佳答案 您可以使用Process.spawn和Process.wait2:pid=Process.spawn'your.exe','--option'#Later...pid,status=Process.wait2pid您的程序将作为解释器的子进程执行。除
我有一个围绕一些对象的包装类,我想将这些对象用作散列中的键。包装对象和解包装对象应映射到相同的键。一个简单的例子是这样的:classAattr_reader:xdefinitialize(inner)@inner=innerenddefx;@inner.x;enddef==(other)@inner.x==other.xendenda=A.new(o)#oisjustanyobjectthatallowso.xb=A.new(o)h={a=>5}ph[a]#5ph[b]#nil,shouldbe5ph[o]#nil,shouldbe5我试过==、===、eq?并散列所有无济于事。
我有一些Ruby代码,如下所示:Something.createdo|x|x.foo=barend我想编写一个测试,它使用double代替block参数x,这样我就可以调用:x_double.should_receive(:foo).with("whatever").这可能吗? 最佳答案 specify'something'dox=doublex.should_receive(:foo=).with("whatever")Something.should_receive(:create).and_yield(x)#callthere
我正在为一个项目制作一个简单的shell,我希望像在Bash中一样解析参数字符串。foobar"helloworld"fooz应该变成:["foo","bar","helloworld","fooz"]等等。到目前为止,我一直在使用CSV::parse_line,将列分隔符设置为""和.compact输出。问题是我现在必须选择是要支持单引号还是双引号。CSV不支持超过一个分隔符。Python有一个名为shlex的模块:>>>shlex.split("Test'helloworld'foo")['Test','helloworld','foo']>>>shlex.split('Test"
我不确定传递给方法的对象的类型是否正确。我可能会将一个字符串传递给一个只能处理整数的函数。某种运行时保证怎么样?我看不到比以下更好的选择:defsomeFixNumMangler(input)raise"wrongtype:integerrequired"unlessinput.class==FixNumother_stuffend有更好的选择吗? 最佳答案 使用Kernel#Integer在使用之前转换输入的方法。当无法以任何合理的方式将输入转换为整数时,它将引发ArgumentError。defmy_method(number)
这是一道面试题,我没有答对,但还是很好奇怎么解。你有N个人的大家庭,分别是1,2,3,...,N岁。你想给你的大家庭拍张照片。所有的家庭成员都排成一排。“我是家里的friend,建议家庭成员安排如下:”1岁的家庭成员坐在这一排的最左边。每两个坐在一起的家庭成员的年龄相差不得超过2岁。输入:整数N,1≤N≤55。输出:摄影师可以拍摄的照片数量。示例->输入:4,输出:4符合条件的数组:[1,2,3,4][1,2,4,3][1,3,2,4][1,3,4,2]另一个例子:输入:5输出:6符合条件的数组:[1,2,3,4,5][1,2,3,5,4][1,2,4,3,5][1,2,4,5,3][
两者都可以defsetup(options={})options.reverse_merge:size=>25,:velocity=>10end和defsetup(options={}){:size=>25,:velocity=>10}.merge(options)end在方法的参数中分配默认值。问题是:哪个更好?您更愿意使用哪一个?在性能、代码可读性或其他方面有什么不同吗?编辑:我无意中添加了bang(!)...并不是要询问nobang方法与bang方法之间的区别 最佳答案 我倾向于使用reverse_merge方法:option