Skip to main content
 Web开发网 » 站长学院 » 浏览器插件

PHP8.0的新特性:错误处理方面已经改进

2021年10月25日6120百度已收录

1 系统函数引发TypeError和ValueError异常一.TypeError和ValueError改进作用#在PHP 8中,内部函数参数强制执行类型和值验证,如果不允许使用预期的类型或值,则将抛出TypeError或ValueError异常错误.#在PHP 8之前,这会导致PHP警告.

1.TypeError触发条件提供的值是不是正确的类型.

2.ValueError触发条件如果提供的值是正确的类型,但PHP在上下文中不可接受,则PHP会引发ValueError异常.

二.系统函数引发TypeError

substr('foo', []);try{ substr('linux',[]);}catch(TypeError $e){ echo $e->getMessage();}三.系统函数引发ValueError

json_decode('"foo"', true, -1);try{ json_decode('"foo"', true, -1);}catch(ValueError $e){ echo $e->getMessage();}四.自定义函数引发TypeError

function show(string $name){ var_dump($name);}show([]);五.自定义函数引发ValueError

function show(int $number){ if($number<10){ throw new ValueError('this value must be greater or equal 10'); }else{ echo $number; }}show(5);#try捕捉function show(int $number){ if($number<10){ throw new ValueError('the number must be greater and equal 10'); }else{ echo $number; }}try{ show(5);}catch(ValueError $e){ echo $e->getMessage();}2 Throw表达式抛出异常一.改进原因在PHP8前,不允许在单个表达式时引发异常,现在可以在箭头函数、三元表达式等单个表达式的任何地方引发异常.

二.箭头函数使用//第1阶段

function show(){ return 123;}echo show();// 第2阶段$fn=function(){ return 123;};echo $fn();//第3阶段echo (function(){ return 123;})();// 第4阶段$fn=fn()=>123;echo $fn();// 第5阶段echo (fn()=>123)();三.箭头函数+引发异常1.先定义后执行

$fn=fn()=>throw new Exception('error');try{ $fn();}catch(Exception $e){ echo $e->getMessage();}2.定义并同时执行

(fn() => throw new Exception('oops'))();四.三元表达式使用

$name=false;$age=20;$r=$name ? $name : $age;$r=$name ?: $age;$r=$name ?? $age;var_dump($r);五.三元表达式+引发异常#前面为真则返回第二个值,否则返回第三个值

$value = $name ? $name : throw new Exception('value not set');$value = $name ?: throw new Exception('value not set');#前面存在则返回第一个值,否则返回第二个值

$value = $name ?? throw new Exception('value not set');

3 无变量捕获的Catch一.作用在catch读法中不用必须写$e变量

二.语法

try{ ...}catch(Exception){ ...}三.实例

try{ (fn()=>throw new Exception('error'))();}catch(Exception){ echo 'Exception error!';}

4 默认错误报告设置为E_ALL一.配置方法#php.ini

error_reporting = E_ALL二.恢复旧设置#屏蔽已弃用错误、提示错误、语法严格性检测

E_ALL & ~E_DEPRECATED & ~E_STRICT & ~E_NOTICE三.屏蔽所有错误

display_errors = Off四.配置生效

pkill -USR2 php-fpm

5 默认情况下显示PHP启动错误#php.ini

一.默认PHP启动错误

display_startup_errors = On二.测试PHP启动错误1.制造启动错误

session.name=''2.启动测试

pkill php-fpm/usr/local/php/sbin/php-fpm三.屏蔽PHP启动错误1.startup错误

display_startup_errors = Off2.控制错误级别

error_reporting = E_ALL & ~E_WARNING3.测试结果

pkill php-fpm/usr/local/php/sbin/php-fpm4.商用建议关闭

6 Assert断言默认情况下引发异常一.Assert改进#php.ini默认开启#assert(true === false);

1.低版本下失败的assert断言会引发警告,但不会引发异常.(PHP5)

assert.exception=On2.php8开始失败的assert断言会直接引发异常.(PHP7,PHP8)

assert.exception=On二.Assert回调

1.display_errors = Off2.assert.callback = assert_fail3.回调实验

assert(5<10);function assert_fail($file,$line,$assertion,$description){ echo $file; echo '<br>'; echo $line; echo '<br>'; echo $description;}

7 操作符@不再抑制Fatal错误一.新版本中@不再抑制Fatal错误1.实例1

@substr();2.实例2

function load_files() { require_once 'file-that-does-not-exist.oops';}@load_files();3.在PHP 8.0中,该@运算符不会抑制在PHP 8.0之前已静音的某些类型的错误

E_ERROR -致命的运行时错误.E_CORE_ERROR -PHP的初始启动中发生致命错误.E_COMPILE_ERROR -致命的编译时错误.E_USER_ERROR-用户触发的trigger_error()功能错误.E_RECOVERABLE_ERROR -可捕获的致命错误.E_PARSE -编译时解析错误.4.E_USER_ERROR实例

function do_something() { trigger_error('Something went wrong', E_USER_ERROR);}@do_something();

8 PDO默认错误模式为ERRMODE_EXCEPTION一.创建sqlite3数据库php8.db

sqlite3 /sqlite3/php8.db二.sql基础操作1.创建表user

create table user(id integer PRIMARY KEY AUTOINCREMENT,name text,age integer);2.插入数据

insert into user values(1,'user1',20);insert into user values(2,'user2',22);3.查询数据

select * from user;三.linux下查看数据库文件(十六进制)

xxd php8.db四.php pdo操作sqlite3 php8数据库

$pdo = new PDO('sqlite:/sqlite3/php8.db');五.pdo报错类型PDO::ATTR_ERRMODE

1.PDO::ERRMODE_SILENT 02.PDO::ERRMODE_WARNING 13.PDO::ERRMODE_EXCEPTION 2六.pdo设置错误类型1.设置

$pdo->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_WARNING);2.获取

$pdo->getAttribute(PDO::ATTR_ERRMODE);七.pdo操作user表

$sql='select * from user2';$smt=$pdo->prepare($sql);$smt->execute();$arr=$smt->fetchAll(PDO::FETCH_ASSOC);八.pdo操作异常捕捉

try{ $pdo=new PDO('sqlite:/sqlite3/php8.db'); $smt=$pdo->prepare('select * from user2'); $smt->execute(); $rows=$smt->fetchAll(PDO::FETCH_ASSOC);}catch(PDOException $e){ echo $e->getMessage();}

评论列表暂无评论
发表评论
微信