처음 PHP를 접했을 때 프로세스 중심 접근 방식을 사용하여 아주 간단한 웹사이트를 재미로 만들고 그냥 PHP를 작성했습니다. 코드 스택, 확장성, 유지 관리성이 너무 낮아 로직을 변경하는 것이 매우 불편합니다. 나중에 PHP가 객체 지향을 지원한다는 사실을 알게 되었는데, 문득 그 당시에는 제가 정말 어리고 무지하다는 생각이 들었습니다. 결국 PHP가 C로 구현되어 있다는 것은 놀라운 일이 아닙니다.
머리말:
연락처 PHP시작하면 가장 먼저 접하게 되는 것은 배열 연산 함수, 문자열 연산 함수, 파일 연산 함수 등의 함수입니다.
이러한 함수는 PHP 사용의 기초이며, PHP가 탄생할 때부터 지원해 온 프로세스 지향 프로그래밍이기도 합니다. 프로세스 지향은 기능을 하나씩 캡슐화하고 모듈식 아이디어로 문제를 해결합니다.
객체 지향 프로그래밍은 PHP4부터 지원되었습니다. 그러나 PHP4의 객체지향 지원은 완벽하지 않습니다. PHP5부터 PHP는 새로운 객체 모델(객체 모델)을 도입하고 액세스 제어, 추상 및 최종 클래스, 클래스 메소드, 매직 메소드, 인터페이스, 객체 복제 및 유형 힌트 등을 포함한 많은 새로운 기능을 추가했습니다. 그리고 최근 출시된 PHP5.3 버전에는 네임스페이스, 지연된 정적 바인딩 및 추가 두 가지 매직 메소드인 __callStatic()과 __부르다().
그럼 PHP의 밑바닥에는 어떻게 구현되어 있고, 그 구조는 어떻게 되나요?
하나. 클래스 구조
TIPI 인용 예:
class ParentClass {
}
interface Ifce {
public function iMethod();
}
final class Tipi extends ParentClass implements Ifce {
public static $sa = 'aaa';
const CA = 'bbb';
public function __constrct() {
}
public function iMethod() {
}
private function _access() {
}
public static function access() {
}
}
로그인 후 복사
부모 클래스 ParentClass, 인터페이스 Ifce 및 하위 클래스 Tipi가 여기에 정의됩니다. 하위 클래스는 상위 클래스 ParentClass를 상속하고 Ifce 인터페이스를 구현하며 정적 변수 $sa, 클래스 상수 CA, 공용 메서드, 전용 메서드 및 공용 정적 메서드를 갖습니다. 이러한 구조는 Zend 엔진 내부에서 어떻게 구현됩니까? 클래스 메소드와 멤버 변수는 어떻게 저장되나요? 액세스 제어, 정적 멤버는 어떻게 표시됩니까?
먼저 클래스의 내부 저장소 구조를 살펴보겠습니다.
위 구조의 일부 필드를 사용하여 커널의 기사 시작 부분에서 PHP 코드의 성능을 분석합니다. 아래와 같이 :
运行程序将报错,违反了第三条:Fatal error: Cannot declare property Tipi::$var final, the final modifier is allowed only for methods and classes in .. 这个错误由zend_do_declare_property函数抛出
프로그램을 직접 실행하면 오류가 보고됩니다. 치명적인 오류: 인터페이스 메서드 Ifce::method()에 대한 액세스 유형은 생략되어야 합니다. 이 코드는 zend_do_begin_function_declaration의 코드에 해당합니다. 기능.
넷. 메소드(Function)와 함수(Method)의 유사점과 차이점
함수 구현에 대해서는 앞에서 소개한 바 있다. 메서드는 비교하는 것입니다. 마찬가지로 일련의 로직이 실행을 위해 컬렉션에 추가되지만 두 가지의 사용에는 많은 차이점이 있습니다. 여기서는 두 가지의 구현을 논의합니다. 구현 관점에서 볼 때 둘의 내부 코드는 궁극적으로 op_array로 해석되며 실행에는 차이가 없습니다($this/self와 같은 객체별 변경이나 메서드가 사용되지 않는 한).
1. 정의(등록)의 구현입니다. 🎜>
2. 호출의 구현입니다.
정의(등록) 메서드 구현
함수와 메서드는 컴파일 단계에서compiler_globals 변수에 등록되며 둘 다 사용합니다. 동일한 커널 처리 함수 zend_do_begin_function_declaration() 및 zend_do_end_function_declaration()을 사용하여 이 프로세스를 완료합니다. 두 가지의 내부 콘텐츠는 결국 op_codes 배열로 해석되어 저장되지만 컴파일 후 "마운트된" 위치는 아래와 같이 다릅니다.
PHP의 함수 및 메소드 등록 위치
호출 구현 메소드
정의 위치와 성격의 차이로 인해 메소드가 함수보다 더 발전된 것으로 판단됩니다. 확인 작업, 메서드 호출에는
ZEND_INIT_METHOD_CALL , 이라는 OPCODE가 하나 더 있습니다. Execution_data.fbc에 메소드를 등록한 후 동일한 처리 함수
ZEND_DO_FCALL_BY_NAME을 사용하여 처리하면 됩니다.
위 내용은 클래스 및 객체 지향 코드에 대한 PHP 핵심 세부 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!