PHP Conference Japan 2024

C 代码和数据的核心接口

(PHP 7 >= 7.4.0, PHP 8)

简介

此类的对象由工厂方法 FFI::cdef()FFI::load()FFI::scope() 创建。定义的 C 变量作为 FFI 实例的属性提供,定义的 C 函数作为 FFI 实例的方法提供。声明的 C 类型可用于使用 FFI::new()FFI::type() 创建新的 C 数据结构。

FFI 定义解析和共享库加载可能需要大量时间。在 Web 环境中,在每次 HTTP 请求时执行此操作是没有意义的。但是,可以在 PHP 启动时预加载 FFI 定义和库,并在需要时实例化 FFI 对象。头文件可以使用特殊的 FFI_SCOPE 定义进行扩展(例如 #define FFI_SCOPE "foo";默认范围是“C”),然后在预加载期间由 FFI::load() 加载。这将创建一个持久绑定,所有后续请求都将通过 FFI::scope() 使用它。有关详细信息,请参阅 完整的 PHP/FFI/预加载示例

可以将多个 C 头文件预加载到同一作用域中。

类概要

final class FFI {
/* 常量 */
public const int __BIGGEST_ALIGNMENT__;
/* 方法 */
public static addr(FFI\CData &$ptr): FFI\CData
public static alignof(FFI\CData|FFI\CType &$ptr): int
public static arrayType(FFI\CType $type, array $dimensions): FFI\CType
public static cdef(string $code = "", ?string $lib = null): FFI
public static free(FFI\CData &$ptr): void
public static isNull(FFI\CData &$ptr): bool
public static load(string $filename): ?FFI
public static memcmp(string|FFI\CData &$ptr1, string|FFI\CData &$ptr2, int $size): int
public static memcpy(FFI\CData &$to, FFI\CData|string &$from, int $size): void
public static memset(FFI\CData &$ptr, int $value, int $size): void
public new(FFI\CType|string $type, bool $owned = true, bool $persistent = false): ?FFI\CData
public static scope(string $name): FFI
public static sizeof(FFI\CData|FFI\CType &$ptr): int
public static string(FFI\CData &$ptr, ?int $size = null): string
public type(string $type): ?FFI\CType
public static typeof(FFI\CData &$ptr): FFI\CType
}

预定义常量

FFI::__BIGGEST_ALIGNMENT__

目录

添加笔记

用户贡献笔记

此页面没有用户贡献的笔记。
To Top