Ruby 1.9.2 リファレンスマニュアル > ライブラリ一覧 > dlライブラリ > DL::CPtrクラス

class DL::CPtr

クラスの継承リスト: DL::CPtr < Object < Kernel < BasicObject

要約

メモリ領域を表すクラスです。C 言語のポインタに相当します。

特異メソッド

定義 説明
self[val] -> DL::CPtr
to_ptr(val) -> DL::CPtr

与えられた val を指す CPtr オブジェクトを生成して返します。

malloc(size, free = nil) -> DL::CPtr

与えられた長さ size のメモリ領域を確保し、それを表す CPtr オブジェクトを生成して返します。

new(addr, size = 0, free = nil) -> DL::CPtr

与えられた addr が指すメモリ領域を表す CPtr オブジェクトを生成して返します。

インスタンスメソッド

定義 説明
self + n -> DL::CPtr

自身のアドレスに n バイトを足した新しい CPtr オブジェクトを返します。

ptr -> DL::CPtr
+ -> DL::CPtr

自身の指す値を CPtr にして返します。 自身の指す値はポインタであると仮定します。 C 言語におけるポインタのポインタに対する間接参照 *p と同じです。

self - n -> DL::CPtr

自身のアドレスから n バイトを引いた新しい CPtr オブジェクトを返します。

ref -> DL::CPtr
- -> DL::CPtr

自身を指す CPtr オブジェクトを返します。 C 言語におけるポインタへのアドレス演算子の適用 &p と同じです。

self <=> other -> Integer

ポインタの指すアドレスの大小を比較します。

eql?(other) -> bool
self == other -> bool

ポインタの指すアドレスが同一かどうかを判定します。

self[offset] -> Integer

自身の指すアドレスに offset バイトを足したメモリ領域の先頭を整数として返します。

self[offset, len] -> String

自身の指すアドレスに offset バイトを足したメモリ領域の先頭 len バイトを複製し、 文字列として返します。

self[offset] = n

自身の指すアドレスに offset バイトを足したメモリ領域を指定された n に書き換えます。

self[offset, len] = v

自身の指すアドレスに offset バイトを足したメモリ領域の先頭 len バイトに 文字列 str をコピーします。

free -> DL::CFunc

GC がメモリを解放するのに使用する DL::CFunc オブジェクトを返します。

free=(cfunc)

GC が自身を解放するのに使う関数を DL::CFunc で指定します。

inspect
null? -> bool

自身が NULL なら true を返します。そうでないなら false を返します。

size -> Integer
size=(s)

自身の指す領域のサイズを表すアクセサです。

to_i -> Integer

自身が指すアドレスを整数で返します。

to_s -> String
to_s(len) -> String

自身が指す領域から長さ len の文字列を複製して返します。

to_str -> String
to_str(len) -> String

自身が指す領域から長さ len の文字列を複製して返します。

to_value -> object

自身はヒープに確保された Ruby のオブジェクトを指すポインタであると仮定して、 自身が指すオブジェクトを返します。

継承したメソッド

! != === =~ __id__ __send__ _dump class clone dclone display enum_for equal? extend freeze frozen? hash initialize initialize_copy instance_eval instance_exec instance_of? instance_variable_defined? instance_variable_get instance_variable_set instance_variables is_a? marshal_dump marshal_load method method_missing methods must_be must_be_close_to must_be_empty must_be_instance_of must_be_kind_of must_be_nil must_be_same_as must_be_within_epsilon must_equal must_include must_match must_raise must_respond_to must_send must_throw nil? pretty_inspect pretty_print pretty_print_cycle pretty_print_inspect pretty_print_instance_variables private_methods protected_methods public_methods remove_instance_variable respond_to? respond_to_missing? singleton_class singleton_method_added singleton_method_removed singleton_method_undefined singleton_methods taint tainted? tap to_a to_ary to_hash to_int to_io to_proc to_regexp to_yaml to_yaml_properties to_yaml_style trust untaint untrust untrusted? wont_be wont_be_close_to wont_be_empty wont_be_instance_of wont_be_kind_of wont_be_nil wont_be_same_as wont_be_within_epsilon wont_equal wont_include wont_match wont_respond_to