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($numbergetMessage();
}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-fpm5 默认情况下显示PHP启动错误
本文转载自:https://www.gylmap.com
#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 = Off
2.assert.callback = assert_fail
3.回调实验
assert(5';
	echo $line;
	echo '
';
	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 0
2.PDO::ERRMODE_WARNING 1
3.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();
}
 
                             
                             
                             
                            