• php踩过的那些坑(4) false,NULL,0,''详解


    一、前方有坑

    php开发过程中,难免会遇到这四个值:false,null,0,’',并且也会对这四个值进行比较,然后分别进行业务代码处理。一招不慎,就会踩到坑,影响数据判断的正确性和安全性,以至于造成代码不健壮,给程序的测试和运行造成很多的麻烦。

    看如下代码:

    $a = NULL; $b = ''; $c = 0; $d = false;

    echo ($a == $b)?1:0; // 输出1

    echo ($a === $b)?1:0; // 输出0

    echo ($a == $c)?1:0; // 输出1

    echo ($a === $c)?1:0; // 输出0

    echo ($b == $c)?1:0; // 输出1

    echo ($b === $c)?1:0; // 输出0

    echo ($a == $d)?1:0; // 输出1

    echo ($a === $d)?1:0; // 输出0

    二、防坑策略

    == 会先进行类型转换,再进行对比,而===会先比较类型,如果类型不同直接返回不相等。

    三、为啥有坑

    先了解这四个值的类型:

    $a = NULL; $b = ''; $c = 0; $d = false;

    echo gettype($a); //输出NULL

    echo gettype($b); //输出string

    echo gettype($c); //输出integer

    echo gettype($d); //输出boolean

    原来这四个值的类型是不一样的!所以结合防坑策略就好理解了。

    人生有坑,处处提防

    其实,在PHP中变量是以C语言的结构体来存储的,''、NULL,false都是以值为0存储的,其中这个结构体有个zend_uchartype;这样的成员变量,他是用来保存变量的类型的,并且''的类型是string,NULL的类型是NULL,false是boolean。

    四、防坑提示

    扩展一下对这四个值的理解:

    $a = NULL; $b = ''; $c = 0; $d = false;

    echo isset($a) ? 1:0; //输出0

    echo isset($b) ? 1:0; //输出1

    echo isset($c) ? 1:0; //输出1

    echo isset($d) ? 1:0; //输出1

    echo '<br>';

    echo is_null($a) ? 1:0; //输出1

    echo is_null($b) ? 1:0; //输出0

    echo is_null($c) ? 1:0; //输出0

    echo is_null($d) ? 1:0; //输出0

    echo '<br>';

    echo empty($a) ? 1:0; //输出1

    echo empty($b) ? 1:0; //输出1

    echo empty($c) ? 1:0; //输出1

    echo empty($d) ? 1:0; //输出1

    世界上本没有坑,坑的人多了也就成了坑

  • 相关阅读:
    【转】winrar命令行详解
    【转】关于色彩空间sRGB和Adobe RGB...
    深入解读TPC-C指标
    解决因 RsFX devicer 而无法卸载 SQL Server 的问题
    LUHN算法
    信用卡卡号编排的含义
    关于第三方API调用的工具 WebApiClient.JIT 的使用记录
    ocelot.json模板
    C#进阶之事件与委托(Event&Delegate)
    C#进阶之面向对象(OOP)
  • 原文地址:https://www.cnblogs.com/phpfensi/p/8143363.html
Copyright © 2020-2023  润新知