您尚未登录,请登录后浏览更多内容! 登录 | 立即注册

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 16431|回复: 0
打印 上一主题 下一主题

[php学习资料] 【PHP系列】PHP 7.0新增特性详解

[复制链接]
跳转到指定楼层
楼主
发表于 2018-6-21 22:38:49 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
开始介绍PHP7.0新特性,具体的可以参照官网的介绍,我来挑一些给大家详细讲解下
http://php.net/manual/en/migration70.new-features.php6 _4 W+ p: x& S' Z0 c
1. ?? 运算符(NULL 合并运算符)
8 o) {0 K# q1 g0 l
  1. $a = $_GET['a'] ?? 1;
复制代码
' P* D0 v) m; S, Z: p0 I0 F% O; v9 U
它相当于:
  1. $a = empty($_GET['a']) ? 1 : $_GET['a'];
复制代码

, r/ z5 o: p" w3 D5 K$ G* M7 l
我们知道三元运算符是可以这样用的:
  1. $a ?: 1
复制代码
5 x# w# g  ^/ ^# _) Z) b4 T
但是这是建立在 $a 已经定义了的前提上。新增的 ?? 运算符可以简化判断。简化代码的同时也更直观了!

3 g5 y. M9 X9 o/ M
2. 函数返回值类型声明
官方文档提供的例子(注意 ... 的边长参数语法在 PHP 5.6 以上的版本中才有):

! \5 r2 I/ t) \( U: L6 v+ i
  1. <?php
    ! N6 z  B  A0 {! M
  2. function arraysSum(array ...$arrays): array; X3 _9 W: \0 \: T; t7 p
  3. {
    ! }% ]: t4 g; |5 |
  4.     return array_map(function(array $array): int {
    - r5 i1 u0 D0 q2 \1 _7 n
  5.          return array_sum($array);
    ( }7 F- ~* y! d6 T6 y
  6.     }, $arrays);
    3 @* i0 j4 J: T- f2 i% h/ y$ N3 Q1 E
  7. }
    ; w7 I* E# @- G' {6 ~  D8 s
  8. * n  l( x4 d+ n' u% T
  9. print_r(arraysSum([1,2,3], [4,5,6], [7,8,9]));
复制代码

9 d( X6 f) i' Q, A; |( j- Z7 d- {9 X# I: C0 m; J( b! }0 X
从这个例子中可以看出现在函数(包括匿名函数)都可以指定返回值的类型。
这个特性可以帮助我们避免一些 PHP 的隐式类型转换带来的问题。在定义一个函数之前就想好预期的结果可以避免一些不必要的错误。
不过这里也有一个特点需要注意。PHP 7 增加了一个 declare 指令:strict_types,既使用严格模式。
使用返回值类型声明时,如果没有声明为严格模式,如果返回值不是预期的类型,PHP 还是会对其进行强制类型转换。但是如果是严格模式, 则会出发一个 TypeError 的 Fatal error。
强制模式:
  1. <?phpfunction foo($a) : int
    " B0 ~  ^: J8 q8 d7 e7 b
  2. {+ p, b% V' n$ o. S" ]/ V
  3.     return $a;
    3 K2 A4 i. T+ G& i4 ~
  4. }
    5 x+ {" m* r( B5 ^
  5. 5 V% b- s3 F% c) L" ]' y5 X+ ~# J
  6. foo(1.0);
复制代码

, z. c2 \% D, J7 A' u! s& |9 f0 Y( R2 m$ b" z" o0 ~' f6 \
以上代码可以正常执行,foo 函数返回 int 1,没有任何错误。
严格模式:
  1. <?php* g/ U& G1 H, Q! m" h( @
  2. declare(strict_types=1);
    3 }' ^, X) e  l& S2 j3 [' G

  3. # q1 _& @; r: @6 }
  4. function foo($a) : int- H( y2 ]* e& G7 v+ G
  5. {
    2 w3 A, ]* b' i$ @, O
  6.     return $a;
    2 A$ z2 j& j, O* g3 V% N9 k5 N
  7. }
    ) }" @" Y: M, F7 B% g
  8. 1 n0 e$ }) W- }, z! _
  9. foo(1.0);
复制代码
5 C) Z9 |( L9 U* X3 Q* \$ P! H

7 G2 N4 }& j, U2 f8 D2 X7 ?2 }- E  T
在声明之后,就会触发致命错误。
# PHP Fatal error:  Uncaught TypeError: Return value of foo() must be of the type integer, float returned in test.php:6
2 J8 ], q* M" z3. 标量类型声明
PHP 7 中的函数的形参类型声明可以是标量了。在 PHP 5 中只能是类名、接口、array 或者 callable (PHP 5.4,即可以是函数,包括匿名函数),现在也可以使用 string、int、float和 bool 了。
  1. <?php4 c# k9 q* ^8 _/ R2 S& u
  2. // Coercive mode
    ( _( l# N" X) i: s# T3 K8 m$ ]
  3. function sumOfInts(int ...$ints)
    : y  ]* C3 O7 d8 U8 y( U
  4. {4 T; Q3 i& p6 j% E+ r9 t2 b; R) [
  5.     return array_sum($ints);# x" A" m0 ^. w' }  J
  6. }0 a# H8 s1 t9 Q. F0 P' u
  7. ( b% n+ K& q$ x! `3 \
  8. var_dump(sumOfInts(2, '3', 4.1));
复制代码

- o0 z" Z9 ~( g
! H. ^  @% @1 @. U
需要注意的是上文提到的严格模式的问题在这里同样适用:强制模式(默认,既强制类型转换)下还是会对不符合预期的参数进行强制类型转换,严格模式下则触发 TypeError 的致命错误。
4. use 批量声明
PHP 7 中 use 可以在一句话中声明多个类或函数或 const 了:
  1. <?php8 A" |' z1 }! R$ x0 O: V
  2. use some\namespace\{ClassA, ClassB, ClassC as C};
    3 J& @$ P4 v1 p/ Y
  3. use function some\namespace\{fn_a, fn_b, fn_c};9 i9 u3 z1 @2 W6 ^2 O4 v0 ~# J
  4. use const some\namespace\{ConstA, ConstB, ConstC};
复制代码
; B$ j! _+ F. y0 Y
但还是要写出每个类或函数或 const 的名称(并没有像 python 一样的 from some import * 的方法)。
需要留意的问题是:如果你使用的是基于 composer 和 PSR-4 的框架,这种写法是否能成功的加载类文件?其实是可以的,composer 注册的自动加载方法是在类被调用的时候根据类的命名空间去查找位置,这种写法对其没有影响。
再来简单说几个:
1、PHP 5.3 开始有了匿名函数,现在又有了匿名类了;
2、define 现在可以定义常量数组;
3、闭包( Closure)增加了一个 call 方法;
4、生成器(或者叫迭代器更合适)可以有一个最终返回值(return),也可以通过 yield from 的新语法进入一个另外一个生成器中(生成器委托)。
生成器的两个新特性(return 和 yield from)可以组合。具体的大家可以自行测试。
4 Z; p6 l' h9 {6 \& H  \0 U8 H4 I. J
$ d1 `+ d, J0 F1 m0 e1 D7 C$ T
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2026-4-30 19:05 , Processed in 0.067792 second(s), 22 queries .

Copyright © 2001-2026 Powered by cncml! X3.2. Theme By cncml!