草庐IT

JavaScript中单例模式这样用

全部标签

ruby - 为什么 random 在 Ruby 中这样工作?

我试图在确定性地随机选择东西方面变得聪明,并发现了这个:irb(main):011:0>Random.new(Random.new(1).rand+1).rand==Random.new(1).rand=>trueirb(main):012:0>Random.new(Random.new(5).rand+1).rand==Random.new(5).rand=>falseirb(main):013:0>Random.new(Random.new(5).rand+5).rand==Random.new(5).rand=>true有那么一瞬间,我想“哇,这可能是随机数生成器的一个属性”,但

ruby - 在 Ruby 中为正则表达式模式生成字符串

在Python语言中,我找到了rstr可以为regex生成一个字符串模式。或者在Python中我们有这个方法可以返回字符串的范围:re.sre_parse.parse(pattern)#.....('range',(97,122))....但是在Ruby中我没有找到任何东西。那么如何在Ruby中为正则表达式模式生成字符串(反向正则表达式)?我想要这样的东西:"/[a-z0-9]+/".example#tvvd"/[a-z0-9]+/".example#yt"/[a-z0-9]+/".example#bgdf6"/[a-z0-9]+/".example#564fb"/[a-z0-9]+/

ruby - 尝试理解双重调度模式

我一直在努力理解double-dispatchpattern并且很难过。我终于尝试了一个示例程序来帮助自己理解。Here's要旨。但后来我决定尝试一下withoutDoubledispatch解决方案看起来并没有比平时更糟糕。我做错了什么?编辑:根据建议,我发布了这个问题here.保留此链接以进行重定向。 最佳答案 在单一分派(dispatch)中——您在大多数现代OO语言中看到的——方法是根据单个对象的运行时类型分派(dispatch)的。这显示为点运算符(在ruby​​、java、javascript等中)或箭头运算符(perl

ruby - 删除名称与模式匹配的所有文件

我有多个文件(在一个包含数千个文件的文件夹中),例如:...page_bonus.txtpage_code1.txtpage_code2.txtpage_text1.txtpage_text2.txtpage_text3.txt...如何删除所有page_code*文件?注意:我不想使用FileUtils或shell 最佳答案 Dir::glob支持单个字符通配符(即?)。根据您的示例,您可以使用?在给定目录中找到适当的文件,然后删除它们。Dir.glob('/home/your_username/Documents/page_co

ruby-on-rails - rails : Could not load database configuration. 没有这样的文件 -

我从GitHub存储库克隆了一个应用程序文件夹,在捆绑安装gems之后,我尝试使用rakedb:setup和rakedb:migrate命令,但都没有用,这是我的错误消息:**arun997@promanager:~/workspace(master)$rakedb:setuprequire'rails/all'...2.470sBundler.require...7.590srakeaborted!Cannotload`Rails.application.database_configuration`:Couldnotloaddatabaseconfiguration.Nosuchf

Ruby 对象字面量(ala javascript)

在ruby中你可以去a={}a['a']=82a['b']='foo'putsa['a']#82我希望我可以使用点符号,例如javascript。将a.a#82有没有办法在ruby​​中构建对象文字并使用点表示法访问它们? 最佳答案 您可以创建一个Struct.A=Struct.new(:a,:b)a=A.new(82,'foo')putsa.a#=>82编辑:你甚至可以做到a={}a['a']=82a['b']='foo'Struct.new(*a.keys).new(*a.values)

ruby - 嵌套单例类方法查找

首先,我知道这个问题在现实世界中没有应用,我只是好奇。假设我们有一个带有单例方法的类:classFoodefself.barendend如果我们调用Foo.bar,它会首先在Foo的每个祖先的单例类中搜索一个方法,然后在被引用的类中查找.class方法及其祖先。我们可以用Foo.singleton_class.ancestors确认,它返回:[#,#,#,Class,Module,Object,Kernel,BasicObject]但是如果我们有一个嵌套的单例类会发生什么,比如:classFooclass如果我们调用Foo.singleton_class.singleton_class

ruby-on-rails - 设计模式和设计原则有什么区别?

我是RubyonRails的新手,我阅读了这些文章。DesignPatternsinRuby:Observer,SingletonDesignPatternsinRuby但我无法理解设计模式和设计原则之间的实际区别。有人可以解释一下区别吗? 最佳答案 设计原则:设计原则是我们在设计软件时应该遵循的核心抽象原则。记住它们不是具体的——而是抽象的。只要我们在允许的条件内,它们就可以以任何语言、任何平台应用,无论处于何种状态。例子:封装变化的内容。针对接口(interface)而非实现编程。依赖抽象。不要依赖于具体的类。设计模式:它们是针

ruby - 在扩展自身的模块中的实例方法中调用单例方法

我自己扩展了Kernel,在实例方法Kernel#abort的定义中,我调用了单例方法Kernel.abort:moduleKernelextendselfdefabortputs"PressENTERtoexit..."getsKernel.abortendendabort当我调用Kernel#abort时,方法定义中的Kernel.abort调用似乎是指原始的Kernel#abort(扩展为Kernel.abort)。Ruby如何知道当我写Kernel.abort时,我指的是原始的abort方法,而不是我刚刚创建的方法?我将如何递归调用我刚刚创建的新abort方法?

ruby - 模式匹配时 =~ 和 match() 有什么区别?

我正在使用Ruby1.9.3。我在玩一些模式,发现了一些有趣的东西:示例1:irb(main):001:0>/hay/=~'haystack'=>0irb(main):003:0>/st/=~'haystack'=>3示例2:irb(main):002:0>/hay/.match('haystack')=>#irb(main):004:0>/st/.match('haystack')=>#=~返回其第一个匹配项的第一个位置,而match返回模式。除此之外,=~和match()还有什么区别吗?执行时间差(根据@Casper)irb(main):005:0>quickbm(10000000