我正在学习Rails并回到Ruby以了解Rails中的方法(以及Ruby的实际工作原理)。当我看到如下方法调用时:validates:first_name,:presence=>true我很困惑。您如何在ruby中编写接受符号或散列的方法。validates方法的源代码也很困惑。有人可以为我简化在ruby类和实例方法中使用符号作为参数的主题吗?更新:好一个@Dave!但我尝试的是这样的:deffull_name(:first_name,:last_name)@first_name=:first_name@last_name=:last_namep"#{@first_name}#
我第一次尝试学习Ruby是在2年前,现在我又重新开始了。我停下来的原因是因为我无法理解Symbol类。现在我又在同一点上,完全迷失在何时以及为何使用Symbols。我已经阅读了Stackoverflow上的其他帖子,并通过Google搜索了一些解释。但是我还不明白。首先,我认为符号只是一种创建某种“命名常量”的方法,而无需经历与Java中相同的过程。:all而不是创建一个具有任意值的常量publicstaticfinalStringALL=8;但是,当您在例如使用它时,它并没有多大意义。attr_accessor:first_name等Symbols只是一个轻量级的String类吗?我
在Ruby1.9中你可以有Fixnum,Float,和Symbol未卡住或卡住的值:irb(main):001:0>a=[17,42.0,:foo];a.map(&:frozen?)=>[false,false,false]irb(main):002:0>a.each(&:freeze);a.map(&:frozen?)=>[true,true,true]我了解卡住字符串、数组或其他可变数据类型的实用性。然而,据我所知,Fixnum,Symbol,和Float实例从一开始就是不可变的。是否有任何理由卡住它们(或者Ruby不会报告它们的任何原因frozen?请注意,在Ruby2.0中Fi
双splat运算符**似乎只适用于键为符号的哈希。例如,当键是字符串时,它将不起作用。两种方式都是如此。用于build:deffoo**;endfoo(:a=>3)#=>nilfoo("a"=>3)#=>ArgumentError:wrongnumberofarguments(1for0)和破坏:defbar*;endbar(**{:a=>3})#=>nilbar(**{"a"=>3})#=>TypeError:wrongargumenttypeString(expectedSymbol)为什么仅限于符号键?这可能与命名关键字符号a:3与hashwithsymbolkeys的语法糖重合
Rails新手,想弄明白什么时候/为什么要在框架。我想我从概念上理解了它们之间的区别每个项目只有一个:symbol实例每个实例一个@ivar多个“strings”-因为它们是在引用时创建的(?)随时纠正我!主要的困惑来自理解Rails期望的规则和约定-在哪里以及为什么?我敢肯定会有一个“啊哈!”时刻即将到来,但我还没有……因为它对我来说似乎很随意(来自C/Obj-C)。-谢谢 最佳答案 @instance_variable是一个实例变量。它通常在Controller中定义并可在View中访问。"string"是一个字符串,就像在任何
我理解字符串和符号之间的理论区别。我知道符号是用来表示一个概念或名称或标识符或标签或键,而字符串是一包字符。我知道字符串是可变的和transient的,而符号是不可变的和永久的。我什至喜欢Symbols看起来在我的文本编辑器中与Strings的不同。令我困扰的是,实际上,Symbols与Strings非常相似,以至于它们没有像Strings那样实现这一事实引起了很多麻烦。它们甚至不支持鸭子类型或隐式强制转换,这与其他著名的“相同但不同”的组合Float和Fixnum不同。当然,最大的问题是从其他地方(如JSON和HTTPCGI)进入Ruby的散列使用字符串键,而不是符号键,因此Ruby
我看到了Ruby字符串文档并测试了这些方法。我发现两个相似的方法是to_sym和intern方法。"cat".intern=>:cat"cat".to_sym=>:cat我搜索了StackOverflow,令人惊讶的是,还没有人问过这个问题。我自己找不到两者之间的区别,所以我想我会问这个问题。如果他们做同样的事情,一种方法比另一种更快吗?如果是这样,那么使用该方法就有意义了。 最佳答案 它们似乎是同一事物的别名。来自documentation可以看到intern的示例代码使用了to_sym:intern→symbolReturnst
有一些Ruby类不允许在其实例上定义单例方法。例如,符号:var=:asymboldefvar.hello"hello"end#TypeError:can'tdefinesingletonmethod"hello"forSymbol我认为这可能是对所有立即值的限制,但它似乎适用于nil、true和false(但不是Fixnum或Bignum的实例):var=truedefvar.hello"hello"endvar.hello#=>"hello"我不明白为什么Ruby允许在某些类的对象上定义单例方法,但不允许在其他类上定义单例方法。 最佳答案
使用ruby2.3:在示例1中,字符串键"a"自动转换为符号,而在示例2中,它仍然是一个字符串。示例1{"a":1}#=>{:a=>1}示例2{"a"=>"c"}#=>{"a"=>"c"}我认为:与旧式哈希火箭=>语法相同。到底是怎么回事?为什么我在Rails中从未注意到这一点?是HashWithIndifferentAccess掩盖了这一点吗? 最佳答案 在Ruby2.3(.0)中,这些都是一样的:{:"a"=>1}{"a":1},{:a=>1}{a:1}它们都翻译成同一个东西:a在所有这些情况下都是一个符号。{"a"=>1}不同
在Ruby中有没有办法把一个符号或字符串变成一个同名的类?例如,如果我有一个类classBobdeftalkputs"Hi,I'mbob"endend我在代码中其他地方的一个方法被传递了一个符号:bob,我可以通过某种方式将其转换为类Bob吗?也许像b=:Bob.newb.talk或者有没有办法做类似的事情? 最佳答案 有很多方法可以做到这一点。您缺乏上下文,因此无法选择“最佳”方式。这里有一些方法。Kernel.const_get(:Bob)eval(:Bob.to_s)Kernel.const_get(:bob.to_s.cap