Ruby 3.2 リファレンスマニュアル > ライブラリ一覧 > ostructライブラリ > OpenStructクラス
クラス・モジュールの継承リスト: OpenStruct < Object < Kernel < BasicObject
要素を動的に追加・削除できる手軽な構造体を提供するクラスです。
OpenStruct のインスタンスに対して未定義なメソッド x= を呼ぶと、 OpenStruct クラスの BasicObject#method_missing で捕捉され、そのインスタンスにインスタンスメソッド x, x= が定義されます。この挙動によって要素を動的に変更できる構造体として働きます。
require 'ostruct'
ab = OpenStruct.new
ab.foo = 25
p ab.foo # => 25
ab.bar = 2
p ab.bar # => 2
p ab # => <OpenStruct foo=25, bar=2>
ab.delete_field("foo")
p ab.foo # => nil
p ab # => <OpenStruct bar=2>
初期化にハッシュを使用することもできます。
require 'ostruct'
son = OpenStruct.new({ :name => "Thomas", :age => 3 })
p son.name # => "Thomas"
p son.age # => 3
son.age += 1
p son.age # => 4
son.items = ["candy","toy"]
p son.items # => ["candy","toy"]
p son # => #<OpenStruct name="Thomas", age=4, items=["candy", "toy"]>
OpenStruct は Ruby のメソッド探索を利用して、プロパティに必要なメソッドを見つけて定義します。これは BasicObject#method_missing と BasicObject#define_singleton_method によって実現されます。
作成されるオブジェクトのパフォーマンスに懸念がある場合は、この点を考慮する必要があります。Hash や Struct を使用する場合と比較して、これらのプロパティの設定にははるかに多くのオーバーヘッドがあるためです。小規模な Hash から OpenStruct を作成し、いくつかの要素にアクセスした場合、直接ハッシュテーブルにアクセスするよりも 200 倍遅くなることがあります。
これは潜在的なセキュリティ問題です。信頼されていないユーザーデータ(例:JSON を用いたリクエスト)から OpenStruct を構築した場合、キーがメソッドを作成し、そのメソッド名が永久に GC されることがないため、DoS 攻撃を受ける可能性があります。
これは、Ruby バージョン間の非互換性の原因にもなります:
o = OpenStruct.new o.then # => Ruby < 2.6 では nil、Ruby >= 2.6 では Enumerator
以下の方法では、組み込みライブラリのメソッドが上書きされる可能性があり、バグやセキュリティ上の問題が発生する可能性があります:
o = OpenStruct.new o.methods # => [:to_h, :marshal_load, :marshal_dump, :each_pair, ...] o.methods = [:foo, :bar] o.methods # => [:foo, :bar]
衝突を避けるために OpenStruct は ! で終わるメソッドは protected と private でのみ使用し、public な組み込みライブラリの ! で終わるメソッドはエイリアスを定義しています:
o = OpenStruct.new(make: 'Bentley', class: :luxury) o.class # => :luxury o.class! # => OpenStruct
! で終わるフィールドは使用しないことが推奨されます(ただし、強制ではありません)。サブクラスのメソッドを上書きすることはできませんし、! で終わる OpenStruct 自身のメソッドを上書きすることもできません。
以上の理由から OpenStruct を一切使用しないことを検討してください。
| 定義 | 説明 | |
|---|---|---|
new(hash = nil) -> OpenStruct
|
OpenStruct オブジェクトを生成します。 |
|
| 定義 | 説明 | |
|---|---|---|
self == other -> bool
|
自身と比較対象のオブジェクトが等しい場合に真を返します。そうでない場合は、偽を返します。 |
|
self[name] -> object
|
引数 name で指定した要素に対応する値を返します。 |
|
self[name] = value
|
引数 name で指定した要素に対応する値に value をセットします。 |
|
delete_field(name) -> object
|
nameで指定された要素を削除します。 |
|
dig(key, ...) -> object | nil
|
self 以下のネストしたオブジェクトを dig メソッドで再帰的に参照して返します。途中のオブジェクトが nil であった場合は nil を返します。 |
|
each_pair -> Enumerator
|
self の各要素の名前と要素を引数としてブロックを評価します。 |
|
eql?(other) -> bool
|
self と other が等しい場合に true を返します。そうでない場合は false を返します。 |
|
hash -> Integer
|
self のハッシュ値を返します。 |
|
inspect -> String
|
オブジェクトを人間が読める形式に変換した文字列を返します。 |
|
to_h -> { Symbol => object }
|
self を各要素の名前をキー(Symbol)、要素が値のハッシュに変換して返します。 |
|
| 定義 | 説明 | |
|---|---|---|
modifiable -> Hash
|
このメソッドは内部的に使用されます。 |
|
new_ostruct_member(name) -> Symbol
|
与えられた名前のアクセサメソッドを自身に定義します。 |
|
| 定義 | 説明 | |
|---|---|---|
InspectKey -> :__inspect_key__
|
内部的に使用する定数です。 |
|
!
!=
__id__
__send__
instance_eval
instance_exec
method_missing
singleton_method_added
singleton_method_removed
singleton_method_undefined
!~
<=>
===
_dump
class
clone
define_singleton_method
display
enum_for
equal?
extend
freeze
frozen?
initialize
initialize_clone
initialize_copy
initialize_dup
instance_of?
instance_variable_defined?
instance_variable_get
instance_variable_set
instance_variables
is_a?
itself
marshal_dump
marshal_load
method
methods
nil?
object_id
pretty_inspect
pretty_print
pretty_print_cycle
pretty_print_inspect
pretty_print_instance_variables
private_methods
protected_methods
psych_to_yaml
public_method
public_methods
public_send
remove_instance_variable
respond_to?
respond_to_missing?
send
singleton_class
singleton_method
singleton_methods
tap
then
to_a
to_ary
to_hash
to_int
to_io
to_proc
to_regexp
to_str
.yaml_tag
::ARGF
::ARGV
::DATA
::ENV
::RUBY_COPYRIGHT
::RUBY_DESCRIPTION
::RUBY_ENGINE
::RUBY_ENGINE_VERSION
::RUBY_PATCHLEVEL
::RUBY_PLATFORM
::RUBY_RELEASE_DATE
::RUBY_REVISION
::RUBY_VERSION
::SCRIPT_LINES__
::STDERR
::STDIN
::STDOUT
::TOPLEVEL_BINDING
| 定義 | 説明 | ライブラリ |
|---|---|---|
json_create(hash) -> OpenStruct
|
JSON のオブジェクトから OpenStruct のオブジェクトを生成して返します。 |
json/add/ostruct |
to_json(*args) -> String
|
自身を JSON 形式の文字列に変換して返します。 |
json/add/ostruct |