草庐IT

instance-initializers

全部标签

Ruby class initialize(constructor) 是私有(private)方法还是公共(public)方法?

ruby中的初始化方法(构造函数)是私有(private)的还是公共(public)的? 最佳答案 让我们看看:classTestdefinitialize;endendpTest.new.private_methods.sort.include?(:initialize)这会打印出true,所以initialize是一个私有(private)方法。这是有道理的,只有当对象被创建时,它才会被new类方法调用。如果我们愿意,我们可以这样做:classTestdefinitialize@counter=0enddefreset!init

ruby-on-rails - find_or_initialize_by 不适用于 2 列

我正在尝试使用ActiveRecord在我的数据库中插入数据。当我使用pdays=MyModel.new而不是下面的find_or_initialize_by进行初始化时,脚本运行良好。但它只运行一次。我需要它每天运行以执行更新。当我第二次尝试使用pdays=MyModel.new运行脚本时,没有出现重复键约束。因此,我正在尝试使用以下带有2个参数的find_or_initialize_by,但这给出了一个错误:undefinedmethod`find_or_initialize_by'2列一起构成唯一记录:vertica_traffic.eachdo|vdays|pdays=MyMo

ruby "instance variable not initialized"警告

在用ruby​​编写一些“学习语言”代码时,作为linkedList实现的一部分,我遇到了这个警告:在“添加”方法中,如果头部不存在则创建它,即defadd(value)new_node=LinkedListNode.new(value)if!@head@head=new_nodeelseself.find{|node|node.next==nil}.next=new_nodeendend然后我收到警告.../linked_list.rb:13:warning:instancevariable@headnotinitialized如何摆脱这个警告?这样做的惯用方法是什么?

ruby-on-rails - rails : Model instance method or helper method?

按照惯例,应将以下定义为我的模型的实例方法还是辅助方法?#app/models/user.rbclassUser或#app/helpers/users_helper.rbmoduleUsersHelperdeffull_name"#{@user.first_name}#{@user.last_name}"endend非常感谢。 最佳答案 选择第一个(保留在模型中),也是因为您可能想做其他事情,比如组合索引:) 关于ruby-on-rails-rails:Modelinstancemeth

ruby:instance_eval 一个文件,同时在堆栈跟踪中维护文件:行?

如果我这样做defeval_file(file)instance_evalread(file)end然后,一旦文件内的方法/block之一发生某些事情,我所看到的就是“eval_file”中的(eval):20。当我对许多文件使用eval_file时,很难判断异常来自哪个文件(异常发生在eval之后,使用方法时)有什么方法可以让我看到实际的文件和行号吗? 最佳答案 从thedocumentation可以看出,BasicObject#instance_eval(实际上还有所有其他*_eval)将简单地报告您告诉它的任何文件名和行号:M

ruby - 在 ruby​​ 中继承 initialize() 方法?

这个问题不太可能帮助任何future的访问者;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况有关,这些情况并不普遍适用于互联网的全局受众。为了帮助使这个问题更广泛地适用,visitthehelpcenter.关闭9年前。我仍然不知道如何让子类的构造函数跟随其父类...示例:require'mechanize'classScraperattr_accessor:agentdefinitialize#Idontknowifusinginstancevariableistherightthingtodo@agent=Mechanize.newendendclassScraper

ruby - @instance_variable 在 ruby​​ block 内不可用?

使用以下代码:defindex@q=""@q=params[:search][:q]ifparams[:search]q=@q@search=Sunspot.search(User)dokeywordsqend@users=@search.resultsend如果使用@q而不是q,搜索总是返回空查询("")的结果。为什么是这样?@q变量对do...endblock不可用吗? 最佳答案 这取决于block的调用方式。如果使用yield关键字或Proc#call方法调用它,那么您将能够在block中使用您的实例变量。如果使用Object

ruby-on-rails - Capistrano::Configuration:Class 的未定义方法 `instance'

我正在尝试在Rails应用程序中首次启动并运行Capistrano。我有一台运行Ubuntu12.04、nginx、unicorn和rails的linux服务器,但是,我似乎遇到了一些问题。我还使用RVM使用Capistrano3.0.0、rails3.2.14、bundler1.4.0和ruby​​1.9.3p448。我只设置了一个生产阶段,此时我只关心Capistrano与我的服务器通信并从github推送我的代码(目前还没有迁移和捆绑等)。当我使用下面的设置尝试命令capproductiondeploy:check或capproductiondeploy:setup(这似乎已被弃

ruby-on-rails - 助手设计 : could not find the `Warden::Proxy` instance on request environment

我尝试将Devise用于我的Rails应用程序。我可以注册并登录,但是当我转到其他页面“构建”时,出现以下错误:Devise::MissingWardeninHome#showDevisecouldnotfindtheWarden::Proxyinstanceonyourrequestenvironment.MakesurethatyourapplicationisloadingDeviseandWardenasexpectedandthattheWarden::Managermiddlewareispresentinyourmiddlewarestack.Ifyouareseeing

Ruby block 、procs 和 instance_eval

我最近尝试做类似的事情:a="somestring"b=Proc.new{upcase}a.instance_evalb这给出了错误:TypeError:can'tconvertProcintoString但这行得通:defb(&block)"somestring".instance_eval&blockendb{upcase}进一步了解此方法:defb(&block)"somestring".instance_evalblockend产生相同的ProctoString错误。所以...我对方block的理解是它们只是过程。但是显然,使用这个&符号有一些特别之处......有人能给我解释