草庐IT

Internals

全部标签

ruby - Class 怎么可能属于 Class 类而没有 Class 实例方法呢?

我正在研究Ruby解释器是如何实现的,并且出现了一个问题,但我还没有得到答案。这就是标题中的那个:因为Class(r_cClass)将super设置为自身(忽略元类,因为实际上super是r_cClass的元类),如果我向Class对象发送一个方法,这将在Class的方法表中查找'类(class)。但是Class的类是Class,所以我不应该最终寻找Class的实例方法吗?但事实并非如此,因为在文档中Class类方法和Class实例方法是分开的。在Ruby的eval.c中的search_method中,我没有发现对Class类有什么特别的检查。任何人都可以阐明这一点吗?

ruby - 为什么我可以在 Ruby 中将一个 undefined variable 赋值给它自己并得到 nil?

这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:Whya=aisnilinRuby?我们应该说,在Ruby中使用undefinedvariable是“奇怪的现象”。是这样的:#irbsessionfollows#foo#undefinedlocalvariableormethod'foo'bar#samefor'bar'foo=bar#stillsamefor'bar'foo=foo#nil-HUH?foo#isnowsettonil!?为什么我可以在Ruby中将一个undefinedvariable赋值给自身并得到nil?请注意,我在这里使用的是Ruby

ruby - ruby 中的字符串文字如何绕过 new/initialize,有没有办法对此进行检测?

今天下午我在玩一个主意,偶然发现了一些我不太明白的东西。基本上我在这个实验中试图实现的是在每次创建字符串时以某种方式知道(供以后使用,例如在某种DSL中)。以下内容适用于通过String.new创建的任何字符串:class::Stringclass例如irb>String.new("foo")initializing'foo'newing'foo'=>"foo"我想不通的是当您使用文字时如何创建String对象。例如,为什么这不经过相同的初始化和设置:irb>"literalstring"=>"literalstring"我意识到当字符串是文字时,编译器会做一些不同的事情,但它不需要初

Ruby 左递归与右递归

出于某种原因,Ruby在面对左递归时似乎表现得更好。例如:defleft_recursive_factorial(number)return1ifnumber.zero?left_recursive_factorial(number.pred)*numberenddefright_recursive_factorial(number)return1ifnumber.zero?number*right_recursive_factorial(number.pred)end当我用超过9000(?)的值调用这些方法时,我得到不同的结果:left_recursive_factorial(900

ruby-on-rails - Rails 使用什么 Ruby 技术让我的 Controller 方法呈现 View ?

只是想知道是否有人知道在Rails框架中使用什么Ruby技术来完成以下任务。如果我不在RailsController上编写一个index方法,如果URL匹配该路由,Rails仍会呈现索引View文件。这是有道理的,因为我的Controller继承自父类,它必须有自己的index方法。但是,如果我确实定义了一个index方法,并且只告诉它设置一个实例变量,它仍然会呈现适当的View。例如:defindex@weasels=Weasel.all#IfIomitthisline,Railsrenderstheindexanyway.#Ifthisbehaviorisdefinedinthep

ruby - 为什么 proc 可能比 block 运行得更快?

Thisanswer在另一个问题上说array.map(&:to_s)比快array.map{|n|n.to_s}在第一个例子中,&把:to_s变成一个Proc。第二个例子使用了一个block。为什么Proc在该基准测试中可能比block快?这种技术是否允许解释器进行一些优化? 最佳答案 这并不是关于“procvsblock”。下面是一个简单的实验(随意复制运行):require'benchmark'many=500array=(1..10000).to_aproc=proc{|a|a.to_s}Benchmark.bmdo|x|x

ruby - 为什么 ruby​​2.0 中 object_id 的 true 和 nil 变了?

我遇到了thisrubyobject_idallocationquestion某个时候回来然后阅读这个很棒的article其中讨论了VALUE并解释了为什么object_id的true、nil和false是这样的。当我发现关于object_id为true和nil的明显变化时,我一直在玩弄ruby​​2.0object_id。forbidden:~$ruby-vruby2.0.0p0(2013-02-24revision39474)[x86_64-linux]forbidden:~$forbidden:~$irbirb(main):001:0>true.object_id=>20irb(

ruby - object_id 分配如何工作?

我正在研究Ruby的.object_id并注意到,在irb的几个连续session中,我得到了这些相同的结果:false.object_id//0true.object_id//2nil.object_id//4100.object_id//201事实上,每个整数的object_id似乎都是((value*2)+1)。另一方面,给定字符串的object_id在退出并重新运行irb后不再相同。这给我提出了几个问题:是否有确定某些object_id的已知方案?其他人基本上是随机的吗?true、false和nil的ID不是连续的。有没有办法询问给定的id代表什么对象?(我很好奇其他个位数和I

javascript - Selenium waitFor 机制的内部工作原理是什么?

我正在尝试通过拦截对doClick(locator)的调用来自定义Selenium的点击命令的行为(通过user-extentions.js)。基本上,只要显示我们应用程序的“忙碌指示器”,我就需要延迟点击操作。(现在对于这种事情的标准答案是在脚本中为这些情况插入一个waitFor。事实上,我们目前在整个脚本中有无数个它们。我正在努力消除它们。)检测页面元素是微不足道的部分。棘手的部分是让脚本真正等待。我看起来很有前途但失败的尝试如下所示:varnativeClick=Selenium.prototype.doClick;Selenium.prototype.doClick=funct

windows - 栈和栈基地址

在MEMORY_BASIC_INFORMATION结构一找到两个PVOID变量,分别称为BaseAddress和AllocationBase。我正在阅读一本关于线程的书,它非常详细地介绍了如何让堆栈空间留在堆栈中,但是有些东西我不确定我是否理解正确。上述结构体中的BaseAddress,指向当前线程栈中的最高地址还是最低地址?由于堆栈向下增长,最低的会在顶部,最高的会在底部。AllocationBase和BaseAddress字段之间到底有什么区别?我觉得MSDN文档的解释不是很清楚,所以我希望有人能澄清一点?在我的书中它还说'AllocationBase'地址与TEB结构中的'Dea