Project

General

Profile

Actions

Bug #18032

closed

Openstruct is ~20..25x slower with Ruby 3.0.0 and 3.0.1 compared to earlier versions

Added by TiloS (Tilo S) over 3 years ago. Updated over 3 years ago.

Status:
Rejected
Target version:
-
[ruby-core:104550]

Description

Doing some timings with different Ruby versions, I noticed that when using Ruby 3.0.0 and 3.0.1
the time to create OpenStruct instances has significantly increased by 20..25x


0.936016 seconds elapsed for Class.new (Ruby 2.7.2)
0.453067 seconds elapsed for Struct (Ruby 2.7.2)
1.016676 seconds elapsed for Hash (Ruby 2.7.2)
1.482318 seconds elapsed for OpenStruct (Ruby 2.7.2)

0.421272 seconds elapsed for Class.new (Ruby 3.0.0)
0.322617 seconds elapsed for Struct (Ruby 3.0.0)
0.719928 seconds elapsed for Hash (Ruby 3.0.0)
35.130777 seconds elapsed for OpenStruct (Ruby 3.0.0) (oops!)

see also: https://stackoverflow.com/questions/1177594/when-should-i-use-struct-vs-openstruct/5440064#5440064

Can someone please look into this?


Files

OpenStruct_timing.rb (1.04 KB) OpenStruct_timing.rb TiloS (Tilo S), 07/09/2021 05:04 AM

Related issues 2 (0 open2 closed)

Related to Ruby master - Bug #12136: OpenStruct.new(format: :bar).send :format # => too few argumentsClosedActions
Related to Ruby master - Bug #15409: OpenStruct error when attribute is called 'method'Closedmarcandre (Marc-Andre Lafortune)Actions
Actions

Also available in: Atom PDF

Like0
Like0Like0Like0Like0Like0