PHP7 新特性详细介绍

 2025-01-16  阅读 268  评论 8  点赞 371

摘要:php 的学习新特性 最近做的项目使用了 php7,但感觉有很多新特性没有用起来。就想总结一下,一些可能会用到的新特性。之前使用的环境是 php5.4,所有也会有 php5.5 和 php5.6 的特性总结进来,这里只列出我觉得在项目中可能用到的特性,主要内容来自 php手册的附录。 generat

php 的学习新特性

PHP7 新特性详细介绍

最近做的项目使用了 php7,但感觉有很多新特性没有用起来。就想总结一下,一些可能会用到的新特性。之前使用的环境是 php5.4,所有也会有 php5.5 和 php5.6 的特性总结进来,这里只列出我觉得在项目中可能用到的特性,主要内容来自 php手册的附录。

generators (php 5 >= 5.5.0, php 7)

通过添加 yield 关键字支持了 generators,generators 提供了一个更简单的方法实现迭代器,不需要实现 iterator 接口。

<?php function xrange($start, $limit, $step = 1) { for ($i = $start; $i <= $limit; $i += $step) { yield $i; } } echo 'single digit odd numbers: '; /* 注意保存在内存中的数组绝不会被创建或返回 */ foreach (xrange(1, 9, 2) as $number) { echo "$number "; }

以上例程会输出:

single digit odd numbers: 1 3 5 7 9

详情点击生成器

新增 finally 关键字 (php 5 >= 5.5.0, php 7)

try-catch 现在支持 finally

foreach 现在支持 list() (php 5 >= 5.5.0, php 7)

foreach 控制结构现在支持通过 list() 构造将嵌套数组分离到单独的变量。例如:

<?php $array = [ [1, 2], [3, 4], ]; foreach ($array as list($a, $b)) { echo "a: $a; b: $b\n"; } ?>

以上例程会输出:

a: 1; b: 2
a: 3; b: 4

array_column (php 5 >= 5.5.0, php 7)

array_column — 返回数组中指定的一列

使用表达式定义常量 (php 5 >= 5.6.0, php 7)

在之前的 php 版本中, 必须使用静态值来定义常量,声明属性以及指定函数参数默认值。 现在你可以使用包括数值、字符串字面量以及其他常量在内的数值表达式来 定义常量、声明属性以及设置函数参数默认值。

<?php const one = 1; const two = one * 2; class c { const three = two + 1; const one_third = one / self::three; const sentence = 'the value of three is '.self::three; public function f($a = one + self::three) { return $a; } } echo (new c)->f()."\n"; echo c::sentence; ?>

以上例程会输出:

4

the value of three is 3

现在可以通过 const 关键字来定义类型为 array 的常量。

<?php const arr = ['a', 'b']; echo arr[0]; ?>

以上例程会输出:

a

使用 ... 运算符定义变长参数函数 (php 5 >= 5.6.0, php 7)

现在可以不依赖 func_get_args(), 使用 ... 运算符 来实现 变长参数函数。

<?php function f($req, $opt = null, ...$params) { // $params 是一个包含了剩余参数的数组 printf('$req: %d; $opt: %d; number of params: %d'."\n", $req, $opt, count($params)); } f(1); f(1, 2); f(1, 2, 3); f(1, 2, 3, 4); f(1, 2, 3, 4, 5); ?>

以上例程会输出:

$req: 1; $opt: 0; number of params: 0
$req: 1; $opt: 2; number of params: 0
$req: 1; $opt: 2; number of params: 1
$req: 1; $opt: 2; number of params: 2
$req: 1; $opt: 2; number of params: 3

使用 ... 运算符进行参数展开 (php 5 >= 5.6.0, php 7)

在调用函数的时候,使用 ... 运算符, 将 数组 和 可遍历 对象展开为函数参数。 在其他编程语言,比如 ruby中,这被称为连接运算符,。

<?php function add($a, $b, $c) { return $a + $b + $c; } $operators = [2, 3]; echo add(1, ...$operators); ?>

以上例程会输出:

6

use function 以及 use const (php 5 >= 5.6.0, php 7)

use 运算符 被进行了扩展以支持在类中导入外部的函数和常量。 对应的结构为 use function 和 use const。

<?php namespace name\space { const foo = 42; function f() { echo __function__."\n"; } } namespace { use const name\space\foo; use function name\space\f; echo foo."\n"; f(); } ?>

以上例程会输出:

42

name\space\f

__debuginfo() (php 5 >= 5.6.0, php 7)

加入 __debuginfo(), 当使用 var_dump() 输出对象的时候, 可以用来控制要输出的属性和值。

<?php class c { private $prop; public function __construct($val) { $this->prop = $val; } public function __debuginfo() { return [ 'propsquared' => $this->prop ** 2, ]; } } var_dump(new c(42)); ?>

以上例程会输出:

object(c)#1 (1) { ["propsquared"]=> int(1764) }

标量类型声明 (php 7)

标量类型声明 有两种模式: 强制 (默认) 和 严格模式。 现在可以使用下列类型参数(无论用强制模式还是严格模式): 字符串(string), 整数 (int), 浮点数 (float), 以及布尔值 (bool)。它们扩充了php5中引入的其他类型:类名,接口,数组和 回调类型。

<?php // coercive mode function sumofints(int ...$ints) { return array_sum($ints); } var_dump(sumofints(2, '3', 4.1));

以上例程会输出:

int(9)

要使用严格模式,一个 declare 声明指令必须放在文件的顶部。这意味着严格声明标量是基于文件可配的。 这个指令不仅影响参数的类型声明,也影响到函数的返回值声明(参见返回值类型声明, 内置的php函数以及扩展中加载的php函数)

返回值类型声明 (php 7)

php 7 增加了对返回类型声明的支持。 类似于参数类型声明,返回类型声明指明了函数返回值的类型。可用的类型与参数声明中可用的类型相同。

<?php function arrayssum(array ...$arrays): array { return array_map(function(array $array): int { return array_sum($array); }, $arrays); } print_r(arrayssum([1,2,3], [4,5,6], [7,8,9]));

以上例程会输出:

array
(
    [0] => 6
    [1] => 15
    [2] => 24
)

null合并运算符 (php 7)

由于日常使用中存在大量同时使用三元表达式和 isset()的情况, 我们添加了null合并运算符 (??) 这个语法糖。如果变量存在且值不为null, 它就会返回自身的值,否则返回它的第二个操作数。

<?php // fetches the value of $_get['user'] and returns 'nobody' // if it does not exist. $username = $_get['user'] ?? 'nobody'; // this is equivalent to: $username = isset($_get['user']) ? $_get['user'] : 'nobody'; // coalesces can be chained: this will return the first // defined value out of $_get['user'], $_post['user'], and // 'nobody'. $username = $_get['user'] ?? $_post['user'] ?? 'nobody'; ?>

太空船操作符(组合比较符)(php 7)

太空船操作符用于比较两个表达式。当$a小于、等于或大于$b时它分别返回-1、0或1。 比较的原则是沿用 php 的常规比较规则进行的。

<?php // integers echo 1 <=> 1; // 0 echo 1 <=> 2; // -1 echo 2 <=> 1; // 1 // floats echo 1.5 <=> 1.5; // 0 echo 1.5 <=> 2.5; // -1 echo 2.5 <=> 1.5; // 1 // strings echo "a" <=> "a"; // 0 echo "a" <=> "b"; // -1 echo "b" <=> "a"; // 1 ?>

通过 define() 定义常量数组 (php 7)

array 类型的常量现在可以通过 define() 来定义。在 php5.6 中仅能通过 const 定义。

<?php define('animals', [ 'dog', 'cat', 'bird' ]); echo animals[1]; // outputs "cat" ?>

匿名类 (php 7)

现在支持通过new class 来实例化一个匿名类,这可以用来替代一些“用后即焚”的完整类定义。

<?php interface logger { public function log(string $msg); } class application { private $logger; public function getlogger(): logger { return $this->logger; } public function setlogger(logger $logger) { $this->logger = $logger; } } $app = new application; $app->setlogger(new class implements logger { public function log(string $msg) { echo $msg; } }); var_dump($app->getlogger()); ?>

以上例程会输出:

object(class@anonymous)#2 (0) {
}

closure::call() (php 7)

closure::call() 现在有着更好的性能,简短干练的暂时绑定一个方法到对象上闭包并调用它。

<?php class a {private $x = 1;} // pre php 7 code $getxcb = function() {return $this->x;}; $getx = $getxcb->bindto(new a, 'a'); // intermediate closure echo $getx(); // php 7+ code $getx = function() {return $this->x;}; echo $getx->call(new a);

以上例程会输出:

1
1

为unserialize()提供过滤 (php 7)

这个特性旨在提供更安全的方式解包不可靠的数据。它通过白名单的方式来防止潜在的代码注入。

<?php // converts all objects into __php_incomplete_class object $data = unserialize($foo, ["allowed_classes" => false]); // converts all objects into __php_incomplete_class object except those of myclass and myclass2 $data = unserialize($foo, ["allowed_classes" => ["myclass", "myclass2"]); // default behaviour (same as omitting the second argument) that accepts all classes $data = unserialize($foo, ["allowed_classes" => true]);

group use declarations (php 7)

从同一 namespace 导入的类、函数和常量现在可以通过单个 use 语句 一次性导入了。

<?php // pre php 7 code 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; // php 7+ code 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}; ?>

先总结这些,内容都是来自php的文档,之后有用到这里略过的新特性也会补充过来~~

以上就是对php 新特性的资料整理,后续继续补充相关资料,谢谢大家对本站的支持!



标签:phpphp教程

评论列表:

  •   henbucuo
     发布于 3天前回复该评论
  • 写的很不错,学到了!
  •   henbucuo
     发布于 2天前回复该评论
  • 写的很不错,学到了!
显示更多评论

发表评论:

管理员

承接各种程序开发,外贸网站代运营,外贸网站建设等项目
  • 内容2460
  • 积分67666
  • 金币86666

Copyright © 2024 LS'Blog-保定PHP程序员老宋个人博客 Inc. 保留所有权利。 Powered by LS'blog 3.0.3

页面耗时0.0274秒, 内存占用1.96 MB, 访问数据库29次

冀ICP备19034377号