草庐IT

java - PlayFramework 2.2 Java Action 组合

全部标签

ruby-on-rails - 如何组合 ActiveRecord 对象?

我想知道在Rails中是否有一种有效的方法来组合多个ActiveRecord对象的结果。例如,我可能对三个单独的表进行三个单独的调用,我希望将结果组合起来,并按公共(public)列排序。这是一个非常基本的代码示例,有望使我的问题更容易理解:@results1=Table1.find(:all)@results2=Table2.find(:all)@results3=Table3.find(:all)@combined_results_sorted_by_date_column=(how?)正如其他人所建议的,这是解决问题的一种方法。@combined_results=@result1

ruby-on-rails - 在 Ruby on Rails 中组合显示和编辑操作?

我只是想知道是否有人在没有任何Show操作的情况下构建过Rails应用程序。在我的应用程序中,如果用户从列表中选择,比如说一个项目,他可能不仅要显示它,还要编辑em>它。那么不执行任何显示操作而是将所有记录链接到编辑表单是否是一种好的做法?我看到的唯一警告是用户可能会不小心编辑项目。但这可以通过使用jQuery在所有表单字段上设置默认属性disabled来避免。这样,用户将必须单击“编辑”按钮才能解锁表单字段以进行编辑。这有意义吗?还是我完全疯了?谁知道呢,也许这会导致与Rails的RESTful架构发生冲突? 最佳答案 第一个想法

ruby - 在 JRuby 中,如何确定导致 java.lang.ThreadDeath 的原因?

在为一些与JRuby中的临时文件交互的代码运行单元测试时,我有时会得到以下信息:Exception:java.lang.ThreadDeaththrownfromtheUncaughtExceptionHandlerinthread"Thread-6395"它似乎没有引起任何问题,但这是怎么回事,我如何确定它发生在哪里?我尝试打开-d,但这并没有给我异常的堆栈跟踪。 最佳答案 FWIW:这可能与http://jira.codehaus.org/browse/JRUBY-7074有关.我偶尔会在不使用反引号但调用系统的JRuby程序中

ruby - 如何在 ruby​​ 中组合包含 method_missing 的模块

我有几个模块缺少扩展方法:moduleSaysHellodefrespond_to?(method)super.respond_to?(method)||!!(method.to_s=~/^hello/)enddefmethod_missing(method,*args,&block)if(method.to_s=~/^hello/)puts"Hello,#{method}"elsesuper.method_missing(method,*args,&block)endendendmoduleSaysGoodbyedefrespond_to?(method)super.respond_

ruby - 我们什么时候使用 ruby​​ 模块 vs 使用类组合?

以前有人问过与此类似的问题,但我特别询问有关使用组合作为使用模块混入的替代方法的问题。classHelperdefdo_somthingendend如果我需要“使用”一个类而不是继承它,我会简单地组合它并使用它。classMyStuffdefinitializehelper=Helper.newhelper.do_somethingendend我为什么要为此创建一个模块:moduleHelperdefdo_somethingendendclassMyStuffincludeHelperend我看到的唯一区别是,如果我使用模块,周围不会有很多Helper对象。但是我没有看到任何东西周围有

ruby - 为什么某些 Ruby 代码在 2.53GHz 上的运行速度是在 2.2GHz Core 2 Duo 处理器上的两倍?

(本题试图找出为什么一个程序在不同的处理器上运行会有所不同,所以它与编程的性能方面有关。)以下程序在配备2.2GHzCore2Duo的Macbook上运行需要3.6秒,在配备2.53GHzCore2Duo的MacbookPro上运行需要1.8秒。这是为什么?这有点奇怪……当CPU的时钟速度仅快15%时,为什么要加倍速度?我仔细检查了CPU仪表,以确保2个内核中没有一个处于100%使用率(以便查看CPU是否忙于运行其他东西)。难道是因为一个是MacOSXLeopard,一个是MacOSXSnowLeopard(64位)?两者都运行Ruby1.9.2。pRUBY_VERSIONpRUBY_

ruby - Ruby 2.2 中的垃圾收集器引发意想不到的 CoW

当我fork我的进程时,如何防止GC引发写时复制?由于我在我的程序中遇到了一些内存问题(我的60核0.5Tb机器上的内存不足,即使是相当小的任务),我最近一直在分析Ruby中垃圾收集器的行为。对我来说,这确实限制了ruby​​在多核服务器上运行程序的实用性。我想在这里展示我的实验和结果。当垃圾收集器在fork期间运行时会出现此问题。我调查了三个案例来说明这个问题。案例一:我们使用数组在内存中分配了很多对象(不超过20字节的字符串)。字符串是使用随机数和字符串格式创建的。当进程fork并且我们强制GC在子进程中运行时,所有共享内存都变为私有(private),导致初始内存重复。案例2:我

ruby-on-rails - Ruby 2.2:PG::CharacterNotInRepertoire:错误:编码 "UTF8"的无效字节序列

我正在升级Rails4.1应用程序以使用Ruby2.2。在升级期间,事实证明该应用程序使用了旧版本的pggem(0.12),并且gem没有使用Ruby2.2安装。所以我尝试使用更新版本的pggem(0.17.1)。现在在系统中创建新用户时有时会出现以下错误:PG::CharacterNotInRepertoire:ERROR:invalidbytesequenceforencoding"UTF8"Ruby2.2和Postgres是否存在任何已知问题?看起来应用程序配置为使用unicode:config.encoding="utf-8"在application.rb中设置,encodin

ruby-on-rails - 为 memcached 和 Rails 组合片段和对象缓存的最佳方法

假设您有一个显示最新帖子的页面片段,并且您在30分钟后将其过期。我在这里使用Rails。30.minutes)do%>...显然,如果该片段存在,您不需要进行数据库查找来获取最新的帖子,因此您也应该能够避免这种开销。我现在正在做的是Controller中类似这样的东西,它似乎可以工作:unlessRails.cache.exist?"views/recent_posts"@posts=Post.find(:all,:limit=>20,:order=>"updated_atDESC")end这是最好的方法吗?安全吗?我不明白的一件事是为什么片段的键是“recent_posts”,而稍后

ruby-on-rails - 如何在 Windows 中为 Ruby on Rails 配置 Apache 2.2?

我正尝试着手编写一些RubyonRails应用程序并在Mongrel上取得了成功,但是,我想将我的应用程序部署到Windows上的Apache2.2实例吗?我发现的所有教程似乎都已过时,并且适用于旧版本的Apache/Rails。有人知道为RubyonRails应用程序配置Apache2.2的最新好教程吗? 最佳答案 编辑:至少在Win出现PhusionPassenger之前,Apache+Mongrel是可行的方法。您可以在没有Mongrel的情况下使用Apache+FastCGI,但在实际负载下您会遇到(更多)僵尸进程和(更多)