草庐IT

ruby - GC.disable 的任何性能缺点?

是否存在GC.disable会降低性能的情况?只要我使用的是真正的RAM而不是交换内存,就可以这样做吗?我正在使用MRIRuby2.0,据我所知,它是64位的,并且使用的是64位的Ubuntu:ruby2.0.0p0(2013-02-24revision39474)[x86_64-linux]Linux[redacted]3.2.0-43-generic#68-UbuntuSMPWedMay1503:33:33UTC2013x86_64x86_64x86_64GNU/Linux 最佳答案 GC.disable将禁用垃圾回收。像rub

c - (U) Ruby 扩展 : rb_gc_mark() and instance variables

我正在编写定义类的ruby​​扩展。如果我使用Data_Wrap_Struct()来实现我对rb_define_alloc_func()的回调,我是否需要手动标记和释放实例变量?还是仍然为我处理? 最佳答案 Ruby的GC将收集在您的Ruby对象的实例变量中引用的所有Ruby对象。您不必也不应该自己释放Ruby实例变量(即在您的扩展中使用rb_iv_set()/rb_iv_get()访问的任何对象)。但是,如果包装的Cstruct引用Ruby对象,那么您必须在传递给Data_Wrap_Struct()的mark回调中标记这些对象。(

ruby-on-rails - rb_gc() 上的跨线程冲突

我正在处理的代码库最近从Ruby1.9.2升级到Ruby1.9.3,从Rails3.1升级到Rails3.2.2。因为我使用的是RVM,所以我只是简单地执行了rvminstall1.9.3,我原以为这是所有必要的。当我运行时railss我得到了错误[BUG]cross-threadviolationonrb_gc()我找到了许多与此问题相关的链接。有oneonStackOverflow,但它并没有真正给出答案。最有希望的答案是ontheRVMsite:IneverycaseofthisIhaveseenthusfarithasalwaysendedupbeingthatarubygem

ruby - 安装gem : Couldn't reserve space for cygwin's heap, Win32错误487错误

我正在尝试在我的机器上安装win32-apigem,但在构建native扩展时我遇到了一些问题:$geminstallwin32-api--no-ri--rdocTemporarilyenhancingPATHtoincludeDevKit...Buildingnativeextensions.Thiscouldtakeawhile...C:\Programs\dev_kit\bin\make.exe:***Couldn'treservespaceforcygwin'sheap,Win32error0ERROR:Errorinstallingwin32-api:ERROR:Failed

ruby-on-rails - Ruby 1.9 垃圾收集器,GC.disable/enable

我正在开发一个Rails2.3、Ruby1.9.1网络应用程序,它在每个请求之前执行大量计算。对于每个请求,它都必须计算一个包含300个节点和约1000条边的图。该图及其所有节点、边和其他对象针对每个请求(~2000个对象)进行初始化-实际上,它们是使用Marshal.load(Marshal.dump())从未计算的缓存图中克隆的。性能在这里是一个很大的问题。现在整个请求平均需要150毫秒。然后我看到在请求期间,部分计算随机花费更长的时间。假设这可能是GarbageCollector启动,我将请求包装在GC.disable和GC.enable中,以便请求等待垃圾收集,直到计算和渲染完

ruby-on-rails - 每个请求的 Ruby GC 执行超过 ~250-320 毫秒

我有一个ruby​​onrails应用程序。我正在调查我的NewRelic门户中的Apdex下降情况,我发现平均有250-320毫秒的时间花在了GC执行上。这是一个非常令人不安的数字。我在下面包含了一个屏幕截图。我的Ruby版本是:ruby1.9.3p194(2012-04-20修订版35410)[x86_64-linux]任何关于调整它的建议都是理想的。这个数字应该低得多。 最佳答案 您在GC上花费了很多时间,因为您经常运行GC。默认情况下,Ruby设置适用于小型脚本而非大型应用程序的GC参数。尝试使用以下环境参数集启动您的应用:

ruby - Ruby 的 GC.stat 字段是什么意思?

我正在使用GC.stat来分析我们的Rails应用程序中的内存使用情况。GC.stat返回具有以下键的散列::count:heap_used:heap_length:heap_increment:heap_live_num:heap_free_num:heap_final_num有人知道这些值的确切含义吗?Ruby源代码(gc.c)中没有关于它们的文档,只有评论:“散列的内容是实现定义的,将来可能会更改。”其中一些字段在上下文中是有意义的,例如count是Ruby分配的堆数。但是heap_final_num是什么?什么是heap_increment?heap_length是最小堆大小吗

数据结构之优先级队列【堆】(Heap)

目录1.优先级队列(PriorityQueue)2.堆的概念3.堆的存储方式4.堆的创建5.用堆模拟实现优先级队列 6.PriorityQueue常用接口介绍6.1 PriorityQueue的特点6.2 PriorityQueue几种常见的构造方式7.top-k问题8.堆排序本篇主要内容总结(1)优先级队列底层是堆来实现的(2)堆的本质是完全二叉树 ,堆有大根堆和小根堆(3)大根堆:根节点最大的堆;小根堆:根节点最小的堆(4)堆的创建实现:大根堆为例大根堆创建:孩子结点和根节点比较交换,核心思想:向下调整  时间复杂度O(n)堆的插入:插入到最后一个位置,和根结点交换,核心思想:向上调整堆的

javascript - Node : How to free buffers that get allocated outside of the V8 memory heap

我有一个应用程序,我按顺序从服务器下载mp3文件,将它们临时存储在我的服务器中,然后将它们直接流式传输到客户端,如下所示:functiondownloadNextTrack(){varrequest=http.get('http://mp3server.com',function(response){response.on('data',function(data){fs.appendFile('sometrack.mp3',data,function(err){});});response.on('end',function(){streamTrack('sometrack.mp3'

javascript - 如何调试 Chrome Javascript 中 GC 事件之间看似长时间的停顿

我一直在尝试优化一个Angular网站,但在某些路由之间切换时,我的页面响应出现大量延迟。显示的每个页面都不大,但其中包含相当数量的元素和合理数量的绑定(bind)。我已经用bindonce做了我能做的,所以我用Chrome查看了调试器,我发现我的大部分时间似乎都花在了GC上。奇怪的是,每个GC之间似乎存在巨大的差距,我正试图弄清楚这些差距到底是什么。我猜是在它实际删除项目时,小条是在进行标记和清除时,但我对分析JS的这种深度并不熟悉。我的大部分工作都是在C++/C#/Java中完成的。 最佳答案 在半秒内收集了超过20MB的垃圾。