|
PHP更新了这久了,一只也没有来巩固一下基本语法。最近抽了点时间梳理了一下php版本的差异。自己记录一下,同时也分享出来 大家一起学习探讨一下
类型
Boolean
String
Array
全局变量
时间长不用总会忘记重新整理一下加深下印象
$_SERVER
SERVER_ADDR IP地址 127.0.0.1
SERVER_NAME 主机名 localhost
SERVER_SOFTWARE 服务器类型 nginx
REMOTE_ADDR 客户端IP. 127.0.0.1
s
$_FILES
$_FILES['file']['name'] 图片原名称
$_FILES['file']['type'] 图片MIME类型
$_FILES['file']['size'] 图片大小
$_FILES['file']['tmp_name'] 服务器端临时名称
常量
const DEBUG = true;
运算符
echo $a <=> $b;
$name = $_POST['name'] ?? '';
$name = $_POST['name'] ?: '';
流程控制
操作符可以用来跳转到程序中的另一位置。该目标位置可以用目标名称加上冒号来标记,而跳转指令是 goto 之后接上目标位置的标记。PHP 中的 goto 有一定限制,目标位置只能位于同一个文件和作用域,也就是说无法跳出一个函数或类方法,也无法跳入到另一个函数。也无法跳入到任何循环或者 switch 结构中。可以跳出循环或者 switch,通常的用法是用 goto 代替多层的 break。
goto a;
echo 'Foo';
a:
echo 'Bar';
函数
function dosum(...$arr){
$sum = 0;
foreach($arr as $v){
$sum += $v;
}
return $sum;
}
$arr = [1, 2, 3, 4, 5];
echo dosum(...$arr);
echo dosum(1,2,3,4,5,6);
- 匿名函数(Anonymous functions)
5.3
也叫闭包函数,在JS中很常见。为了防止污染全局作用域。5.3 以后PHP也支持了这种写法
$test = function($name='Li'){
echo 'My name is '.$name;
};
$test();
如果想要从父作用域中继承变量怎么办
$tpl = 'My name is ';
$test = function($name='Li') use($tpl) {
echo $tpl.$name;
};
$test();
需要注意的是,闭包函数的父作用域,是定义它的作用域,不是调用的作用域
类和对象
::class 类的静态方法,用于获取类的完全限定名称,(包含命名空间)
namespace Foo{
class test{
}
echo test::class;
}
5.4 新增加的一个多继承实现方式trait。下面总结了一下基本概念
1.trait 和 class 是相似的概念,但不能被实例化
2.一个类可以使用多个trait,优先级是 class > trait > 父类继承的方法
3.使用insteadof 来解决 tarit 冲突
4.使用as,来修改方法的访问控制
5.在trait中也可以使用tarit。和在class中用法一致
trait A {
public function say(){
echo 'trait A';
}
}
trait B {
public function say(){
echo 'trait B';
}
public function walk(){
echo 'walk B';
}
}
class Person {
use A, B{
B :: say insteadof A;
walk as protected;
}
}
$obj = new Person;
$obj->say();
$obj->walk();
6.在trait中使用, 属性、静态属性、静态方法、抽象类都是被允许的。
trait Test {
public static $obj;
public $name = 1;
static function createObj(){
return empty(self::$obj) ? new self : self::$obj;
}
}
class son {
use Test;
}
$obj = son::createObj();
echo $obj->name;
echo $obj === $obj1 ? 0 : 1;
该功能从语言内部角度考虑被命名为”后期静态绑定”。”后期绑定”的意思是说,static:: 不再被解析为定义当前方法所在的类,而是在实际运行时计算的。也可以称之为”静态绑定”,因为它可以用于(但不限于)静态方法的调用
乍一看,好像什么也没看懂。看看具体的代码吧。
class A {
public static function who() {
echo __CLASS__;
}
public static function test() {
self::who();
}
}
class B extends A {
public static function who() {
echo __CLASS__;
}
}
B::test();
class A {
public static function who() {
echo __CLASS__;
}
public static function test() {
static::who();
}
}
class B extends A {
public static function who() {
echo __CLASS__;
}
}
B::test();
总结:PHP5.3新增加了一类关键字,static 可以在调用函数的方法。用这个关键字,来实现了后期静态绑定。
异常处理
比较简单记录一下
try{
throw new Execption('抛出异常');
} catch (Execption $e){
$error = $e->getMessage();
}
echo $error;
|