PHP 최적화의 목적은 가장 빠른 실행 속도와 가장 쉬운 코드 유지 관리를 위해 최소한의 비용을 지출하는 것입니다. 이 문서에서는 포괄적인 최적화 기술을 제공합니다.
1. 에코는 인쇄보다 빠릅니다.
2. 문자열 연결 대신 echo의 다중 매개변수를 사용합니다.
3. for 루프를 실행하기 전에 최대 루프 수를 결정합니다. 매 루프마다 최대값을 계산하지 말고 대신 foreach를 사용하는 것이 가장 좋습니다.
4. 전역 변수의 경우 사용 후 unset()해야 합니다.
5. 문자열을 포함하려면 큰따옴표 대신 작은따옴표를 사용하세요. PHP는 큰따옴표로 묶인 문자열에서 변수를 검색하기 때문에 작은따옴표는 검색하지 않습니다.
6. 함수는 정규식을 대체하여 동일한 기능을 완성합니다.
7. 변수 $i의 증가 또는 감소를 실행할 때 $i++는 ++$i보다 느립니다. 이 차이점은 PHP에만 해당되며 다른 언어에는 적용되지 않습니다. ++$i에는 3개의 명령어(opcode)만 필요하고 $i++에는 4개의 명령어가 필요하므로 더 빠릅니다. 사후 증가는 실제로 이후에 증가되는 임시 변수를 생성합니다. 접두사 증가는 원래 값에서 직접 증가합니다.
8. if, else if 문을 여러 개 사용하는 것보다 switch case를 사용하는 것이 좋습니다.
9. var_dump를 사용하여 PHP 코드를 디버깅합니다. PHP 디버깅 기술을 찾고 있다면 var_dump가 여러분이 찾고 있는 목표라고 말하고 싶습니다. 이 명령은 PHP 정보 표시 측면에서 모든 요구 사항을 충족할 수 있으며 대부분의 디버깅 코드 사례는 값을 얻는 것과 관련이 있습니다. PHP에서.
10. 파일을 포함할 때 전체 경로를 사용하면 운영 체제 경로를 구문 분석하는 데 시간이 덜 걸립니다.
11. 매 순간 글로벌 가치를 창출하는 것은 나쁜 습관이지만 때로는 실제 상황에서 이것이 필요할 때도 있습니다. 데이터베이스 테이블이나 데이터베이스 연결 정보에 전역 값을 사용하는 것은 좋지만, PHP 코드에서는 전역 값을 자주 사용하지 않는 것이 좋습니다. 또는 더 나은 접근 방식은 전역 변수를 config.php 파일에 저장하는 것입니다.
12. 스크립트가 실행되기 시작하는 시간을 알고 싶다면 time() 대신 $_SERVER['REQUEST_TIME']을 사용하는 것이 좋습니다.
13. Apache의 mod_deflate 모듈을 엽니다.
14. @를 사용하여 오류 메시지를 차단하는 것은 매우 비효율적입니다.
15. PHP 내장 함수를 많이 사용해 보세요.
16. 정의되지 않은 지역 변수를 증가시키는 것은 미리 정의된 지역 변수를 증가시키는 것보다 9~10배 느립니다.
17. 파생 클래스의 메서드는 기본 클래스에 정의된 동일한 메서드보다 빠르게 실행됩니다.
18. 함수에서 호출하지 않고 로컬 변수를 정의하는 것만으로도 속도가 느려집니다(로컬 변수를 증가시키는 것과 같은 정도).
19. Apache는 PHP 스크립트를 구문 분석합니다. 시간은 정적 HTML 페이지를 구문 분석하는 것보다 2~10배 느립니다. 더 많은 정적 HTML 페이지를 사용하고 더 적은 수의 스크립트를 사용해 보십시오.
20. 앞서 언급했듯이 PHP 웹사이트에서 가장 중요한 부분은 데이터베이스일 가능성이 99%입니다. 따라서 SQL을 올바르게 사용하는 방법에 대해 잘 알고 관계형 테이블과 고급 데이터베이스 기술을 배워야 합니다.
21. 하나의 매개변수로 빈 함수를 호출하는 것은 7~8개의 지역 변수 증가 연산을 수행하는 것과 동일한 시간이 걸립니다.
22. 문자열을 연산하고 그 길이가 특정 요구 사항을 충족하는지 확인해야 할 때 자연스럽게 strlen() 함수를 사용하게 됩니다. 이 함수는 계산을 수행하지 않고 zval 구조(PHP 변수를 저장하는 데 사용되는 C의 내장 데이터 구조)에 저장된 알려진 문자열 길이를 반환하기 때문에 매우 빠르게 실행됩니다.
23. 모든 상황에서 객체 지향 개발을 사용해야 하는 것은 아닙니다. 객체 지향 개발은 비용이 많이 들고 각 메서드와 객체 호출이 많은 메모리를 소비합니다.
24. 스크립트를 캐시할 수 없으면 호출될 때마다 다시 컴파일됩니다. PHP 캐싱 메커니즘을 도입하면 일반적으로 성능을 25%~100% 향상하여 컴파일 오버헤드를 제거할 수 있습니다.