标量类型声明有两种模式:
1、强制模式
2、严格模式
declare(strict_types=1);
代码中通过指定 strict_types的值(1或者0),1表示严格类型校验模式,作用于函数调用和返回语句;0表示弱类型校验模式。
下面通过两个例子来看看:
1、非严格
function sum(int ...$int){
return array_sum($int);
}
print(sum(2,'1',2.1));
上面程序会输出:5。
2、严格
declare(strict_types=1);
function sum(int ...$int){
return array_sum($int);
}
print(sum(2,'1',2.1));
当执行上面的程序时,会出现参数不是整数的错误:
Fatal error: Uncaught TypeError: Argument 2 passed to sum() must be of the type int, string given, called in …
因为是严格模式,会验证参数的类型。
PHP 7 中可以声明函数返回值的类型,声明的类型有:
int
float
bool
string
interfaces
array
callable
话不多说,举个例子吧。
declare(strict_types=1);
function getStr(): string
{
return 'wwww';
}
echo getStr();
这段程序会输出:www。
declare(strict_types=1);
function getStr(): string
{
return 1;
}
echo getStr();
因为在严格模式下,所以上面这段代码会报错:
Fatal error: Uncaught TypeError: Return value of getStr() must be of the type string, int returned in …
我们之前判断一个变量存在且值不为空时,会这样写:
$name = isset($_GET['anme']) ? $_GET['anme'] : 'csdn';
现在我们可以这样写:
$name = $_GET['name'] ?? 'csdn';
下面我们通过一个例子来证实下。
$name = isset($_GET['anme']) ? $_GET['anme'] : 'csdn';
echo $name;
echo PHP_EOL;
$name = $_GET['name'] ?? 'csdn';
echo $name;
上面代码输出结果:
csdn
csdn
可以看出效果时一样的。
PHP7 中的组合比较符,是比较两个表达式 $a和 $b,如果 $a 小于、等于或大于 $b,则返回-1、0和1。具体的看看下面的例子:
$a = 1;
$b = 2;
print_r($a<=>$b); // 输出:-1
$a = 1;
$b = 1;
print_r($a<=>$b); // 输出:0
$a = 1;
$b = 0;
print_r($a<=>$b); // 输出:1
浮点型、字符串的比较其结果也是一样的。
在 PHP 5.6 中仅能通过 const 定义常量数组,PHP 7 可以通过 define() 来定义。
实例
difine(config,['host','name','password']);
print_r(config[2]);// 输出:password
php7 中可以定义类似匿名函数的匿名类 new class,这样我们可以定义一些用完就销毁的类,无需重新定义一个类。
实例
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;
// 使用 new class 创建匿名类
$app->setLogger(new class implements Logger {
public function log(string $msg) {
print($msg);
}
});
$app->getLogger()->log("我的第一条日志");
以上程序输出结果:我的第一条日志
PHP 7 的 Closure::call() 有着更好的性能,将一个闭包函数动态绑定到一个新的对象实例并调用执行该函数。
也就是这个类可以调用一个匿名函数,而这个匿名函数在类中是没有定义的,从而实现到我们想要的效果。
实例
class A {
private $x = 1;
}
// PHP 7 之前版本定义闭包函数代码
$getXCB = function() {
return $this->x;
};
// 闭包函数绑定到类 A 上
$getX = $getXCB->bindTo(new A, 'A');
echo $getX();
print(PHP_EOL);
// PHP 7+ 代码
$getX = function() {
return $this->x;
};
echo $getX->call(new A);
上面程序输出的结果为:
1
1
PHP 7 增加了可以为 unserialize() 提供过滤的特性,可以防止非法数据进行代码注入,提供了更安全的反序列化数据。
实例
class MyClass1 {
public $obj1prop;
}
class MyClass2 {
public $obj2prop;
}
$obj1 = new MyClass1();
$obj1->obj1prop = 1;
$obj2 = new MyClass2();
$obj2->obj2prop = 2;
$serializedObj1 = serialize($obj1);
$serializedObj2 = serialize($obj2);
// 默认行为是接收所有类
// 第二个参数可以忽略
// 如果 allowed_classes 设置为 false, unserialize 会将所有对象转换为 __PHP_Incomplete_Class 对象
$data = unserialize($serializedObj1 , ["allowed_classes" => true]);
// 转换所有对象到 __PHP_Incomplete_Class 对象,除了 MyClass1 和 MyClass2
$data2 = unserialize($serializedObj2 , ["allowed_classes" => ["MyClass1", "MyClass2"]]);
print($data->obj1prop);
print(PHP_EOL);
print($data2->obj2prop);
上面程序输出的结果为:
1
2
PHP 7 通过 intl 扩展来支持国际化 (i18n) 和本地化 (l10n) 。此扩展仅仅是对 ICU 库的基础包装,并提供了和 ICU 库类似的方法和特性。
PHP 7 通过新的 IntlChar 类暴露出 ICU 中的 Unicode 字符特性。这个类自身定义了许多静态方法用于操作多字符集的 unicode 字符。
printf('%x', IntlChar::CODEPOINT_MAX);
echo IntlChar::charName('@');
var_dump(IntlChar::ispunct('!'));
结果为:
10ffff
COMMERCIAL AT
bool(true)
CSPRNG(Cryptographically Secure Pseudo-Random Number Generator,伪随机数产生器)。
PHP 7 通过引入几个 CSPRNG 函数提供一种简单的机制来生成密码学上强壮的随机数。
string random_bytes ( int $length )
length - 随机字符串返回的字节数。
返回一个字符串,接受一个int型入参代表返回结果的字节数。
$bytes = random_bytes(5);
print(bin2hex($bytes)); // 6f36d48a29
int random_int ( int $min , int $max )
min - 返回的最小值,必须是大于或等于 PHP_INT_MIN 。
max - 返回的最大值,必须是小于或等于 PHP_INT_MAX 。
返回一个指定范围内的int型数字。
print(random_int(100, 999));
print(PHP_EOL);
print(random_int(-1000, 0));
输出的结果为:
723
-64