컴퓨터 과학에서 구문 설탕은 작업을 더 쉽게 표현할 수 있는 프로그래밍 언어의 구문을 의미합니다. 이를 통해 프로그래머가 언어를 더 쉽게 사용할 수 있습니다. 작업이 더 명확해지고, 더 편리해지거나, 더 일관될 수 있습니다. 프로그래머의 프로그래밍 습관과 함께.
빈 개체는 4.0
="font으로 간주됩니다. -size:14px;line-height:22px;padding:4px 2px 0px;">true4.0
以后都视为true
string
的内部结构类似 array
, 可以像python一下使用下标访问字符串
$str = '012345'; echo $str[1]; //1 echo $str{2}; //2
5.4
以后可以像JS一样定义数组
$arr = ['one', 'two', 'three']; //感觉方便了很多
时间长不用总会忘记重新整理一下加深下印象
SERVER_ADDR
IP地址 127.0.0.1
SERVER_NAME
主机名 localhost
SERVER_SOFTWARE
服务器类型 nginx
REMOTE_ADDR
客户端IP. 127.0.0.1
s
$_FILES['file']['name']
图片原名称
$_FILES['file']['type']
图片MIME类型
$_FILES['file']['size']
图片大小
$_FILES['file']['tmp_name']
服务器端临时名称
5.3
之后可以使用const
来定义常量
const DEBUG = true;
96b4fef55684b9312718d5de63fb7121
比较运算符,7.0
之后支持
echo $a <=> $b;/* 当 $a < $b 时, 表达式返回 -1 当 $a = $b 时, 表达是返回 0 当 $a > $b 时, 表达式返回 1 */
??
空合并运算符 PHP7
特性。
$name = $_POST['name'] ?? ''; //如果前面的值不为null,则返回本身,否则返回后面的值
三元运算符 ?:
5.3
以后可以使用
$name = $_POST['name'] ?: ''; ////如果前面的值不为null,则返回本身,否则返回后面的值
goto
5.3
문자열의 내부 구조
는 array
, 아래 첨자를 사용하여 python🎜goto a;echo 'Foo'; a:echo 'Bar';//输出 Bar🎜Array🎜🎜🎜🎜
5.4
앞으로는 JS🎜function dosum(...$arr){ $sum = 0; foreach($arr as $v){ $sum += $v; } return $sum; }$arr = [1, 2, 3, 4, 5];echo dosum(...$arr); // 输出15echo dosum(1,2,3,4,5,6); //输出21//TODO/** 这个语法,我最近总在用。感觉还比较简单。不过要注意服务器版本。。最近入了一个坑。 */🎜전역 변수🎜
$test = function($name='Li'){ echo 'My name is '.$name; };$test();🎜$_SERVER🎜🎜🎜🎜와 같은 배열을 정의할 수 있습니다.
SERVER_ADDR
IP 주소 127.0.0.1🎜🎜🎜SERVER_NAME
호스트 이름 localhost🎜🎜🎜SERVER_SOFTWARE
서버 유형 nginx🎜🎜🎜REMOTE_ADDR
클라이언트 IP. .0.1 $_FILES [ 'file']['name']
사진의 원래 이름🎜🎜🎜$_FILES ['file']['type']
이미지 MIME 유형🎜🎜🎜$ _FILES['file']['size']
사진 크기🎜🎜🎜$ _FILES['file']['tmp_name']
서버측 임시 이름🎜🎜Constant🎜🎜🎜🎜5.3 이후
에서는 const 상수 정의 🎜<pre class="prettyprint" style="font-size:14px;line-height:22px;">//这里定义一个默认的输出名字的方式$tpl = &#39;My name is &#39;;//使用 use() 来引用父级的变量,最后输出结果与上边一致 $test = function($name=&#39;Li&#39;) use($tpl) {
echo $tpl.$name;
};$test();</pre>🎜operator🎜🎜🎜🎜<code style="font-size:14px;line-height:22px;padding:4px 2px 0px;">b207bb093495751f3e536c5eb7122819
7.0
🎜 이후 지원되는 비교 연산자 namespace Foo{ class test{ } echo test::class; // 输出 FOO\test, 在使用命名空间的情况非常有用}🎜🎜🎜
??
Null 병합 연산자 PHP7
기능. 🎜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; // 使用B的say方法代替了A的say方法 walk as protected; // 将walk 设置为受保护的 } }$obj = new Person;$obj->say(); // echo trait A;$obj->walk(); // 提示不能访问一个受保护的方法🎜🎜🎜삼항 연산자
?:
5.3
은 나중에 사용할 수 있습니다🎜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 1echo $obj === $obj1 ? 0 : 1; // echo 1🎜Process control🎜🎜🎜🎜이동
5.3
이상은 유효합니다🎜操作符可以用来跳转到程序中的另一位置。该目标位置可以用目标名称加上冒号来标记,而跳转指令是 goto 之后接上目标位置的标记。PHP 中的 goto 有一定限制,目标位置只能位于同一个文件和作用域,也就是说无法跳出一个函数或类方法,也无法跳入到另一个函数。也无法跳入到任何循环或者 switch 结构中。可以跳出循环或者 switch,通常的用法是用 goto 代替多层的 break。
goto a;echo 'Foo'; a:echo 'Bar';//输出 Bar
变长参数 ...
, 5.6
以后可用
function dosum(...$arr){ $sum = 0; foreach($arr as $v){ $sum += $v; } return $sum; }$arr = [1, 2, 3, 4, 5];echo dosum(...$arr); // 输出15echo dosum(1,2,3,4,5,6); //输出21//TODO/** 这个语法,我最近总在用。感觉还比较简单。不过要注意服务器版本。。最近入了一个坑。 */
匿名函数(Anonymous functions)5.3
也叫闭包函数,在JS中很常见。为了防止污染全局作用域。5.3 以后PHP也支持了这种写法
$test = function($name='Li'){ echo 'My name is '.$name; };$test();
如果想要从父作用域中继承变量怎么办
//这里定义一个默认的输出名字的方式$tpl = 'My name is ';//使用 use() 来引用父级的变量,最后输出结果与上边一致 $test = function($name='Li') use($tpl) { echo $tpl.$name; };$test();
需要注意的是,闭包函数的父作用域,是定义它的作用域,不是调用的作用域
::class
类的静态方法,用于获取类的完全限定名称,(包含命名空间)
namespace Foo{ class test{ } echo test::class; // 输出 FOO\test, 在使用命名空间的情况非常有用}
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; // 使用B的say方法代替了A的say方法 walk as protected; // 将walk 设置为受保护的 } }$obj = new Person;$obj->say(); // echo trait A;$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 1echo $obj === $obj1 ? 0 : 1; // echo 1
5.3
类的后期静态绑定
官方的解释是:
该功能从语言内部角度考虑被命名为”后期静态绑定”。”后期绑定”的意思是说,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(); // echo A;// 上面是一个正常的调用, 输出了 A// 当我们把 class A 的 test 方法修改一下。 将 self 改成 static 后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(); // echo B;
总结:PHP5.3
新增加了一类关键字,static
可以在调用函数的方法。用这个关键字,来实现了后期静态绑定
。
比较简单记录一下
try{ throw new Execption('抛出异常'); } catch (Execption $e){ //获取异常 $error = $e->getMessage(); }echo $error; //抛出异常
相关推荐:
위 내용은 PHP 5.0~7.1에서 일반적으로 사용되는 구문 설탕의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!