>백엔드 개발 >PHP 튜토리얼 >PHP 표준 사양에 대한 자세한 설명

PHP 표준 사양에 대한 자세한 설명

小云云
小云云원래의
2018-03-19 14:14:423262검색

이 글은 주로 PHP 표준 사양에 대한 자세한 설명을 공유하여 모든 사람에게 도움이 되기를 바랍니다.

psr0: 자동 로딩 표준

이 psr4로 대체되었습니다. 이에 대해 알아볼 수 있습니다.

1 필수: 정규화된 네임스페이스 및 클래스 형식: 8980288201290d9aed4a4a1e9fb64640(bccb42071a069e82f3db9f594db28e62)*db8289497bf4216f16c2354fbc68092c
2. 필수: 각 네임스페이스에는 최상위 네임스페이스(공급업체 이름)가 있어야 합니다.
3. 각 네임스페이스에는 여러 개의 하위 네임스페이스가 포함될 수 있습니다.
4. 파일 시스템이 소스 파일을 로드하면 네임스페이스 사이의 구분 기호가 DIRECTORY_SEPARATOR로 변환됩니다.
5. 클래스 이름 5a0c9c2f6b8da8934d3ad612e7d342ad에 있는 밑줄 _은 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여야 합니다. 필수: 파일은 BOM3 없이 UTF-8로 인코딩되어야 합니다. .php 파일의 코드는 클래스, 함수, 상수 등을 정의하는 선언만 가능하거나 일부 부가 작업만 가능합니다. 4. 네임스페이스와 클래스는 psr0 또는 psr45를 충족해야 합니다. 클래스 이름은 StudlyCaps [Camel]이어야 합니다. 대문자로 시작하는 케이스 이름 지정] 사양 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의 확장입니다. 들여쓰기는 4자리 공백을 사용해야 합니다. 3. 한 줄당 문자 수는 이론적으로 80자 이내로 유지해야 합니다. 120개를 초과할 수 없지만 엄격한 제한이 있어서는 안 됩니다. 4. 각 네임스페이스 선언 및 사용 선언 블록 뒤에 빈 줄을 삽입해야 합니다. 모든 사용은 네임스페이스 뒤에 선언되어야 합니다. 5. 메소드와 클래스의 여는 중괄호는 선언 후 새 줄에 작성해야 합니다. 6. abstract 및 final은 private, protected 및 public 수정자 앞에 와야 하며 static은 액세스 수정자 뒤에 선언되어야 합니다. 7. 제어 구조의 키워드 뒤에는 공백이 있어야 하지만, 메소드나 함수 호출 시에는 공백이 있어서는 안 됩니다. 8. 제어 구조의 여는 중괄호는 선언과 같은 줄에 작성되어야 합니다. 9. 제어 구조의 여는 왼쪽 브래킷 뒤와 닫는 오른쪽 브래킷 앞에는 공백이 없어야 합니다. 10. 모든 PHP 파일은 Unix LF를 줄 종결자로 사용해야 합니다.
11. 모든 PHP 파일은 빈 줄로 끝나야 합니다. 12. 공백이 아닌 줄 뒤에는 추가 공백이 없어야 합니다. 13. 한 줄에 하나 이상의 명세서가 있어야 합니다. 14. 모든 PHP 키워드는 소문자여야 합니다.

Instance

<?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. 정규화된 클래스 이름에는 "공급업체 네임스페이스"라고 하는 최상위 네임스페이스가 있어야 합니다. 2. 정규화된 클래스 이름에는 하나 이상의 하위 네임스페이스가 있을 수 있습니다. 3. 완전한 클래스 이름에는 최종 클래스 이름이 있어야 합니다. . 밑줄에는 특별한 의미가 없습니다. 5. 전체 클래스 이름은 대문자와 소문자로 구성될 수 있습니다. 6. 모든 클래스 이름은 대소문자를 구분해야 합니다. 7. 전체 클래스 이름에서 첫 번째 네임스페이스 구분 기호를 제거하고 앞의 하나 이상의 연속 네임스페이스 및 하위 네임스페이스가 "네임스페이스 접두사"로 사용됩니다. 이는 적어도 하나의 "파일 기본 디렉터리"에 해당해야 합니다. 네임스페이스 접두사 바로 뒤에 오는 하위 네임스페이스는 해당 "파일 기본 디렉터리"와 일치해야 하며 네임스페이스 구분 기호는 디렉터리 구분 기호로 사용됩니다. 9. 끝에 있는 클래스 이름은 .php 접미사가 붙은 해당 파일의 이름과 동일해야 합니다. 10. 자동 로더의 구현은 예외를 발생시켜서는 안 되고, 어떤 수준의 오류 메시지도 트리거해서는 안 되며, 반환 값을 가져서는 안 됩니다.

Instance

전체 클래스 이름 네임스페이스 접두사 파일 기본 디렉터리 파일 경로
AcmeLogWriterFile_Writer AcmeLogWriter ./acme-log-writer/lib/ . /acme-log-writer/lib/File_Writer.php
AuraWebResponseStatus AuraWeb /path/to/aura-web/src/ /path/to/aura-web/src/Response/Status . php
SymfonyCoreRequest SymfonyCore ./vendor/Symfony/Core/ ./vendor/Symfony/Core/Request.php
ZendAcl Zend /usr/includes/Zend/ /usr/includes/Zend/Acl.php

관련 권장 사항:

PHP 표준 클래스(stdclass) 사용 예

PHP 표준 라이브러리 SPL

php 표준 생성 확인 코드 프로그램

위 내용은 PHP 표준 사양에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.