


An in-depth analysis of the new features of PHP7.0 (five new features), the top five of PHP7.0_PHP Tutorial
In-depth analysis of the new features of PHP7.0 (five major new features), the top five of php7.0
So far, PHP has officially released the RC5 version of php7, which is expected to be released in 2020 The first official version will be released around November! Now, the major features of php7 have definitely been finalized and there will be no more changes. The iterations of some subsequent versions are mainly bug fixes, optimizations and the like. Let’s talk about the five new features of php7.0 that we have been looking forward to.
If you are using a framework based on composer and PSR-4, can this method of writing successfully load class files? In fact, it is possible. The autoloading method registered by composer searches the location according to the namespace of the class when the class is called. This way of writing has no effect on it.
1. Operator (NULL coalescing operator)
I put this first because I find it useful. Usage:
$a = $_GET['a'] ?? 1;
It is equivalent to:
<?php $a = isset($_GET['a']) ? $_GET['a'] : 1;
We know that the ternary operator can be used like this:
$a ?: 1
But this is based on the premise that $a has been defined. The new ?? operator can simplify judgment.
2. Function return value type declaration
Example provided by the official documentation (note that the side length parameter syntax of ... is only available in PHP 5.6 and above):
<?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]));
It can be seen from this example that functions (including anonymous functions) can now specify the type of return value.
The way this statement is written is somewhat similar to swift:
func sayHello(personName: String) -> String { let greeting = "Hello, " + personName + "!" return greeting }
This feature can help us avoid some problems caused by PHP's implicit type conversion. Thinking about the expected results before defining a function can avoid unnecessary mistakes.
However, there is also a feature that needs attention here. PHP 7 adds a declare directive: strict_types, which uses strict mode.
When using return value type declaration, if it is not declared in strict mode, and if the return value is not of the expected type, PHP will still cast it. But if it is strict mode, a Fatal error of TypeError will be triggered.
Forced mode:
<?php function foo($a) : int { return $a; } foo(1.0);
The above code can be executed normally, and the foo function returns int 1 without any errors.
Strict mode:
<?php declare(strict_types=1); function foo($a) : int { return $a; } foo(1.0);
# PHP Fatal error: Uncaught TypeError: Return value of foo() must be of the type integer, float returned in test.php:6
After the declaration, a fatal error will be triggered.
Is it similar to the strict mode of js?
3. Scalar type declaration
The formal parameter type declaration of functions in PHP 7 can be scalar. In PHP 5, it can only be a class name, interface, array or callable (PHP 5.4, it can be a function, including anonymous functions). Now you can also use string, int, float and bool.
Official example:
<?php // Coercive mode function sumOfInts(int ...$ints) { return array_sum($ints); } var_dump(sumOfInts(2, '3', 4.1));
It should be noted that the strict mode problem mentioned above also applies here: in the forced mode (default, both forced type conversion), the parameters that do not meet the expectations will still be forced to type conversion, and in strict mode, it will be triggered TypeError fatal error.
4. use batch declaration
In PHP 7, use can declare multiple classes or functions or const in one sentence:
<?php 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};
But you still have to write the name of each class or function or const (there is no from some import * method like python).
A question to note is: If you are using a framework based on composer and PSR-4, can this writing method successfully load class files? In fact, it is possible. The autoloading method registered by composer searches the location according to the namespace of the class when the class is called. This way of writing has no effect on it.
5. Other features
I won’t introduce some other features one by one. If you are interested, you can check the official documentation: http://php.net/manual/en/migration70.new-features.php
Tell me a few briefly:
PHP 5.3 started to have anonymous functions, and now there are anonymous classes;
define can now define constant arrays;
Closure adds a call method;
Generators (or iterators, more appropriately) can have a final return value (return), or can be passed into another generator (generator delegate) through the new syntax of yield from.
Two new features of generators (return and yield from) can be combined. You can test the specific appearance by yourself. PHP 7 is now at RC5 and the final version should be coming soon.
The above is all about the new features of php7.0. I hope you will like this introduction.

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



Alipay PHP...

JWT is an open standard based on JSON, used to securely transmit information between parties, mainly for identity authentication and information exchange. 1. JWT consists of three parts: Header, Payload and Signature. 2. The working principle of JWT includes three steps: generating JWT, verifying JWT and parsing Payload. 3. When using JWT for authentication in PHP, JWT can be generated and verified, and user role and permission information can be included in advanced usage. 4. Common errors include signature verification failure, token expiration, and payload oversized. Debugging skills include using debugging tools and logging. 5. Performance optimization and best practices include using appropriate signature algorithms, setting validity periods reasonably,

Article discusses late static binding (LSB) in PHP, introduced in PHP 5.3, allowing runtime resolution of static method calls for more flexible inheritance.Main issue: LSB vs. traditional polymorphism; LSB's practical applications and potential perfo

Article discusses essential security features in frameworks to protect against vulnerabilities, including input validation, authentication, and regular updates.

Sending JSON data using PHP's cURL library In PHP development, it is often necessary to interact with external APIs. One of the common ways is to use cURL library to send POST�...

The article discusses adding custom functionality to frameworks, focusing on understanding architecture, identifying extension points, and best practices for integration and debugging.

The application of SOLID principle in PHP development includes: 1. Single responsibility principle (SRP): Each class is responsible for only one function. 2. Open and close principle (OCP): Changes are achieved through extension rather than modification. 3. Lisch's Substitution Principle (LSP): Subclasses can replace base classes without affecting program accuracy. 4. Interface isolation principle (ISP): Use fine-grained interfaces to avoid dependencies and unused methods. 5. Dependency inversion principle (DIP): High and low-level modules rely on abstraction and are implemented through dependency injection.

Session hijacking can be achieved through the following steps: 1. Obtain the session ID, 2. Use the session ID, 3. Keep the session active. The methods to prevent session hijacking in PHP include: 1. Use the session_regenerate_id() function to regenerate the session ID, 2. Store session data through the database, 3. Ensure that all session data is transmitted through HTTPS.
