我试图保留一个回调字典,其中回调可以包含一个基类类型的参数,然后我可以用任何派生类型调用回调。当我尝试这样做时,出现编译错误。我来自 C++/C# 背景,所以我很难理解这是如何在 Swift 中完成的。
这是一个简化的用例:
public func RegisterMessage<T: Message>(type: MessageType, callback: (msg: T) -> ())
{
// ERROR: Cannot assign a value of type '(msg: T) -> ()' to a value
// of type '((msg: Message) -> ())?'
MessageCallbacks[type] = callback
}
private var MessageCallbacks : [MessageType : (msg: Message) -> ()] = [:]
如果它正在编译,这里是我期望使用它的代码:
RegisterMessage<SetPositionMessage>(MessageType.SetPosition, OnSetPosition)
// This would take msg's type, using it to find the callback in the
// dictionary, and then it would pass the msg into the callback function.
let msg = SetPositionMessage()
SendMessage(msg)
public func SendMessage(msg: Message)
{
MessageCallbacks[msg.MessageType]?.(msg)
}
我想要完成的是,我有一种方法可以指定一个回调函数,该回调函数应根据发送的消息类型进行调用。
这是显示我的问题的另一个代码示例。我可以拥有一个接受派生类型的基类型容器,但这不适用于具有基类型的回调容器。
public class BaseClass {
}
public class DerivedClass : BaseClass {
}
var Container: [BaseClass] = []
Container.append(BaseClass())
Container.append(DerivedClass())
var Callbacks: [(msg: BaseClass) -> ()] = []
func BaseCallback(msg: BaseClass) {}
func DerivedCallback(msg: DerivedClass) {}
Callbacks.append(BaseCallback)
Callbacks.append(DerivedCallback)
// ERROR! Cannot assign a value of type '(DerivedClass) -> ()' to expected argument type '(msg: BaseClass) -> ()'
最佳答案
你可以使用:
MessageCallbacks[type] = (callback as! (msg: Message) -> ())
关于Swift:带有回调的泛型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34891908/
我有一个服务模型/表及其注册表。在表单中,我几乎拥有服务的所有字段,但我想在验证服务对象之前自动设置其中一些值。示例:--服务Controller#创建Action:defcreate@service=Service.new@service_form=ServiceFormObject.new(@service)@service_form.validate(params[:service_form_object])and@service_form.saverespond_with(@service_form,location:admin_services_path)end在验证@ser
我正在阅读SandiMetz的POODR,并且遇到了一个我不太了解的编码原则。这是代码:classBicycleattr_reader:size,:chain,:tire_sizedefinitialize(args={})@size=args[:size]||1@chain=args[:chain]||2@tire_size=args[:tire_size]||3post_initialize(args)endendclassMountainBike此代码将为其各自的属性输出1,2,3,4,5。我不明白的是查找方法。当一辆山地自行车被实例化时,因为它没有自己的initialize方法
使用rspec-rails3.0+,测试设置分为spec_helper和rails_helper我注意到生成的spec_helper不需要'rspec/rails'。这会导致zeus崩溃:spec_helper.rb:5:in`':undefinedmethod`configure'forRSpec:Module(NoMethodError)对thisissue最常见的回应是需要'rspec/rails'。但这是否会破坏仅使用spec_helper拆分rails规范和PORO规范的全部目的?或者这无关紧要,因为Zeus无论如何都会预加载Rails?我应该在我的spec_helper中做
假设我有一个类A,里面有一些方法。假设stringmethodName是这些方法之一,我已经知道我想给它什么参数。它们在散列中{'param1'=>value1,'param2'=>value2}所以我有:params={'param1'=>value1,'param2'=>value2}a=A.new()a.send(methodName,value1,value2)#callmethodnamewithbothparams我希望能够通过传递我的哈希以某种方式调用该方法。这可能吗? 最佳答案 确保methodName是一个符号,而
当我进入Rails控制台时,我已将pry设置为加载代替irb。我找不到该页面或不记得如何将其恢复为默认行为,因为它似乎干扰了我的Rubymine调试器。有什么建议吗? 最佳答案 我刚发现问题,pry-railsgem。忘记了它的目的是让“railsconsole”打开pry。 关于ruby-on-rails-带有Pry的Rails控制台,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/question
我了解instance_eval和class_eval之间的基本区别。我在玩弄时发现的是一些涉及attr_accessor的奇怪东西。这是一个例子:A=Class.newA.class_eval{attr_accessor:x}a=A.newa.x="x"a.x=>"x"#...expectedA.instance_eval{attr_accessor:y}A.y="y"=>NoMethodError:undefinedmethod`y='forA:Classa.y="y"=>"y"#WHATTT?这是怎么回事:instance_eval没有访问我们的A类(对象)然后它实际上将它添加到
是否可以为单个ActiveRecord实例添加回调?作为进一步的限制,这是继续使用库,所以我无法控制该类(除了对其进行猴子修补)。这或多或少是我想做的:defdo_something_creazymessage=Message.newmessage.on_save_call:do_even_more_crazy_stuffenddefdo_even_more_crazy_stuff(message)puts"Message#{message}hasbeensaved!Hallelujah!"end 最佳答案 你可以通过在创建对象后立
我在一个简单的RailsAPI中有以下Controller代码:classApi::V1::AccountsControllerehead:not_foundendendend问题在于,生成的json具有以下格式:{id:2,name:'Simpleaccount',cash_flows:[{id:1,amount:34.3,description:'simpledescription'},{id:2,amount:1.12,description:'otherdescription'}]}我需要我生成的json是camelCase('cashFlows'而不是'cash_flows'
在Ruby(或Rails)中,我们可以做到new_params=params.merge({:order=>'asc'})现在new_params是一个带有添加键:order的散列。但是是否有一行可以返回带有已删除key的散列?线路new_params=params.delete(:order)不会工作,因为delete方法返回值,仅此而已。我们必须分3步完成吗?tmp_params=paramstmp_params.delete(:order)returntmp_params有没有更好的方法?因为我想做一个new_params=(params[:order].blank?||para
我想写一点“Deprecate-It”库并经常使用“method_added”回调。但是现在我注意到在包含模块时不会触发此回调。是否有任何回调或变通方法,以便在某些内容包含到自身时通知类“Foobar”?用于演示的小Demo:#IncludingModulswon'ttriggermethod_addedcallbackmoduleInvisibleMethoddefinvisible"Youwon'tgetacallbackfromme"endendclassFoobardefself.method_added(m)puts"InstanceMethod:'#{m}'addedto'