??语法: 假如变量存正在且值没有为NULL,它就会前往本身的值,不然前往它的第二个操作数.
//php7之前 if判别 if(empty($_GET['param'])) { $param = 1; }else{ $param = $_GET['param']; } //php7之前 三元运算符 $param = empty($_GET['param']) ? 1 : $_GET['param']; //PHP7 null兼并运算符 $param = $_GET['param'] ?? 1;//1
2. define() 界说常量数组
//php7之前 define("CONTENT", "hello world"); echo CONTENT;//hello world //PHP7 define('ANIMALS', [ 'dog', 'cat', 'bird' ]); echo ANIMALS[2];//bird //PHP7 类外也可以使用const来界说常量 const CONSTANT = 'Hello World'; echo CONSTANT;//Hello World
3. 组合比拟符(<=>)
组合比拟符用于比拟两个表白式.当$a小于、等于或年夜于$b时它辨别前往-一、0或1. 比拟的准则是相沿PHP的惯例比拟规定进行的.
/整数 echo 1 <=> 1; // 0 echo 1 <=> 2; // -1 echo 2 <=> 1; // 1 //浮点数 echo 1.5 <=> 1.5; // 0 echo 1.5 <=> 2.5; // -1 echo 2.5 <=> 1.5; // 1 //字符串 echo "a" <=> "a"; // 0 echo "a" <=> "b"; // -1 echo "b" <=> "a"; // 1
4. 变量类型申明
两种模式: 强迫(默许)以及严格模式. 能够应用下列类型参数: string,int,float,bool
//... 操作符: 示意这是一个可变参数. php5.6及以上的版本可以使用: 函数界说的时分变量前应用. function intSum(int ...$ints){ return array_sum($ints); } var_dump(intSum(2,'3.5'));//5 //严格模式 //模式申明:declare(strict_types=1); 默许状况值为0,值为1代表为严格校验的模式 declare(strict_types=1); function add(int $a,int $b){ return $a+$b; } var_dump(add(2,'3.5')); //Fatal error: Uncaught TypeError: Argument 2 passed to add() must be of the type integer
5. 前往值类型申明
添加前往类型申明的支持.相似于参数类型申明.(用法正在函数界说的前面加 :类型名)
//无效的前往类型 declare(strict_types = 1); function getInt(int $value): int { return $value; } print(getInt(6));//6
//有效前往类型 declare(strict_types = 1); function getNoInt(int $value): int { return $value+'2.5'; } print(getNoInt(6));//Fatal error: Uncaught TypeError: Return value of getNoInt() must be of the type integer
6. 匿名类
容许new class {} 创立一个匿名的工具.
<?php //php7之前 接话柄现 interface User{ public function getDiscount(); } class VipUser implements User{ //扣头系数 private $discount = 0.6; public function getDiscount() { return $this->discount; } } class Goods{ private $price = 200; private $objectVipUser; //User接口VipUser类完成 public function getUserData($User){ $this->objectVipUser = $User; $discount = $this->objectVipUser->getDiscount(); echo "商品价钱:".$this->price*$discount; } } $display = new Goods(); //惯例实例化接话柄现工具 $display ->getUserData(new VipUser);//商品价钱:120
<?php //php7 创立一个匿名的工具 interface User{ public function getDiscount(); } class Goods{ private $price = 200; private $objectVipUser; public function getUserData($User){ $this->objectVipUser = $User; $discount = $this->objectVipUser->getDiscount(); echo "商品价钱:".$this->price*$discount; } } $display = new Goods(); //new匿名工具完成user接口 $display ->getUserData(new class implements User{ private $discount = 0.6; public function getDiscount() { return $this->discount; } });//商品价钱:120
7. Closure::call()
Closure::call() 办法被增加为一个冗长的形式降临时绑定一个工具作用域到一个闭包并挪用它. 与PHP5的bindTo相比.它的功能要快患上多.
<?php //php7之前 class A { private $attribute = 'hello world'; } $getClosure = function(){ return $this->attribute; }; $getAttribute = $getClosure->bindTo(new A, 'A');//两头层闭包 echo $getAttribute();//hello world
<?php //PHP7 class A { private $attribute = 'hello world'; } $getClosure = function(){ return $this->attribute; }; echo $getClosure->call(new A);//hello world
8. unserialize()
unserialize()函数:过滤的特点,能够避免合法数据进行代码注入,提供了更平安的反序列化数据
<?php class A{ public $name = 'admin_a'; } class B{ public $name = 'admin_b'; } $objA = new A(); $objB = new B(); $serializedObjA = serialize($objA); $serializedObjB = serialize($objB); //默许行为是接纳一切类; 第二个参数能够疏忽 $dataA = unserialize($serializedObjA , ["allowed_classes" => true]); var_dump($dataA);//object(A)#3 (1) { ["name"]=> string(7) "admin_a" } //假如allowed_classes设置为false,unserialize会将一切工具转换为__PHP_Incomplete_Class工具 $dataA = unserialize($serializedObjA , ["allowed_classes" => false]); var_dump($dataA);//object(__PHP_Incomplete_Class)#4 (2) { ["__PHP_Incomplete_Class_Name"]=> string(1) "A" ["name"]=> string(7) "admin_a" } //转换一切工具到 __PHP_Incomplete_Class工具,除了了工具"B" $dataB = unserialize($serializedObjB , ["allowed_classes" => ["B"]]); var_dump($dataB);//object(B)#3 (1) { ["name"]=> string(7) "admin_b" }
9. IntlChar
IntlChar:提供了一些可用于拜访Unicode字符信息的适用办法的拜访. 留意:必需装置Intl扩大能力应用!
var_dump(IntlChar::CODEPOINT_MAX);//int(1114111) echo '<br>'; var_dump(IntlChar::charName('+'));//string(9) "PLUS SIGN" echo '<br>'; var_dump(IntlChar::ispunct('?'));//bool(true)
10. CSPRNG
CSPRNG 函数提供一种简略的机制来天生明码的随机数.
random_bytes() -加密生活被维护的伪随机字符串.
random_int() -加密生活被维护的伪随机整数.
$bytes = random_bytes(8); echo(bin2hex($bytes));//随机2073a110a2e3c497 echo '<br>'; echo(random_int(1, 999));//随机786 echo '<br>'; print(random_int(-999, -1));//随机-357
11. use 语句
能够应用单个use语句从相反的定名空间导入类,函数以及常量,而没有是应用多个use语句.
//PHP7以前 use some\namespace\ClassA; use some\namespace\ClassB; use some\namespace\ClassC as C; use function some\namespace\fn_a; use function some\namespace\fn_b; use function some\namespace\fn_c; use const some\namespace\ConstA; use const some\namespace\ConstB; use const some\namespace\ConstC; // PHP7之后 use some\namespace\{ClassA, ClassB, ClassC as C}; use function some\namespace\{fn_a, fn_b, fn_c}; use const some\namespace\{ConstA, ConstB, ConstC};
12. intp
新添加intp()函数,接纳两个参数,前往值为第一个参数除了于第二个参数的值并取整.
echo intp(8,4);//2 echo intp(10,4);//2 echo intp(5,10);//0
13. PHP7 谬误解决
PHP7 扭转了年夜少数谬误的陈诉形式.没有同于PHP5的传统谬误陈诉机制,如今年夜少数谬误被作为Error异样抛出.
这类Error异样能够像一般异样同样被try / catch块所捕捉. 假如不婚配的try / catch块,则挪用异样解决函数(由 set_exception_handler() 注册)进行解决. 假如还没有注册异样解决函数,则依照传统形式解决:被陈诉为一个致命谬误(Fatal Error).
Error类并非从Exception类扩大进去的,以是用catch (Exception $e) { ... } 这样的代码是捕捉没有到Error的.你能够用 catch (Error $e) { ... } 这样的代码, 或许经过注册异样解决函数( set_exception_handler())来捕捉Error.
<?php //php7之前 自界说异样解决 class getException extends Exception{ public function errorMsg(){ return '谬误的信息'.$this->getMessage().'<br>谬误的代码'.$this->getCode(); } } try { $num =10; if($num > 1) { throw new getException($num,404); } } catch (getException $e) { echo $e->errorMsg(); }
<?php //php7 异样解决 try { test(); }catch(Error $e) { echo $e->getMessage();//Call to undefined function test() }
相干保举:《PHP教程》
以上就是php7新特点的了解以及比拟的具体内容,更多请存眷资源魔其它相干文章!
标签: php7开发教程 php7开发资料 php7开发自学 php7新特性
抱歉,评论功能暂时关闭!