关键概念
1. 一致的方法命名
// bad - inconsistent naming class usermanager { public function getuser($id) { /* ... */ } public function fetchrole($id) { /* ... */ } public function retrievepermissions($id) { /* ... */ } } // good - consistent naming pattern class usermanager { public function getuser($id) { /* ... */ } public function getrole($id) { /* ... */ } public function getpermissions($id) { /* ... */ } }登录后复制
命名方法时,一致性至关重要。在这个糟糕的例子中,我们使用三个不同的动词(get、fetch、retrieve)来执行类似的操作。这迫使开发人员记住同一类型操作的不同术语。好的示例在所有方法中一致地使用“get”,使 api 更可预测且更容易记住。当开发人员需要访问数据时,他们会直观地知道寻找以“get”开头的方法。
2. 预期回报类型
// bad - unexpected return types class filehandler { public function readfile($path) { if (!file_exists($path)) { return false; // unexpected boolean } return file_get_contents($path); } } // good - consistent return types with exceptions class filehandler { public function readfile($path): string { if (!file_exists($path)) { throw new filenotfoundexception("file not found: {$path}"); } return file_get_contents($path); } }登录后复制
这个糟糕的例子混合了返回类型 - 有时返回字符串(文件内容),有时返回布尔值(false)。这给如何处理返回值带来了不确定性。这个很好的例子通过声明字符串返回类型并使用错误情况的异常来确保类型安全。这与 php 的内置行为相匹配,并使错误处理更加明确和可预测。
3. 可预测的参数顺序
// bad - inconsistent parameter order class orderprocessor { public function createorder($items, $userid, $date) { /* ... */ } public function updateorder($date, $orderid, $items) { /* ... */ } } // good - consistent parameter order class orderprocessor { public function createorder($userid, $items, $date) { /* ... */ } public function updateorder($orderid, $items, $date) { /* ... */ } }登录后复制
相似方法中的参数顺序应该保持一致。糟糕的示例将相似的参数放在不同的位置,使 api 变得混乱。好的示例保持了逻辑顺序:首先是标识符(userid/orderid),然后是主要数据(项目),最后是可选/元数据参数(日期)。这种模式符合 php 框架中的常见约定,并使 api 更加直观。
4. 清晰的方法行为
// bad - ambiguous behavior class cart { public function add($product) { // sometimes creates new item, sometimes updates quantity // unpredictable! } } // good - clear, single responsibility class cart { public function addnewitem($product) { /* ... */ } public function updatequantity($productid, $quantity) { /* ... */ } }登录后复制
方法应该有明确、单一的职责。坏例子的“add”方法不明确 - 它可能会添加一个新项目或更新一个现有项目。这个很好的例子将其分为两个不同的方法,具有明确的名称和目的。这使得代码的行为可预测,并遵循单一职责原则 (srp)。
5. 一致的错误处理
class PaymentProcessor { public function processPayment(float $amount): PaymentResult { try { // Process payment return new PaymentResult(true, 'Payment successful'); } catch (PaymentException $e) { // Always handle errors the same way throw new PaymentFailedException($e->getMessage()); } } }登录后复制
此示例演示了通过异常进行一致的错误处理。当出现问题时,它总是抛出特定的异常类型(paymentfailedexception),而不是返回不同的类型或使用错误代码。这为整个应用程序的错误处理创建了一个可预测的模式。该方法还为成功案例使用专用的 paymentresult 对象,保持类型一致性。
这些实践中的每一种都有助于使代码更易于维护、更易于理解且不易出现错误,因为它的行为方式是开发人员基于 php 开发中的常见模式和约定所期望的方式。
以上就是最小惊讶原则(POLA)的详细内容,更多请关注慧达安全导航其它相关文章!
免责 声明
1、本网站名称:慧达安全导航
2、本站永久网址:https//www.huida178.com/
3、本站所有资源来源于网友投稿和高价购买,所有资源仅对编程人员及源代码爱好者开放下载做参考和研究及学习,本站不提供任何技术服务!
4、本站所有资源的属示图片和信息不代表本站的立场!本站只是储蓄平台及搬运
5、下载者禁止在服务器和虚拟机下进行搭建运营,本站所有资源不支持联网运行!只允许调试,参考和研究!!!!
6、未经原版权作者许可禁止用于任何商业环境,任何人不得擅作它用,下载者不得用于违反国家法律,否则发生的一切法律后果自行承担!
7、为尊重作者版权,请在下载24小时内删除!请购买原版授权作品,支持你喜欢的作者,谢谢!
8.若资源侵犯了您的合法权益,请持 您的版权证书和相关原作品信息来信通知我们!QQ:1247526623我们会及时删除,给您带来的不便,我们深表歉意!
9、如下载链接失效、广告或者压缩包问题请联系站长处理
10、如果你也有好源码或者教程,可以发布到网站,分享有金币奖励和额外收入!
11、本站资源售价只是赞助,收取费用仅维持本站的日常运营所需
12、因源码具有可复制性,一经赞助,不得以任何形式退款。
13、本文内容由网友自发贡献和站长收集,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系1247526623@qq.com
转载请注明出处: 慧达安全导航 » 最小惊讶原则(POLA)
发表评论 取消回复