问个PHP代码规范的问题
PHPz
PHPz 2017-04-11 10:40:35
[PHP讨论组]

首先,有个函数是这么写的。

function  exam(){
    //从数据库获取数据。
    $records = $aModel->where(['type' => 1])->get();
    
    if(empty($records))  return false;
    
    $newRecord = $bModel->map();
    foreach($records as $item){
        $newRecord->name = $item->name;
        $newRecord->age = $item->age;
        try{
            $bModel->insert($newRecord);
        }
        catch(\Exception $e){
            \Log::catch($e);
        }
    }
    return true;
}

然后,这个函数是这么调用的。

if(true !== exam()){
    echo "表更新失败";
    return false;
}

请各位经验丰富的phper看下,这其中有几个地方看着挺别扭的:

  1. 函数exam()中,return 的位置是否合适。

  2. 假如遇到函数中返回类型不确定,执行完成返回结果,执行失败返回false这种情况下,调用的时候是否适合对结果进行类似 if(false === exam()) 的判断。

  3. 感觉在if判断中执行函数,会使得代码的可读性降低,不知是否存在这样的问题。

PHPz
PHPz

学习是最好的投资!

全部回复(2)
ringa_lee

1.函数exam()中,return 的位置是否合适。

有点疑惑,exam函数返回值就是false 和 true,为什么不直接return exam()
然后你这样的写法可以简化成 if(!eaxm()){return false}

2.假如遇到函数中返回类型不确定,执行完成返回结果,执行失败返回false这种情况下,调用的时候是否适合对结果进行类似 if(false === exam()) 的判断。

适合

3.感觉在if判断中执行函数,会使得代码的可读性降低,不知是否存在这样的问题。

不会
大家讲道理

你的try..catch()...不写return false,
意思是插入失败也会返回true

try{
    $bModel->insert($newRecord);
}
catch(\Exception $e){
    \Log::catch($e);
    return false;  # 没有这个, 插入错误并不回返回false
}
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号