搜索
thinkphp中$this->reset && session($key, null); 这种写法是什么意思?
巴扎黑
巴扎黑 2017-04-10 16:33:13
[PHP讨论组]
public function check($code, $id = '') {
        $key = $this->authcode($this->seKey).$id;
        // 验证码不能为空
        $secode = session($key);
        if(empty($code) || empty($secode)) {
            return false;
        }
        // session 过期
        if(NOW_TIME - $secode['verify_time'] > $this->expire) {
            session($key, null);
            return false;
        }

        if($this->authcode(strtoupper($code)) == $secode['verify_code']) {
            $this->reset && session($key, null);//这个地方为什么用&&,而不是三元运算符?
            return true;
        }

        return false;
    }

我的理解是应该写成这样:

$this->reset ? session($key, null):1;
巴扎黑
巴扎黑

全部回复(5)
天蓬老师

根据&&的执行规则,如果左边返回true,则执行右边操作,否则不执行右边的操作。这样写既不会是二楼说的不规范,也不会是一楼说的用if代码太多。

高洛峰

其实就是一个蹩脚的写法,虽然执行结果和三元运算符一样,没一点好处
可读性太差。

不赞同楼下的写法,既然有三元运算符,为什么还要用if?
一行代码可以搞定的问题,为什么要用3行?

阿神

你可以看做三元运算法理解,但是即使你看成三元的,也是一种不规范的写法。

其合理的写法应该是

if ($this->reset) {
    session($key, null);
}
黄舟

赞同 @zj飞得更高 同学的答案。

不过实际上,推荐用andor操作符,他们的优先级更低,更适合进行语句的链接。

更主要的是可读性不低啊,and是“就做...”,or是“否则做...”

ringa_lee

一般称作短路运算
用于替代简化内容体只有一句的if语句.

不认为这是一种不规范的写法,存在即合理,这个运算符的用法就是这样的,只不过大多数用在条件判断里而已

记得在哪里看到过这种写法的效率是高于if的,没实测过,虽然这种性能效率可忽略
有些时候if嵌套的很多,但里面的内容却只有一句,用这个或者三目运算可读性反而会好点

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

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