[PHP]一些坑
一、如果有一个非数字字符字符串跟0 == 运算时,会返回true
$test = 'error'; var_dump($test == 0);//true
二、只有在对象在zval的refcount值为0时(即已经没有变量(symbol)引用这个zval时),才会触发对象的__destruct()方法,调用unset只会删除变量(symbol),减少对象引用次数
class test1 { public function __destruct() { print "Destroying test1.\n"; } } $a = new test1(); $b = $a; unset($a);//当只unset($a)时,不会触发__destruct() unset($b);//这里才会触发__destruct() echo "now exit.\n";
三、__destruct()方法不会销毁类的静态属性,因为内存中,对象的实例数据和对象静态数据是分离的
class test1 { public static $id = 'test1'; public function foo(){ static::$id .= '_extends'; } public function __destruct() { print "Destroying test1.\n"; } } $a = new test1(); $b = $a; $b->foo(); unset($a);//当只unset($a)时,不会触发__destruct() unset($b);//这里才会触发__destruct() echo test1::$id."\n";//test1::$id不会被销毁 echo "now exit.\n";
四、对象被销毁的同时,它的动态属性也会被自动销毁,并不需要手动去销毁动态属性
class test1 { public function __destruct() { print "Destroying test1.\n"; } } class test2 { public $test1 = NULL; public function __destruct() { print "Destroying test2.\n"; } } $a = new test1(); $b = new test2(); $b->test1 = $a; unset($a);//当只unset($a)时,不会触发__destruct() unset($b);//当b被销毁,意味着b的所有属性值(symbol)也会被销毁,所以b销毁后会触发a被销毁 echo "now exit.\n";
五、单引号所谓的“转义序列将不会被替换”并不包含"\"和"'","\"遇到本身或者单引号时还是会被替换,所以下面的示例中"\\"在脚本被解释后等同于"\",
php函数json_encode接收到的键'b'的值,实际上是'CM00\1'.
<?php $arr = array( 'a' => 'CM00\1', 'b' => 'CM00\\1', ); echo json_encode($arr);
$.ajax({ "url": "./temp_185.php", "dataType": "text", "success": function(data){ console.log(data); //output: {"a":"CM00\\1","b":"CM00\\1"} } });
六、在命名空间路径中,不能包含有php保留字,会导致php解析报语法错误
Parse error: syntax error, unexpected 'protected' (T_PROTECTED), expecting identifier (T_STRING) in /xxx/xxx/xxx
七、在简单的表达式赋值当中,只有object和resource类型是按引用传递的,其他都是按值传递的:
按值传递 | Boolean |
Integer | |
Float | |
String | |
Array | |
按引用传递 | Object |
Resource |
八、只有被强制使用了返回引用操作符&后,xdebug_debug_zval的is_ref字段才会变成1,这跟symbol引用的值是什么类型无关,注意,如果不显式的使用&,即使是给symbol赋了引用类型的值,is_ref字段也会是0。