草庐IT

一种基于Tent混沌映射初始化种群的改进灰狼算法

全部标签

ruby-on-rails - RSpec 找不到我的 Controller 未初始化的常量

我的Rails应用程序最近从Rails3迁移到Rails4,我一直在尝试在个别规范(Controller、模型等)上运行rspec,但它似乎在实际定位对象时遇到了问题。例如,当我尝试运行以下代码时,它会出现未初始化常量错误。这似乎发生在多个Controller上。我已经尝试删除rails_helper.rb和spec_helper.rb并运行railsgeneraterspec:install但它似乎没有解决错误。为什么找不到Controller?我要执行的操作->rspecspec/controllers/activity_controller_spec.rb/Users/osx_u

ruby - 如果 Ruby 的所有实现都被编译成字节码,Ruby 真的是一种解释型语言吗?

在为thisquestionaboutBlueRuby选择的答案中,查克说:AllofthecurrentRubyimplementationsarecompiledtobytecode.ContrarytoSAP'sclaims,asofRuby1.9,MRIitselfincludesabytecodecompiler,thoughtheabilitytosavethecompiledbytecodetodiskdisappearedsomewhereintheprocessofmergingtheYARVvirtualmachine.JRubyiscompiledintoJava

ruby - 有没有一种简单的方法可以在 Ruby 中复制多维数组?

我在Ruby中有一个二维数组,我想生成一个工作副本。显然我不能这样做;array=[[3,4],[5,9],[10,2],[11,3]]temp_array=array因为我对temp_array所做的任何修改也将对数组进行,因为我只是复制了对象标识符。我以为我可以通过简单地使用来解决这个问题;temp_array=array.dup但这不起作用,因为temp_array只是一个重复的对象标识符数组,所以我最终还是修改了初始数组(如果我明白这样做时出了什么问题)。我找到的解决方案是执行以下操作;temp_array=[]array.each{|sub|temp_array这实现了我想要

ruby - 我如何混入 Singleton 来创建一个接受初始化参数的类?

我已经了解了如何将类定义为单例(howtocreateasingletoninRuby):require'singleton'classExampleincludeSingletonend但是如果我想在初始化单个实例时将一些参数传递给#new怎么办?示例应始终初始化某些属性。例如,假设我有一个类,其唯一目的是记录到一个文件,但它需要一个要记录到的文件的名称才能工作。classMyLoggerdefinitialize(file_name)@file_name=file_nameendend我怎样才能使MyLogger成为单例,但确保它获得一个文件名? 最佳答

ruby-on-rails - Ruby on Rails,一种形式的两种模型

我有两个非常相似的模型Pretreatment和Diagnosis,属于模型Patient:classPretreatment在Patient显示页面上,我显示了两种形式,一种用于预处理,另一种用于诊断:我的问题是如何将这两个表单放在一起,以便用户只需按一次提交按钮?我不确定,但我认为嵌套属性不是处理它的正确方法,也许是fields_for`标签?更新我尝试使用fields_for标签:但是我得到了错误:undefinedmethod`model_name'forArray:Classin 最佳答案 对关联模型使用fields_fo

ruby - 在 Ruby 中初始化对象时如何设置属性值?

给定以下类:classTestattr_accessor:nameend当我创建对象时,我想执行以下操作:t=Test.new{name='SomeTestObject'}目前,它导致name属性仍然是nil。是否可以不添加初始化器? 最佳答案 好的,我想到了一个解决方案。它使用initialize方法,但另一方面却完全按照您的意愿行事。classTestattr_accessor:namedefinitialize(init)init.each_pairdo|key,val|instance_variable_set('@'+ke

ruby-on-rails - 如何在不初始化 Rails 的情况下从 schema.rb 创建数据库?

我正在尝试从schema.rb创建我所有的表我使用了命令:“rakedb:schema:load”但是,这失败了,因为在我的一个初始化器中,它引用了一个显然不存在的模型/表(因为数据库是空的)我可以注释掉这些行,然后再次运行schema:load,但是有其他选择吗? 最佳答案 可能最快的方法是将有问题的初始化程序移动到应用程序外部的临时目录,然后运行您的模式加载。但是,如果这不起作用,或者由于某种原因不是一个选项,您总是可以通过创建一个简单的rails应用程序来执行模式加载来解决这个问题:创建一个新的Rails应用:railsnew

ruby - 我应该如何构建我的(moSTLy)基于文本的游戏服务器?

想想MUD/MUCK,但可能还有头像或现场插图。我选择的语言是ruby。我需要处理多个持久连接,数据在服务器和它的各种客户端之间异步传输。单个数据库必须根据客户端session中发生的事件保持最新。每个客户端session中的事件可能需要立即更新多个其他客户端(用户进入房间;用户向另一个用户发送私有(private)消息)。这是一个目标项目和一个学习项目,所以我打算重新发明一两个轮子来了解更多关于并发网络编程。但是,我对并发编程和网络编程都不熟悉;以前,我几乎只在Web应用程序中的非持久同步HTTP请求领域工作。所以,我想确保我正在重新发明正确的轮子。根据emboss的出色回答,我已经

ruby-on-rails - 运行 rake 任务时如何跳过 Rails 初始值设定项的加载?

我的Rails应用程序有一个网站爬虫,它加载爬虫在config/initializers中的Rails初始值设定项中使用的身份验证凭据。初始化程序通过调用SiteLogin模型中的模型方法来加载身份验证。当我运行rakedb:migrate来创建SiteLogin模型表时,它失败了,因为初始化程序期望数据库表已经存在。我可以简单地注释掉初始化程序中的代码,运行迁移以创建表,然后取消注释初始化程序代码,而不用担心这个问题。问题是,我正在使用Capistrano进行部署,这意味着我必须先在没有初始化代码的情况下进行部署以运行迁移,然后再使用初始化代码进行部署。有没有更好的方法来做到这一点,

ruby-on-rails - 在 Gemfile 和 .ruby-version Dotfile 中列出 Ruby 版本是一种不好的做法吗?

我最新的Rails项目或多或少是尝试让我打破很多东西并在这个过程中学习。我的gemfile中指定了最新版本的Ruby:ruby'2.2.3'而且我还有一个.ruby-version项目中的dotfile,内容如下:2.2.3除了明显的重复之外,这还有什么问题?这两个公约的目的是什么?如果我应该只有一个约定来列出我的Ruby版本,为什么我应该在另一个(dotfile)之上使用一个(Gemfile)?在一个项目中同时拥有这两个约定是否完全可以?我将成为这个实验项目的唯一维护者,并且不认为必须维护这个微妙的重复是一个问题。我不打算为这个项目升级Ruby,如果我这样做了,我不会有记住在两个地方