首页 后端开发 PHP8 了解PHP 8新特性Attributes注解

了解PHP 8新特性Attributes注解

Jul 27, 2020 pm 05:52 PM

了解PHP 8新特性Attributes注解

PHP8 的 Alpha 版本,过几天就要发布了,其中包含了不少的新特性,当然我自己认为最重要的还是 JIT,这个我从 2013 年开始参与,中间挫折无数,失败无数后,终于要发布的东东。

不过,今天呢,我不打算谈 JIT,等 PHP8 发布了以后,我再单独写个类似《深入理解 PHP8 之 JIT》系列来说吧。

嘿嘿,今天呢,我想谈谈 Attributes,为啥呢, 是昨天我看到很多群在转发一个文章,叫做《理解 PHP8 中的 Attributes》,说实在的,这篇文章应该是直接从英文翻译过来的,写的晦涩难懂,很多同学看完以后表示,看的一头雾水,不知道在说啥。

于是我想,就用一篇文章来简单说说这是个啥。

说注解之前,先说说以前的注释,我们经常会在 PHP 的项目中,看到的一个东西,类似如下的 @param 和 @see :

/**
 * @param Foo $argument
 * @see https:/xxxxxxxx/xxxx/xxx.html
 */    
 function dummy($Foo) {}
登录后复制

这个叫做注释,对于以前的 PHP 来说,注释中的 @param 和 @see 毫无意义,整个这一段会保存为一个函数 / 方法的一个叫做 doc_comment 的字符串。

如果我们要分析这段注释的含义,我们需要通过设计一些特定的语法,就比如栗子中的 @+name, 类似 @param 一样, 然后自己分析这段字符串,来提取对应的信息。

比如我们要获取 See 这个注释的信息,我们需要做类似:

$ref = new ReflectionFunction("dummy");
$doc = $ref->getDocComment();
$see = substr($doc, strpos($doc, "@see") + strlen("@see "));
登录后复制

这样的字符串处理,相对比较麻烦,也比较容易出错。

而 Attributes 呢,其实就是把 “注释” 升级为支持格式化内容的 “注解”

比如上面的例子:

<<Params("Foo", "argument")>>
<<See("https://xxxxxxxx/xxxx/xxx.html")>>
function dummy($argument) {}
登录后复制

大家不要纠结这么写的意义是啥,从功能上来说,现在你就可以通过 Reflection 来获取这段格式化的注解了,比如,我们现在要获取 See 这个注解:

$ref = new ReflectionFunction("dummy");
 
var_dump($ref->getAttributes("See")[0]->getName());
var_dump($ref->getAttributes("See")[0]->getArguments());
登录后复制

会输出:

string(3) "See"
array(1) {
  [0]=>
  string(30) "https://xxxxxxxx/xxxx/xxx.html"
}
登录后复制

当然,还有稍微高级一点的用法,就是你可以定义一个所谓的 “注解类”:

<?php
<<phpAttribute>>
class MyAttribute {
     public function __construct($name, $value) {
          var_dump($name);
          var_dumP($value);
     }
}
登录后复制

然后, 你就可以写类似, 注意其中的 newInstance 调用:

<<MyAttribute("See", "https://xxxxxxxx/xxxx/xxx.html")>>
function dummy($argument) {
}
$ref = new ReflectionFunction("dummy");
 
$ref->getAttributes("MyAttribute")[0]->newInstance();
登录后复制

如果你跑这段代码,你会看到 MyAttribute 的__construct 方法被调用了,调用传递的参数就是”See” 和”https://xxx”

明白了么, 就是你可以把一个注解 “实例化”, 然后,你就可以基于这个能力,来做自己的 “注释即配置” 的设计。总结下 Attributes 的写法就是如下的形式:

<<Name>>
<<Name(Arguments)>>
<<Name(Argunment1, Arguments2, ArgumentN)>>
 
<<Name1(Argument), Name2(Argument), Name3(Argument)>>
登录后复制

然后你就可以通过 PHP 的 Reflection 系列的方法,根据 getAttributes (“Name”) 获取对应的注解, 进一步你可以通过调用返回的注解的 getName 方法获取名字,getArguments 方法获取括号中的 Arguments。

再进一步,如果 Name 是一个你自己定义的,带有 phpAttriubtes 注解的类, 你还可以调用 newInstance 方法,实现类似”new Name (Arguments)” 的调用。

也许很多人会问,这有什么卵用?

坦白说,我一直对新特性无感,但这个 Attributes,多少还是应该有那么一点点吧。

推荐文章:《PHP8.0

以上是了解PHP 8新特性Attributes注解的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解锁Myrise中的所有内容
4 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)