草庐IT

编译构造

全部标签

ruby - Mac OS X 10.6.8 手动编译 Ruby 时的 GEM 在哪里?

我在SnowLeopard上手动构建了Ruby1.9.2。现在我找不到我的旧GEM文件了。我猜他们现在正走在不同的道路上。所以我有三个问题:geminstallsinatra放置sinatragem的“旧”gem路径是什么?我手动构建Ruby时设置的"new"gem路径是什么?如何更改它以便Ruby再次找到我的gem? 最佳答案 在命令提示符处键入gemenv(使用旧的Ruby安装的gem命令)会给出类似于以下内容的内容:>RubyGemsEnvironment:>-RUBYGEMSVERSION:1.3.6>-RUBYVERSIO

ruby - 资源编译在服务器环境中崩溃,出现 : "NoMethodError: undefined method ` [ ]' for nil:NilClass"

为了这个我一直在努力。我一直与Assets管道关系不好,它总是给我带来麻烦..今天又是..当我尝试在本地编译我的Assets时,一切都很好:$RAILS_ENV=productionrakeassets:precompile--trace但是当我使用Capistrano部署时:cd/var/www/xxx/releases/20140717164232&&(RAILS_ENV=productionbundleexecrakeassets:precompile)它因以下错误而崩溃:rakeaborted!NoMethodError:undefinedmethod`[]'fornil:Ni

ruby-on-rails - 文字和构造函数之间的区别? ([] 与 Array.new 和 {} 与 Hash.new)

我很想知道[]和Array.new以及{}和Hash.new之间的更多区别我对它进行了相同的基准测试,似乎简写是赢家require'benchmark'many=500000Benchmark.bmdo|b|b.report("[]\t"){many.times{[].object_id}}b.report("Array.new\t"){many.times{Array.new.object_id}}b.report("{}\t"){many.times{{}.object_id}}b.report("Hash.new\t"){many.times{Hash.new.object_id

ruby-on-rails - 编译器未能生成可执行文件。 (运行时错误)

我最近升级到了OSMountainLion。我正在处理的项目需要gemsys-proctable作为依赖项,但是当我运行bundleinstall时,我得到:Fetchinggemmetadatafromhttps://rubygems.org/............Installingsys-proctable(0.9.2)withnativeextensionsGem::Installer::ExtensionBuildError:ERROR:Failedtobuildgemnativeextension./Users/mgriffel/.rvm/rubies/ruby-1.9.

ruby - 无法编译 ruby​​ 1.9.3

当我运行时rvminstall1.9.3--with-gcc=clang在MacOSXLion上,ruby无法编译,我在(.rvm/log/ruby-1.9.3-p374/make.log)中收到以下错误[2013-01-2916:31:05]makeCC=clangLD=ldLDSHARED=clang-dynamic-bundleCFLAGS=-O3-ggdb-Wall-Wextra-Wno-unused-parameter-Wno-parentheses-Wno-long-long-Wno-missing-field-initializers-Werror=pointer-ari

编译器是否对所有内联函数调用执行相同的操作?

C++编译器是否会对将两个不同的呼叫呼叫采取不同的决定?考虑这样的代码:inlinefunc(intx){returnx+(x编译器会在循环之前对呼叫和循环中的呼叫执行相同的操作?如果我们考虑了代码长度以及速度优化,则不应将循环之前的呼叫与内部的呼叫,内部的呼叫。看答案这取决于您的编译器。假设你用gcc5.4.0和-O2优化水平。内部的第一行main功能inty=func(1)+func(2)+func(3)+func(4);将根据整数文字和内部的代码在编译时间计算for循环将被内衬。但是,如果您使用另一个编译器或另一个优化级别,则结果可能会有所不同。如果您希望检查代码的组件输出,请使用编译器

ruby - 构造函数覆盖

我有一个类:classOnedefinitialize;endend我需要像这样用我自己的构造函数创建一个新类:classTwo但是当我启动代码时,出现错误:thingtest.rb:10:in`initialize':wrongnumberofarguments(1for0)(ArgumentError) 最佳答案 super在这种情况下(没有括号)是一种特殊形式。它使用原始参数调用父类(superclass)方法。尝试调用super() 关于ruby-构造函数覆盖,我们在StackO

ruby - 在 ruby​​ 中调用父构造函数

如何调用父类的构造函数?moduleCattr_accessor:c,:ccdefinitializationc,cc@c,@cc=c,ccendendclassBattr_accessor:b,:bbdefinitializationb,bb@b,@bb=b,bbendendclassA谢谢。 最佳答案 Ruby没有构造函数,因此显然不可能调用它们,无论是父类还是其他。然而,Ruby确实有方法,并且为了调用与当前正在执行的方法同名的父方法,您可以使用super关键字。[注意:不带参数的super是传递与当前正在执行的方法相同的参数

ruby - 如何编译 Ruby?

是否有一种工具可以让我编译Ruby代码使其运行得更快?例如,我听说有一个Python的工具叫“pyc”,它可以让我们编译代码,使其运行速度提高10倍。 最佳答案 简单的答案是您不能,至少对于MRI1.8(标准)。这是因为1.8通过遍历抽象语法树来工作。Python、Ruby1.9、JRuby和Rubinius使用字节码,这允许编译为中间表示(字节码)。从MRIRuby2.3开始,这变得很容易,请参阅answer下面。使用Rubinius,您可以按照这篇文章中的描述进行操作:http://rubini.us/2011/03/17/ru

ruby - rspec:如何 stub 构造函数调用的实例方法?

classAdefinitialize@x=do_somethingenddefdo_something42endend如何在调用原始实现之前在rspec中stubdo_something(从而将42分配给@x)?当然,在不改变实现的情况下。 最佳答案 Here'sthecommitwhichaddsthefeaturetorspec-这是在2008年5月25日。有了这个你可以做A.any_instance.stub(do_something:23)但是,rspec的最新gem版本(1.1.11,2008年10月)没有这个补丁。Th