Project

General

Profile

Actions

Bug #10231

closed

Process.detach(pid) defines new singleton classes every call

Added by headius (Charles Nutter) about 10 years ago. Updated about 10 years ago.

Status:
Closed
Target version:
ruby -v:
Any version with Process.detach
[ruby-core:64972]

Description

The logic for Process.detach(pid) adds a singleton "pid" method to the thread it returns for every call. This is bad for method caches (MRI still flushes them all for this, I believe) and memory churn (singleton classes are not small).

The offending line of code is here: https://github.com/ruby/ruby/blob/trunk/process.c#L1041

I would suggest that Process.detach should return a subclass of Thread that has the pid method defined ahead of time.

It also stores the value in thread local storage, rather than as an instance variable. I'm not sure why.

Actions

Also available in: Atom PDF

Like0
Like0Like0Like0Like0Like0Like0Like0Like0Like0