zoukankan      html  css  js  c++  java
  • php中0,空,null和false之间区别

    $a =  0; 
    $b="0"; 
    $c= ''; 
    $d= null; 
    $e = false;
    
    echo "5个变量-原始测试类型";
        var_dump($a);//int 0
        var_dump($b);//string '0'
        var_dump($c);//string ''
        var_dump($d);//null
        var_dump($e);//boolean false
    
    echo "<h4>empty测试</h4>";
        var_dump(empty($a));//true
        var_dump(empty($b));//true
        var_dump(empty($c));//true
        var_dump(empty($d));//true
        var_dump(empty($e));//true

    echo "<hr>"; var_dump(isset($a));//true var_dump(isset($b));//true var_dump(isset($c));//true var_dump(isset($d));//【false】 见结论一 var_dump(isset($e));//true

    echo "<h4>(==)双等式测试</h4>"; var_dump($a == $b);//true var_dump($a == $c);//true var_dump($a == $d);//true var_dump($a == $e);//true !! var_dump($b == $c);//【false】见结论二 var_dump($b == $d);//【false】见结论二 var_dump($b == $e);//true var_dump($c == $d);//true var_dump($c == $e);//true echo "<h4>(===)三等式测试</h4>"; var_dump($a === $b);//false var_dump($a === $c);//false var_dump($a === $d);//false var_dump($a === $e);//false var_dump($b === $c);//false var_dump($b === $d);//false var_dump($b === $e);//false
    var_dump($c === $d);//false var_dump($c === $e);//false

    总结:

    对于 【0 ;'0' '' ;null false】五种类型

    empty操作以上五个变量,都返回false

    强等于(===)比较 都为false,同强语言结果(三个等号比较不但要比较值,而且要比较类型)

    但对于(==)比较,需要注意string类型,涉及到底层结构与类型转换

    结论一:关于变量类型的理解

    1.null为不存在之意:php底层的zval空间里(结构见下方)没有存其value值,只存储了一个type标志其 IS_NULL(所以解释了 empty(null)=true,isset(null)=false ,isset('')=true)

    2.【; '0' ; '' ; false 】:这四个为存在,php底层是开辟zval空间存储,有value,有type

    结论二:

    1、string '0'与 string '' 不相等,(想一下就明白,同类型比较【1个长度】的字符串怎么可能 等于 【0个长度】 的字符串)

    2、int 0 却和 string '' 空相等,(非同类形比较,php会做类型转换)

    3、string '0' 与 null 不相等,int 0 与 null 相等

  • 相关阅读:
    Django的路由寻址
    Guava Cache 原理分析与最佳实践
    「必知必会」最细致的 ArrayList 原理分析
    「必知必会」最细致的 LinkedList 原理分析
    oracle listagg() 函数
    .net HttpClient 向 WebApi Post 的方法
    MySql 如何让表名支持大小写
    Java的基本数据类型
    CF666E
    spring使用mybatis执行SQL脚本,创建和初始化数据库
  • 原文地址:https://www.cnblogs.com/sgm4231/p/9780121.html
Copyright © 2011-2022 走看看