るりまサーチ

最速Rubyリファレンスマニュアル検索!
33件ヒット [1-33件を表示] (0.114秒)
トップページ > クエリ:i[x] > クエリ:-[x] > クエリ:SIZEOF_INT[x]

別のキーワード

  1. _builtin -
  2. open-uri open
  3. irb/input-method gets
  4. irb/input-method new
  5. matrix -

ライブラリ

モジュール

キーワード

検索結果

Fiddle::SIZEOF_INT -> Integer (24301.0)

Cでの sizeof(int) の値

...Cでの sizeof(int) の値...

Fiddle::SIZEOF_INTPTR_T -> Integer (12300.0)

Cでの sizeof(intptr_t) の値

...Cでの sizeof(intptr_t) の値...

Fiddle::Importer#bind(signature, *opts) { ... } -> Fiddle::Function (6260.0)

Ruby のブロックを C の関数で wrap し、その関数をモジュールに インポートします。

...関数として定義されます。
また、Fiddle::Importer#[] で Fiddle::Function オブジェクトとして
取り出すことができます。

signature で関数の名前とシネグチャを指定します。例えば
"int compare(void*, void*)" のように指定します。

opts に...
...
require 'fiddle/import'

module M
extend Fiddle::Importer
dlload "libc.so.6"
typealias "size_t", "unsigned long"
extern "int qsort(void*, size_t, size_t, void*)"

bind("int compare(void*, void*)"){|px, py|
x = px.to_s(Fiddle::SIZEOF_INT).unpack("i!")
y...
...= py.to_s(Fiddle::SIZEOF_INT).unpack("i!")

x <=> y
}
end

data = [32, 180001, -13, -1, 0, 49].pack("i!*")
M.qsort(Fiddle::Pointer[data], 6, Fiddle::SIZEOF_INT, M["compare"])
p data.unpack("i!*") # => [-13, -1, 0, 32, 49, 180001]...