首頁  >  文章  >  後端開發  >  詳細介紹PHP7 新特性

詳細介紹PHP7 新特性

怪我咯
怪我咯原創
2017-07-05 10:28:341174瀏覽

本文主要介紹PHP7 新功能的資料,這裡整理了詳細的資料及簡單實作程式碼幫助大家學習參考新功能的知識,有興趣的朋友可以參考下

PHP 的學習新特性

最近做的專案使用了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 &#39;Single digit odd numbers: &#39;;

/* 注意保存在内存中的数组绝不会被创建或返回 */
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 = &#39;The value of THREE is &#39;.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 = [&#39;a&#39;, &#39;b&#39;];

echo ARR[0];
?>

以上例程會輸出:

a


#使用... 運算子定義變長參數函數(PHP 5 >= 5.6. 0, PHP 7)

現在可以不依賴func_get_args(), 使用... 運算子來實作變長參數函數。

<?php
function f($req, $opt = null, ...$params) {
 // $params 是一个包含了剩余参数的数组
 printf(&#39;$req: %d; $opt: %d; number of params: %d&#39;."\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 [
   &#39;propSquared&#39; => $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, &#39;3&#39;, 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[&#39;user&#39;] and returns &#39;nobody&#39;
// if it does not exist.
$username = $_GET[&#39;user&#39;] ?? &#39;nobody&#39;;
// This is equivalent to:
$username = isset($_GET[&#39;user&#39;]) ? $_GET[&#39;user&#39;] : &#39;nobody&#39;;

// Coalesces can be chained: this will return the first
// defined value out of $_GET[&#39;user&#39;], $_POST[&#39;user&#39;], and
// &#39;nobody&#39;.
$username = $_GET[&#39;user&#39;] ?? $_POST[&#39;user&#39;] ?? &#39;nobody&#39;;
?>

太空船操作符(组合比较符)(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(&#39;ANIMALS&#39;, [
 &#39;dog&#39;,
 &#39;cat&#39;,
 &#39;bird&#39;
]);

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, &#39;A&#39;); // 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};
?>

以上是詳細介紹PHP7 新特性的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn