草庐IT

objc_requires_super

全部标签

ruby - require File.expand_path(..., __FILE__) 是最佳实践吗?

requireFile.expand_path(...,__FILE__)是要求项目中其他文件的最佳方式吗? 最佳答案 在Ruby1.9.2中+require_relative可能是更正确的方法。出于安全原因,require已更改为不包含您的'.'目录。添加了require_relative,以便为相对于您的调用脚本路径的模块提供本地文件解决方案。您可以searchhereonStackOverflow,特别是在“Whatisrequire_relativeinRuby?”中,以及互联网和查找使用技巧以及why-formessage

ruby - Ruby 中的 super 关键字

这段代码中的super是做什么用的?definitializeoptions={},&block@filter=options.delete(:filter)||1superend据我所知,这就像递归调用函数,对吧? 最佳答案 no...super调用父类的方法,如果存在的话。此外,正如@EnabrenTane指出的那样,它还将所有参数传递给父类方法。 关于ruby-Ruby中的super关键字,我们在StackOverflow上找到一个类似的问题: http

ruby - "require"默认查找的路径是什么?

在Ruby中,有人告诉我这样做require"some_file"Ruby会在某些地方寻找文件。我知道它会查找some_file.rb,但默认情况下它在哪里查找? 最佳答案 这取决于您的平台,以及Ruby的编译方式,因此没有“那个”答案。你可以通过运行找到:ruby-e'puts$:'不过,通常情况下,您拥有标准、站点和供应商Ruby库路径,包括每个路径下的架构、版本和通用目录。​​ 关于ruby-"require"默认查找的路径是什么?,我们在StackOverflow上找到一个类似的

ruby-on-rails - ruby super 关键字

据我了解,super关键字在当前类的父类(superclass)中调用与当前方法同名的方法。下面的autoload方法中,调用了super。我想知道在哪个父类(superclass)中我会找到一个具有相同名称的方法,或者对super的调用在这里做什么moduleActiveSupportmoduleAutoload...defautoload(const_name,path=@@at_path)full=[self.name,@@under_path,const_name.to_s,path].compact.join("::")location=path||Inflector.und

ruby - 何时在 Ruby 中使用 `require` 、 `load` 或 `autoload` ?

我理解Ruby中require、load和autoload之间的细微差别,但我的问题是,你怎么知道要加载哪一个利用?除了能够在匿名模块中“包装”load之外,require似乎是首选。但是autoload允许您延迟加载文件——这听起来很棒,但我不确定您实际上比require获得了什么一种方法优于另一种方法吗?是否存在一种方法脱颖而出的情况? 最佳答案 通常,您应该使用require。load每次都会重新加载代码,因此如果您从多个模块执行此操作,将会做很多额外的工作。autoload的惰性在理论上听起来不错,但许多Ruby模块会做一些

ruby - 我安装了一个 gem 但 require 'gemname' 不起作用。为什么?

我真正要问的问题是为什么require不采用gem的名称。另外,如果没有,找到需要该死的东西的密咒的最简单方法是什么!?例如,如果我安装了memcache-client,那么我必须使用它来要求它require'rubygems'require'memcache' 最佳答案 我的系统似乎也不知道RubyGems的存在——除非我告诉它。“require”命令被RubyGems覆盖,因此它可以加载gems,但除非您已经需要RubyGems,否则它不知道如何执行此操作。所以如果你自己写,你可以这样做:require'rubygems'req

ruby-on-rails - load 与 Ruby 中的 require 有何不同?

在RubyonRails应用程序中,load和require之间有什么主要区别吗?还是它们都具有相同的功能? 最佳答案 require在所有定义的搜索路径中搜索库并追加.rb或.so到您输入的文件名。它还确保图书馆只是包括一次。因此,如果您的应用程序需要库A和B,并且库B也需要库A,那么A将只加载一次。使用load,你需要添加库的全名,每次你加载它调用load-即使它已经在内存中。 关于ruby-on-rails-load与Ruby中的require有何不同?,我们在StackOverf

Ruby:require 与 require_relative - 在 Ruby <1.9.2 和 >=1.9.2 中运行的最佳实践

如果我想要,最佳实践是什么requireRuby中的一个相关文件and我希望它在1.8.x和>=1.9.2中工作?我看到几个选项:就做$LOAD_PATH忘记一切做$LOAD_PATHrequire'./path/to/file'检查是否RUBY_VERSIONrequire_relative作为require,使用require_relative事后需要的地方检查是否require_relative已经存在,如果存在,尝试像之前的情况一样继续使用奇怪的结构,例如requireFile.join(File.dirname(__FILE__),'path/to/file')-唉,它们似乎

ruby 'require' 错误 : cannot load such file

我有一个文件,main.rb,内容如下:require"tokenizer.rb"tokenizer.rb文件位于同一目录,其内容为:classTokenizerdefself.tokenize(string)returnstring.split("")endend如果我尝试运行main.rb,我会收到以下错误:C:\DocumentsandSettings\my\src\folder>rubymain.rbC:/Ruby193/lib/ruby/1.9.1/rubygems/custom_require.rb:36:in`require':cannotloadsuchfile--to

ruby - Ruby 中的 require_relative 和 require 有什么区别?

Ruby中的require_relative和require有什么区别? 最佳答案 看看docs:require_relativecomplementsthebuiltinmethodrequirebyallowingyoutoloadafilethatisrelativetothefilecontainingtherequire_relativestatement.Forexample,ifyouhaveunittestclassesinthe"test"directory,anddataforthemunderthetest"t