判断变量是否不为空,函数isset()、!empty()与!is_null()的比较
转载:https://blog.csdn.net/qq_38812954/article/details/79581785
判断变量的值,尤其是判断他们是否不为空,我们有以下4种方法:
- if(isset($test)) true:变量已被赋值/设置
- if(!empty($test)) true:变量不为空
- if(!is_null($test)) true:变量不为空
- if($test) true:以自身为参数,变量不为空
(为方便讨论,empty与is_null均取反值,使4个函数都为true时,变量不为空)
四个函数的区别,先说结论0,例子具体分析看第1部分。
0.总结isset(), !empty(), !is_null(),以自身为参数的区别
- isset()、!empty()会首先检查变量是否存在(存在返回true),然后再对变量值进行检测;
is_null()、以自身为参数,直接检查变量值是否为null,如果变量未定义会出现错误警告。 - isset()、!empty()的输入参数必须是一个变量($变量),因为它们是语言结构,不是函数,无法被变量函数调用(参考阅读:可变函数);
is_null()、以自身为参数,输入参数只要是能够有返回值的就可以(常量、变量、表达式等都可以); - 判断为空的时刻:
- isset():仅当 未定义 或者 值为null 时,返回false;
- !empty():未定义、 NULL、 “”(空字符)、0、“0”、FALSE、array(),均返回false;
- !is_null():直接判断是否不为null,只有为null才返回false;未定义会出现错误警告;
- 以自身为参数:未定义、 NULL、 “”(空字符)、0、“0”、FALSE、array(),均返回false;变量未定义时出现错误警告;
1.例子具体分析
4个函数对输入值为:数值(正常)、“”(空字符串)、array()(空数组)、0、“0”、false、null、值未定义,8种情况分别进行检验。
测试代码如下:
- <?php
- $test=array("数值"=>100,"空字符串\"\""=>"","空数组array()"=>array(),"数值0"=>0,"字符\"0\""=>"0","false"=>false,"null"=>null);
- $i=1;
- /*将前七种情况放在数组里(最后一种是变量未定义),方便后面foreach循环测试*/
- foreach( $test as $key=>$value){
- echo 'try:$test',$i,'=',$key,'<br/>';
- echo 'isset',isset($value)?' 1 define':' 0 undefine','<br/>';
- echo '!empty',!empty($value)?' 1 no empty':' 0 empty','<br/>';
- echo '!is_null',!is_null($value)?' 1 no null':' 0 null','<br/>';
- echo '以自身为参数',$value?' 1 no null':' 0 null','<br/>';
- echo '<br/>';
- ++$i;
- }
- /*4个函数对前七种情况通过foreach循环进行测试输出,返回1为true,0为false。*/
- $key="值未定义";
- unset($value);//使用unset()销毁指定的变量$value;
- echo 'try:$test',$i,'=',$key,'<br/>';
- echo 'isset',isset($value)?' 1 define':' 0 undefine','<br/>';
- echo '!empty',!empty($value)?' 1 no empty':' 0 empty','<br/>';
- echo '!is_null',!is_null($value)?' 1 no null':' 0 null','<br/>';
- echo '以自身为参数',$value?' 1 no null':' 0 null','<br/>';
- echo '<br/>';
- /*对最后一种情况:变量未定义进行测试*/
- ?>
测试结果如下:
try:$test1=数值
isset 1 define
!empty 1 no empty
!is_null 1 no null
以自身为参数 1 no nulltry:$test2=空字符串””
isset 1 define
!empty 0 empty
!is_null 1 no null
以自身为参数 0 nulltry:$test3=空数组array()
isset 1 define
!empty 0 empty
!is_null 1 no null
以自身为参数 0 nulltry:$test4=数值0
isset 1 define
!empty 0 empty
!is_null 1 no null
以自身为参数 0 nulltry:$test5=字符”0”
isset 1 define
!empty 0 empty
!is_null 1 no null
以自身为参数 0 nulltry:$test6=false
isset 1 define
!empty 0 empty
!is_null 1 no null
以自身为参数 0 nulltry:$test7=null
isset 0 undefine
!empty 0 empty
!is_null 0 null
以自身为参数 0 nulltry:$test8=值未定义
isset 0 undefine
!empty 0 empty
!is_null
Notice: Undefined variable: value in D:\xampp\htdocs\test\0105vs_isset_empty_is_null.php on line 22
0 null
以自身为参数
Notice: Undefined variable: value in D:\xampp\htdocs\test\0105vs_isset_empty_is_null.php on line 23
0 null
函数的true/false可用下表进行归纳(”1”表true,”0”表false):
| 函数/$t的值 | 备注 | isset($t) | !empty($t) | !is_null($t) | $t |
|---|---|---|---|---|---|
| 100 | 有值 | 1 | 1 | 1 | 1 |
| “” | 空字符串 | 1 | 0 | 1 | 0 |
| array() | 空数组 | 1 | 0 | 1 | 0 |
| 0 | 数值0 | 1 | 0 | 1 | 0 |
| “0” | 字符0 | 1 | 0 | 1 | 0 |
| false | false | 1 | 0 | 1 | 0 |
| null | null | 0 | 0 | 0 | 0 |
| 这里$t未定义 | 0 | 0 | 0(Notice) | 0(Notice) |
从上表可知:
- 对于值为null和未定义的变量,四种方式都能返回false
- 其中,!is_null()和“以自身为参数”对于未定义的变量还会出现Notice直接报错;
- !empty()和“以自身为参数” 还会对“”、array()、0、“0”、false,均返回false;
- 而isset()和!is_null()只对null和未定义变量做出false判断;
isset()、!empty()的输入参数必须是一个变量
- $test=100;
- echo isset($test),'<br/>';
- echo !empty($test),'<br/>';
- echo !is_null($test),!is_null(100),!is_null($test=100),'<br/>';
只有!is_null(),可以直接写!is_null(100),!is_null($b=100);
而isset()和!empty()这样写会报错,输入参数只能写入一个变量($变量)
- 因为isset()和!empty()是语言结构,is_null()是一个函数;
判断变量是否不为空,函数isset()、!empty()与!is_null()的比较的更多相关文章
- php中函数 isset(), empty(), is_null() 的区别,boolean类型和string类型的false判断
php中函数 isset(), empty(), is_null() 的区别,boolean类型和string类型的false判断 实际需求:把sphinx返回的结果放到ssdb缓存里,要考虑到sph ...
- php中函数 isset(), empty(), is_null() 的区别
NULL:当你在你的脚本中写下这样一行代码 $myvariable; //此处你想定义一个变量,但未赋值.会有Notice: Undefined variable echo $myvariable + ...
- velocity 判断 变量 是否不是空或empty
原先的 #if($mobile) 这种写法是不准确的 ,请换成 "$!{ mobile}"!="" 说明 : #if($mobile) 这种写法 只能 ...
- 常用验证函数isset()/empty()/is_numeric()函数
1) isset()用来检查变量是否设置,若变量存在且值不为NULL时为TRUE: 检查多个变量时变量要全部存在且值不为NULL时为TRUE: 若用函数unset()释放后再用isset()检测时为F ...
- PHP中判断变量为空的几种方法
判断变量为空,在许多场合都会用到,同时自己和许多新手一样也经常会犯一些错误, 所以自己整理了一下PHP中一些常用的.判断变量为空的方法. 1. isset功能:判断变量是否被初始化本函数用来测试变量是 ...
- PHP判断变量是否存在及函数isset() 、empty()与is_null的区别
一.举例说明 A.如何判断一个变量是否定义? <?php // 假设不存在$test 变量 if (isset($test)) { echo '$test 已经set', '<br/> ...
- null、 is_null() 、empty() 、isset() PHP 判断变量是否为空
PHP中,在判断变量是否为空的时候,总会纠结应该选用哪个函数,下面列取常用的多种情况,其中1/3经过我的验证,其它来自网络,验证后使用... 使用 PHP 函数对变量 $x 进行比较 表达式 gett ...
- php isset() empty() 区别, 判断 变量存在与否神器
先看PHP手册: bool empty ( mixed $var ) 判断一个变量是否被认为是空的.当一个变量并不存在,或者它的值等同于FALSE,那么它会被认为不存在.如果变量不存在的话,empty ...
- js判断字符串是否全为空(使用trim函数/正则表达式)
我们需要判断用户输入的是否全是空格,可以使用以下方法: 方法一: 使用trim() /* 使用String.trim()函数,来判断字符串是否全为空*/ function kongge1(test) ...
随机推荐
- 用Nacos做微服务架构里的服务注册与发现中心
转自:https://www.jianshu.com/p/61608ff86344 Nacos 另一个非常重要的特性就是服务注册与发现,说到服务的注册与发现相信大家应该都不陌生,在微服务盛行的今天,服 ...
- php扩展安装方式
目录 扩展安装 php源码编译安装 PEAR.PECL phpize 源码安装 扩展安装 以php安装swoole扩展为例. php源码编译安装 下载源码包并编译安装 $ wget http://cn ...
- QT 创建一个线程播放监控视频
1.创建一个线程类(PlayVideoThread): PlayVideoThread.h头文件 #pragma once #include <QObject> #include &quo ...
- TCP/IP协议图--TCP/IP基础
1. TCP/IP 的具体含义 从字面意义上讲,有人可能会认为 TCP/IP 是指 TCP 和 IP 两种协议.实际生活当中有时也确实就是指这两种协议.然而在很多情况下,它只是利用 IP 进行通信时所 ...
- Django框架下报的版本问题
报错环境 python=3.6.5,django=2.2,PyMySQL=0.9.3 …… django.core.exceptions.ImproperlyConfigured: mysqlclie ...
- X86驱动:恢复SSDT内核钩子
SSDT 中文名称为系统服务描述符表,该表的作用是将Ring3应用层与Ring0内核层,两者的API函数连接起来,起到承上启下的作用,SSDT并不仅仅只包含一个庞大的地址索引表,它还包含着一些其它有用 ...
- SpringCloud使用Consul作为分布式配置中心
版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.net/qq_36027670/article/de ...
- 艾瑞克·弗洛姆 ( Erich Fromm )
艾瑞克·弗洛姆 ( Erich Fromm ) 来源 https://www.zhihu.com/question/22891103 ------------------------------ 作者 ...
- springboot mvc自动配置(目录)
对于长时间基于spring框架做web开发的我们,springmvc几乎成为了开发普通web项目的标配.本系列文章基于快速启动的springboot,将从源码角度一点点了解springboot中mvc ...
- 基于【 bug解决】一 || mysql的ONLY_FULL_GROUP_BY导致的sql语句错误
一.Mysql错误: In aggregated query without GROUP BY, expression #1 of SELECT list contains nonaggregated ...