草庐IT

android - MediaPlayer 应该在单独的线程中运行吗?

全部标签

ruby-on-rails - 如何在我的 Rails 应用程序中运行 rake 任务

我想做的事情:在model.rb中,在after_commit中,我想运行rake任务ts:reindexts:reindex通常使用rakets:index运行 最佳答案 如果您希望此rake代码在请求周期内运行,那么您应该避免通过system或任何exec系列(包括反引号)运行rake,因为这将启动一个新的ruby​​解释器并重新加载每次调用Rails环境。相反,您可以直接调用Rake命令,如下所示:-require'rake'classSomeModel注意:在Rails4+中,您将使用Rails.root而不是RAILS_R

ruby-on-rails - Rails : Skinny Controller vs. Fat Model,还是我应该让我的 Controller 厌食?

我知道之前已经回答过类似的问题-例如:逻辑应该往哪里走在哪里做某些任务等。但我有一个更具体的问题-我应该在多大程度上采用这个公理:让你的Controller瘦,让你的模型胖!这是一个例子:例如,假设我有多个验证数据源。一个很好的例子是VIN号码-我可以根据制造商数据源、DMV数据源以及我的本地数据库对其进行验证,以查看我的记录。所以我有一个名为Vin和vins_controller的模型。在模型内部我有5种方法:check_against_local_dbcheck_against_dmvcheck_against_car_maker_1check_against_car_maker_

ruby - 为什么 EventMachine 的延迟比 Ruby 线程慢?

我有两个使用Mechanize获取Google索引页的脚本。我原以为EventMachine会比Ruby线程更快,但事实并非如此。EventMachine代码成本:“0.24s用户0.08s系统2%cpu12.682总计”Ruby线程代码成本:“0.22s用户0.08s系统5%cpu5.167总计”我是否以错误的方式使用了EventMachine?事件机器:require'rubygems'require'mechanize'require'eventmachine'trap("INT"){EM.stop}EM.rundonum=0operation=proc{agent=Mechan

ruby-on-rails - 应该破坏我的回溯吗?

我有一个或多或少像这样的测试:classFormDefinitionTest我特意加了一个raise"blah"在路上的某个地方,我得到了这个错误:RuntimeError:blahtest/unit/form_definition_test.rb:79:in`__bind_1290079321_362430'当我应该得到一些东西时:/Users/pupeno/projectx/db/seed/sheet_definitions.rb:17:in`sheet_definition':blah(RuntimeError)from/Users/pupeno/projectx/db/seed

ruby-on-rails - 我应该忽略 schema.rb 因为扩展在开发/生产操作系统上不同吗?

我的数据库使用PostgreSQL。我在Mac上开发,需要这一行:#db/schema.rbonMacenvironmentenable_extension"plpgsql"但是,在Linux上不需要扩展。在这种情况下,我们是否应该忽略schema.rb并通过db:migrate为开发和生产环境生成它? 最佳答案 据我所知,问题是自动生成的schema.rb在生产和开发中会有所不同,因此会导致git中的文件发生变化,因为这一行。该行是由mac上的postgres适配器生成的吗?如果它是手动添加的,我会尝试将它放在其他地方,也许在初始

ruby - Ruby 的 Net::HTTP 线程安全吗?

Ruby的Net::HTTP线程安全吗?(除了它明确表示不是的version_1_1和version_1_2方法) 最佳答案 我不会指望它。2008年,matzwrote:ForMRI(1.8.x)andYARV(1.9.x),everyCimplementedmethodsareprotectedbyGIL(GlobalInterpreterLock),sothatyoudon'thavetoworryabout.Butitmightdependoneachimplementation.Net::HTTP在stdlib中,这意味着

ruby-on-rails - 从 rake 任务中运行工头

我有以下Rake任务:namespace:foremandotask:devdo`foremanstart-fProcfile.dev`endenddesc"RunForemanusingProcfile.dev"task:foreman=>'foreman:dev'forman命令在shell中运行良好,但是当我运行rakeforeman时,出现以下错误:/Users/me/.gem/ruby/2.0.0/gems/bundler-1.5.2/lib/bundler/rubygems_integration.rb:240:in`blockinreplace_gem':foremani

ruby - Ruby 的线程组有什么用?

我正在浏览Pickaxe,寻找有关Thread的文档,并遇到了ThreadGroup。文档描述了它的作用,但没有解释它的用途。是与线程池相关的线程组,我assumedRubydoesn'thave? 最佳答案 新线程在其父线程组中创建。您可以使用ThreadGroup组织由产生其他线程的父线程给出的隐式树结构,并使用list实例方法获取所有尚未终止的线程,即定义对所有线程进行操作的方法组中的线程。此外,如果您运行不受信任的代码并希望关注它产生的线程,您可以使用enclose来禁止向该组添加(或删除)线程。

ruby-on-rails - 在 Devise on Rails 中使用单独的身份验证模型

我有一个简单的解决方案,我自己使用以下对象:Account(有token字段,认证时返回并用于API调用)身份验证(具有auth_type/auth_id和对帐户的引用)我有一个单独的身份验证模型,可以连接多种登录方式(设备UUID、电子邮件/密码、twitter、facebook等)。但似乎在Devise的所有示例中,您都在User(Account)模型上使用它。那不是不够灵活吗?例如,OmniAuth模块在User模型上存储提供者和ID,如果您希望能够从Twitter和Facebook登录,会发生什么情况?只有一个提供者有空间吗?我应该在我的Account模型还是Authentic

ruby-on-rails - 模型方法应该调用 'save' 本身吗?

假设我们在模型中有一个方法只需要调用已保存的记录可能会更新模型本身,因此之后需要再次保存模型“保存”调用是否应该像下面的代码一样发生在方法内部defresultsave!ifnew_record?#dosomefunkystuffherethatmayalsochangethemodelstate#...#Andcalculatethereturnvaluesearch_result="foo"#Let'ssay"foo"isthevaluewecalculatedsave!ifchanged?search_result#returnend还是应该由外部观察者(Controller)负