PHP接口通过interface定义,方法必须为public且无实现,支持类型提示和默认参数;类实现接口需用implements关键字,严格实现所有方法,访问控制为public,参数与返回类型需兼容,支持协变与逆变;PHP类可实现多个接口以组合行为,提升代码解耦与扩展性。

PHP接口中的方法具有特定的规范和使用要求,理解这些特点对构建清晰、可维护的面向对象程序至关重要。接口不是用来实现具体功能的,而是定义类必须遵循的“契约”。下面从定义规范与实现要求两个方面进行解析。
接口方法的定义规范
在PHP中,接口通过interface关键字定义,其中的方法有以下明确规则:
- 所有方法默认为public,不能使用private或protected修饰
- 方法不能包含具体实现(即不能有方法体),只能声明方法名和参数
- 方法可以包含类型提示,包括参数类型和返回类型
- 从PHP 8.0起,接口方法支持默认参数值
interface Payable {
public function pay(float $amount): bool;
public function refund(float $amount, string $reason = ''): bool;
}
接口方法的实现要求
当一个类实现接口时,必须严格遵守接口中定义的方法签名,否则会触发致命错误。
- 实现类必须使用implements关键字引入接口
- 必须实现接口中的所有方法
- 方法的访问控制必须是public,不能更弱
- 参数数量和类型必须一致,支持协变与逆变(PHP 7.4+)
- 返回类型需兼容接口声明,支持返回类型的协变
class CreditCardPayment implements Payable {
public function pay(float $amount): bool {
// 实现支付逻辑
return true;
}
public function refund(float $amount, string $reason = ''): bool {
// 实现退款逻辑
return true;
}
}
接口的多继承与组合使用
PHP不支持类的多重继承,但一个类可以实现多个接口,从而实现行为的组合。
立即学习“PHP免费学习笔记(深入)”;
- 多个接口之间用逗号分隔
- 若多个接口有相同方法,实现类只需实现一次,但必须满足所有接口对该方法的要求
- 可用于构建高内聚、低耦合的系统结构
interface Loggable {
public function log(string $message);
}
class TransactionProcessor implements Payable, Loggable {
public function pay(float $amount): bool { /*...*/ }
public function refund(float $amount, string $reason = ''): bool { /*...*/ }
public function log(string $message) { /*...*/ }
}
基本上就这些。接口的核心价值在于规范行为、解耦依赖,合理使用能显著提升代码的扩展性与测试性。











