首頁 >後端開發 >php教程 >php標準規範詳解

php標準規範詳解

小云云
小云云原創
2018-03-19 14:14:423246瀏覽

本文主要和大家分享php標準規範詳解,希望能幫助大家。

psr0:自動載入標準

已經被psr4 取代,可以了解下

1. 強制:完全限定命名空間和類別的格式: \c7d6308d52d1cb887475973afa3ff9f1\(65b7377a1df92bec1d41c5523cac7d43\)*dadba11fc212b6b8df3aaae07b836a2f
2. 強制:每個命名空間必須有一個頂層命名空間(Vendor Name)。
3. 每個命名空間中可以含有任意數量的子命名空間。
4. 當檔案系統載入來源檔案時,命名空間之間的分隔符號將會轉換為 DIRECTORY_SEPARATOR。
5. 類別名稱dadba11fc212b6b8df3aaae07b836a2f中的底線 _ 都會轉換為 DIRECTORY_SEPARATOR。 _ 沒有什麼特殊的意義。
6. 完全限定命名空間和類別從檔案系統載入原始檔案時將會加上 .php 後綴。
7. 完全限定命名空間中的字母大小寫可以是任何組合。

實例

\Doctrine\Common\IsolatedClassLoader => /path/to/project/lib/vendor/Doctrine/Common/IsolatedClassLoader.php
\Symfony\Core\Request => /path/to/project/lib/vendor/Symfony/Core/Request.php
\Zend\Acl => /path/to/project/lib/vendor/Zend/Acl.php
\Zend\Mail\Message => /path/to/project/lib/vendor/Zend/Mail/Message.php

\namespace\package\Class_Name => /path/to/project/lib/vendor/namespace/package/Class/Name.php
\namespace\package_name\Class_Name => /path/to/project/lib/vendor/namespace/package_name/Class/Name.php

psr1:基本程式設計規格

強制:php 標籤必須是bb9bd6d87db7f8730c53cb084e6b4d2d 或e001818591141260ad444db4de1b1edb2. 強制:檔案必須以不含BOM的UTF-8 編碼3. php 檔案中的程式碼只能是定義類別、函數、常數等聲明,或只能是一些副操作4. 命名空間和類別必須滿足psr0 或psr45. 類名必須是StudlyCaps 【大寫開頭的駝峰命名】規範6. 類別中常量所有字母必須大寫,下劃線分隔7. 方法名稱必須是camelCase 駝峰命名規範。

解釋

副操作包含却不仅限于:生成输出、直接的 require 或 include、连接外部服务、
修改 ini 配置、抛出错误或异常、修改全局或静态变量、读或写文件等。<?php// side effect: change ini settingsini_set(&#39;error_reporting&#39;, E_ALL);// side effect: loads a fileinclude "file.php";// side effect: generates outputecho "<html>\n";// declarationfunction foo(){
    // function body}<?php// declarationfunction foo(){
    // function body}// conditional declaration is not a side effectif (! function_exists(&#39;bar&#39;)) {    function bar()
    {
        // function body
    }
}

psr2 程式設計風格規格

#是psr1 的拓展

1. 必須遵循psr12. 縮排必須使用4 個空格符3. 每行的字元數應該軟性保持在80個之內, 理論上一定不可多於120個, 但一定不能有硬性限制。 4. 每個命名空間宣告語句和 use 宣告語句區塊後面,必須插入一個空白行。所有 use 必須在 namespace 後聲明。 5. 方法和類別的開始花括號必須寫在其聲明後另起一行。 6. abstract 以及 final 必須在修飾符 private、protected 以及 public 之前,而 static 必須聲明在存取修飾符之後。 7. 控制結構的關鍵字後必須要有一個空格符,而呼叫方法或函數時一定不能有。 8. 控制結構的開始花括號必須寫在宣告的同一行。 9. 控制結構的開始左括號後和結束右括號前,都一定不能有空格符號。 10. 所有PHP檔案必須使用 Unix LF 作為行的結束符號。
11. 所有PHP檔案必須以一個空白行作為結束。 12. 非空白行後一定不能有多餘的空格符。 13. 每行一定不能存在多於一條語句。 14. PHP所有 關鍵字必須全部小寫。

實例

<?phpnamespace Vendor\Package;use FooInterface;use BarClass as Bar;use OtherVendor\OtherPackage\BazClass;class Foo extends Bar implements FooInterface{
    public function sampleMethod($a, $b = null)
    {
        if ($a === $b) {
            bar();
        } elseif ($a > $b) {            $foo->bar($arg1);
        } else {
            BazClass::bar($arg2, $arg3);
        }
    }    final public static function bar()
    {
        // method body
    }
}

psr4 自動載入

##\374a617deb4f1e1a0d1ab49b52f43400(\6e04880826c89117ee8f8e8a48ca5f62)*\7fff5d86c19d4c1c485a0d77008f2dd8

#:psr4 之後不再叫完全限定命名空間,而是完全限定類別名稱。 1. 完全限定類別名稱必須有一個頂層命名空間,被稱為"vendor namespace"2. 完全限定類別名稱可以有一個或多個子命名空間3. 完整的類別名稱必須有一個最終的類別名稱;4 . 底線都是沒有特殊意義的5. 完整的類別名稱可以由任意大小寫字母組成;6. 所有類別名稱都必須是大小寫敏感的。 7. 完整的類別名稱中,去掉最前面的命名空間分隔符,前面連續的一個或多個命名空間和子命名空間,作為“命名空間前綴”,其必須與至少一個“文件基目錄”相對應; 8. 緊接命名空間前綴後的子命名空間必須與對應的」檔案基底目錄「相匹配,其中的命名空間分隔符號將作為目錄分隔符。 9. 末尾的類別名稱必須與對應的以 .php 為後綴的檔案同名。 10. 自動載入器(autoloader)的實作一定不能拋出例外、一定不能觸發任一層級的錯誤訊息、不應該有回傳值。

實例

完整類別名稱#命名空間前綴檔案基底目錄檔案路徑\Acme\Log\Writer\File_WriterAcme\Log\Writer./acme -log-writer/lib/./acme-log-writer/lib/File_Writer.php\Aura\Web\Response\StatusAura\Web/path/to/aura-web/src//path/to/aura-web/src/Response/Status.php#\Symfony\Core\RequestSymfony\Core./vendor/Symfony/Core/./vendor/Symfony/Core/Request .php\Zend\AclZend/usr/includes/Zend//usr/includes/Zend /Acl.php
相關推薦:

#PHP標準類別(stdclass)用法範例

PHP標準函式庫SPL

php標準產生驗證碼程式#

以上是php標準規範詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn