Ruby 1.8.7 リファレンスマニュアル > ライブラリ一覧 > dlライブラリ > DL::PtrDataクラス
クラスの継承リスト: DL::PtrData < Object < Kernel
メモリ領域を表すクラスです。C 言語のポインタに相当します。
malloc(size, free = nil) -> DL::PtrData
[permalink][rdoc][TODO]
サイズが size であるメモリ領域を確保し、それを指す DL::PtrData を返します。
new(addr, size = 0, free = nil) -> DL::PtrData
[permalink][rdoc][TODO]
アドレス addr を指すポインタに相当する PtrData オブジェクトを返します。
size を指定した場合、アドレス addr に確保されているメモリ領域のサイズは size であるとします。 GC は free 関数を使用してメモリを解放します。
self + n -> DL::PtrData
[permalink][rdoc]自身のアドレスに n バイトを足した新しい PtrData オブジェクトを返します。
この返り値には、free 関数がセットされていません。
ptr -> DL::PtrData
[permalink][rdoc]+ self -> DL::PtrData
自身の指す値を PtrData にして返します。 自身の指す値はポインタであると仮定します。 C 言語におけるポインタのポインタに対する間接参照 *p と同じです。
この返り値には、free 関数がセットされていません。
a = ['abc', 'def'].to_ptr p a.ptr.to_s #=> "abc"
self - n -> DL::PtrData
[permalink][rdoc]自身のアドレスから n バイトを引いた新しい PtrData オブジェクトを返します。
この返り値には、free 関数がセットされていません。
ref -> DL::PtrData
[permalink][rdoc]- self -> DL::PtrData
自身を指す PtrData オブジェクトを返します。 C 言語におけるポインタへのアドレス演算子の適用 &p と同じです。
この返り値には、free 関数がセットされていません。
s = "abc".to_ptr p s == s.ref.ptr #=> true
self <=> other -> Integer
[permalink][rdoc]ポインタの指すアドレスの大小を比較します。
self == other -> bool
[permalink][rdoc]eql?(other) -> bool
ポインタの指すアドレスが同一かどうかを判定します。
self[key] -> object
[permalink][rdoc][TODO]
構造体または共用体メンバ key の値を返します。返り値は DL::PtrData#struct! または DL::PtrData#union! によって定義された型により、Ruby のオブジェクトへ 変換されたものです。
self[offset, len = 0] -> String
[permalink][rdoc]自身の指すアドレスに offset バイトを足したメモリ領域の先頭 len バイトを複製し、 文字列として返します。(self + offset).to_s(len) と同等です。 offset + len が自身のサイズより小さいかを検証しません。
self[key] = val
[permalink][rdoc][TODO]
構造体または共用体メンバ key の値を val にします。
self[offset] = str
[permalink][rdoc][TODO]
自身の指すアドレスに offset バイトを足したメモリ領域に 文字列 str をコピーします。コピー先の領域が str のサイズより大きいか検証しません。
self[offset, len] = str
[permalink][rdoc][TODO]
自身の指すアドレスに offset バイトを足したメモリ領域の先頭 len バイトに 文字列 str をコピーします。str のサイズが len より小さい場合は、残りの領域を 0 で埋めます。 コピー先の領域が len より大きいか検証しません。
data_type -> [object]
[permalink][rdoc][TODO]
使ってはいけません。
define_data_type -> nil
[permalink][rdoc][TODO]
使ってはいけません。
free -> DL::Symbol
[permalink][rdoc][TODO]
GC がメモリを解放するのに使用するシンボルオブジェクト sym を返します。 sym は普通 PtrData#free= や PtrData.new によって設定されます。
free=(sym)
[permalink][rdoc][TODO]
GC が自身を解放するのに使う関数を DL::Symbol で指定します。
null? -> bool
[permalink][rdoc]自身が NULL なら true を返します。そうでないなら false を返します。
size -> Integer
[permalink][rdoc]size=(s)
[TODO]
自身の指す領域のサイズを返します。 s を指定した場合は、自身の指す領域のサイズは s であると設定します。 ただし、自身が指すメモリのサイズが s になるように再割り当てはしません。
struct!(type, *members) -> nil
[permalink][rdoc][TODO]
構造体のメンバにメソッド DL::PtrData#[] でアクセスできるようにします。 C 言語における構造体のポインタへのキャストと同じです。
ptr = DL.malloc(DL.sizeof('LL')) ptr.struct!('LL', :tv_sec, :tv_usec) ptr[:tv_sec] = 10 p ptr[:tv_sec] #=> 10
to_a(type) -> [object]
[permalink][rdoc]to_a(type, size) -> [object]
[TODO]
自身が指す領域から type で指定された型の配列を複製して返します。 type は 'S','P','I','L','D' そして 'F' のいずれかです。 size を指定した場合は、自身が指す領域からサイズが size である配列を 複製します。
size が自身のサイズより小さいかを検査しません。
type が定めされた型指定子でない場合、空の配列を返します。
to_i -> Integer
[permalink][rdoc]自身が指すアドレスを整数で返します。
to_s -> String
[permalink][rdoc]to_s(len) -> String
自身が指す領域から長さ len の文字列を複製して返します。
len を省略した場合は、文字列の終りは '\0' であると仮定して、 strlen(3) を使って長さを算出します。
to_str
[permalink][rdoc][TODO]
union!(type, *members) -> nil
[permalink][rdoc][TODO]
共用体のメンバにメソッド DL::PtrData#[] でアクセスできるようにします。 C 言語における共用体のポインタへのキャストと同じです。