[#104481] [Ruby master Feature#18020] Introduce `IO::Buffer` for fiber scheduler. — samuel@...

Issue #18020 has been reported by ioquatix (Samuel Williams).

31 messages 2021/07/03

[#104492] [Ruby master Bug#18022] Spec errors for rbconfig/unicode_[emoji_]version_spec: Using Ruby 2.7 even when on Ruby 3.1 — duerst@...

Issue #18022 has been reported by duerst (Martin Dst).

8 messages 2021/07/04

[#104552] [Ruby master Feature#18033] Time.new to parse a string — nobu@...

Issue #18033 has been reported by nobu (Nobuyoshi Nakada).

26 messages 2021/07/09

[#104560] [Ruby master Bug#18035] Introduce general module for immutable by default. — samuel@...

Issue #18035 has been reported by ioquatix (Samuel Williams).

41 messages 2021/07/09

[#104629] [Ruby master Misc#18039] DevelopersMeeting20210819Japan — mame@...

Issue #18039 has been reported by mame (Yusuke Endoh).

11 messages 2021/07/16

[#104643] [Ruby master Bug#18040] Why should `foo(1 if true)` be an error? — bughit.github@...

Issue #18040 has been reported by bughit (bug hit).

10 messages 2021/07/19

[#104665] [Ruby master Feature#18042] YARV code optimization — motoroller95@...

Issue #18042 has been reported by motoroller (Iskandar Gohar).

11 messages 2021/07/23

[#104692] [Ruby master Bug#18048] Thread#join can break with fiber scheduler unblock fails or blocks. — samuel@...

Issue #18048 has been reported by ioquatix (Samuel Williams).

10 messages 2021/07/27

[#104723] [Ruby master Bug#18054] No rule to make target 'thread_fd_close.c', needed by 'thread_fd_close.o' — duerst@...

Issue #18054 has been reported by duerst (Martin Dst).

8 messages 2021/07/29

[ruby-core:104555] [Ruby master Bug#18032] Openstruct is ~20..25x slower with Ruby 3.0.0 and 3.0.1 compared to earlier versions

From: marcandre-ruby-core@...
Date: 2021-07-09 06:34:58 UTC
List: ruby-core #104555
Issue #18032 has been updated by marcandre (Marc-Andre Lafortune).

Status changed from Assigned to Rejected

@mame is correct that #15409 was a concern, but this is mainly due to #12136 and listed in the release notes for 3.0.

Basically we have prioritized correctness over performance and came back to a solution similar to that of Ruby 2.2.

Note that only initialization from a Hash was impacted, but setting the attributes one by one was not much impacted.

If the benchmarking code is changed:

```ruby
# before
OpenStruct.new(:name => "User", :age => 21)
# after
o = OpenStruct.new
o.name = "User"
o.age = 21
```

You'll see that this similar code was always slow.

The documentation now states the multiple caveats of OpenStruct, one of which is performance.

A different class that would not define methods but use only `method_missing` would be faster, but not quite as accurate.

----------------------------------------
Bug #18032: Openstruct is ~20..25x slower with Ruby 3.0.0 and 3.0.1 compared to earlier versions
https://bugs.ruby-lang.org/issues/18032#change-92834

* Author: TiloS (Tilo S)
* Status: Rejected
* Priority: Normal
* Assignee: marcandre (Marc-Andre Lafortune)
* ruby -v: 3.0.0
* Backport: 2.6: UNKNOWN, 2.7: UNKNOWN, 3.0: UNKNOWN
----------------------------------------
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)


-- 
https://bugs.ruby-lang.org/

Unsubscribe: <mailto:ruby-core-request@ruby-lang.org?subject=unsubscribe>
<http://lists.ruby-lang.org/cgi-bin/mailman/options/ruby-core>

In This Thread