이전 미니 프로젝트에서 얻은 경험과 교훈을 고려하면 많은 곳이 표준화되어 있지 않고 효율적이지 않습니다. 그래서 PHP를 더 배울 때 더 이상의 우회를 방지하기 위해 인터넷 리소스를 기반으로 PHP 관련 지식을 특정 요약으로 만들었습니다.
PHP는 영어 하이퍼텍스트 전처리 언어인 Hypertext Preprocessor의 약어입니다. PHP는 HTML 문서에 내장되어 서버 측에서 실행되는 스크립트 언어입니다. 언어 스타일은 C 언어와 유사하며 널리 사용됩니다.
PHP의 독특한 구문은 C, Java, Perl 및 PHP 자체 구문을 혼합합니다. CGI나 Perl보다 빠르게 동적 웹 페이지를 실행할 수 있습니다. 다른 프로그래밍 언어와 비교하여 PHP로 만든 동적 페이지는 프로그램을 HTML 문서에 삽입하여 실행하며 HTML 태그를 완전히 생성하는 CGI보다 실행 효율성이 훨씬 높습니다. PHP는 컴파일된 코드도 실행할 수 있으며 컴파일은 암호화를 달성하고 코드를 최적화할 수 있습니다. 실행하면 코드가 더 빠르게 실행됩니다.
PHP 프로그래밍에 대한 몇 가지 요약:
0. 문자열을 포함하려면 큰따옴표 대신 작은따옴표를 사용하세요. 그러면 속도가 더 빨라집니다. PHP는 큰따옴표로 묶인 문자열에서 변수를 검색하기 때문에 작은따옴표는 검색하지 않습니다. 참고: echo만이 이를 수행할 수 있으며, 이는 여러 문자열을 매개변수로 사용할 수 있는 "함수"입니다(주석: PHP 설명서 echo는 다음과 같습니다). 실제 함수가 아닌 언어 구조이므로 함수는 큰따옴표로 묶입니다.
1. 클래스 메소드를 정적으로 정의할 수 있다면 정적으로 정의해 보세요. 속도가 거의 4배 증가합니다.
2. $row['id']는 $row[id]보다 7배 빠릅니다.
3. Echo는 인쇄보다 빠르며 echo $str1, $str2와 같은 문자열 연결 대신 여러 개의 echo 매개변수(주석: 마침표 대신 쉼표를 사용하는 것을 나타냄)를 사용합니다.
4. for 루프를 실행하기 전에 최대 루프 수를 결정합니다. 대신 foreach를 사용하는 것이 가장 좋습니다.
5. 사용하지 않는 변수, 특히 큰 배열을 등록 취소하여 메모리를 확보하세요.
6. __get, __set, __autoload를 사용하지 마세요.
7. require_once()는 비용이 많이 듭니다.
8. 파일을 포함할 때 절대 경로를 사용하십시오. 이렇게 하면 PHP가 include_path에서 파일을 검색하는 속도가 느려지고 운영 체제 경로를 구문 분석하는 데 시간이 덜 걸립니다.
9. 스크립트가 실행되기 시작하는 시간(주석: 서버가 클라이언트 요청을 수신함)을 알고 싶다면 time()보다 $_SERVER['REQUEST_TIME']을 사용하는 것이 좋습니다.
10. 함수는 정규식을 대체하여 동일한 기능을 완성합니다.
11. str_replace 함수는 preg_replace 함수보다 빠르지만 strtr 함수는 str_replace 함수보다 4배 더 효율적입니다.
12. 문자열 대체 함수가 배열이나 문자를 매개변수로 허용할 수 있고 매개변수 길이가 너무 길지 않은 경우 전달된 각 매개변수가 문자가 되도록 추가 대체 코드를 작성하는 것을 고려할 수 있습니다. 코드 줄. 쿼리 및 바꾸기를 위한 매개변수로 배열을 허용합니다.
13. if, else if 문을 여러 개 사용하는 것보다 선택적 분기 문(번역 주석: switch case)을 사용하는 것이 더 좋습니다.
14. @를 사용하여 오류 메시지를 차단하는 것은 매우 비효율적입니다.
15. 웹페이지 탐색 속도를 향상하려면 Apache의 mod_deflate 모듈을 켜세요.
16. 데이터베이스 연결은 사용이 끝나면 종료되어야 합니다.
17. 오류 메시지는 비용이 많이 듭니다.
18. 메소드에서 지역 변수를 증가시키는 것이 가장 빠릅니다. 함수에서 지역 변수를 호출하는 것만큼 빠릅니다.
19. 전역 변수를 증가시키는 것은 지역 변수를 증가시키는 것보다 2배 느립니다.
20. 객체 속성(예: $this->prop++)을 증가시키는 것은 지역 변수를 증가시키는 것보다 3배 느립니다.
21. 정의되지 않은 지역 변수를 증가시키는 것은 미리 정의된 지역 변수를 증가시키는 것보다 9~10배 느립니다.
22. 함수에서 호출하지 않고 지역 변수를 정의하는 것만으로도 속도가 느려집니다(지역 변수를 증가시키는 것과 같은 정도로). PHP는 아마도 전역 변수가 존재하는지 확인할 것입니다.
23. 10개의 메서드를 추가했기 때문에(메서드 테스트 전후 모두) 메서드 호출이 클래스에 정의된 메서드 수와 독립적인 것처럼 보이지만 성능에는 변화가 없었습니다.
24. 파생 클래스의 메서드는 기본 클래스에 정의된 동일한 메서드보다 빠르게 실행됩니다.
25. 하나의 매개변수로 빈 함수를 호출하는 것은 7~8개의 지역 변수 증가 연산을 수행하는 것과 같은 시간이 걸립니다. 유사한 메소드 호출은 15개에 가까운 지역 변수 증분을 필요로 합니다.
26. Apache가 PHP 스크립트를 구문 분석하는 시간은 정적 HTML 페이지를 구문 분석하는 것보다 2~10배 느립니다. 더 많은 정적 HTML 페이지를 사용하고 더 적은 수의 스크립트를 사용해 보십시오.
27. 스크립트를 캐시할 수 없으면 호출될 때마다 다시 컴파일됩니다. PHP 캐싱 메커니즘을 도입하면 일반적으로 성능을 25%~100% 향상하여 컴파일 오버헤드를 제거할 수 있습니다.
28. 최대한 캐시를 시도하고, memcached를 사용할 수 있습니다. Memcached는 동적 웹 애플리케이션을 가속화하고 데이터베이스 부하를 줄이는 데 사용할 수 있는 고성능 메모리 개체 캐싱 시스템입니다. OP 코드 캐싱은 각 요청에 대해 스크립트를 다시 컴파일할 필요가 없도록 유용합니다.
29. 문자열을 연산하고 그 길이가 특정 요구 사항을 충족하는지 확인해야 할 때 자연스럽게 strlen() 함수를 사용하게 됩니다. 이 함수는 계산을 수행하지 않고 zval 구조(PHP 변수를 저장하는 데 사용되는 C의 내장 데이터 구조)에 저장된 알려진 문자열 길이를 반환하기 때문에 매우 빠르게 실행됩니다. 다만, strlen()은 함수이기 때문에 함수 호출이 소문자 등 여러 단계를 거치기 때문에 다소 느릴 것입니다(주석: 소문자 함수 이름을 말하며, PHP는 함수 이름 대문자와 소문자를 구분하지 않습니다 ), 해시 검색, 호출된 함수와 함께 실행됩니다. 어떤 경우에는 isset() 트릭을 사용하여 코드 실행 속도를 높일 수 있습니다.
(아래 예)
if (strlen($foo) < 5) { echo “Foo is too short”$$ }
(다음 기술과 비교)
if (!isset($foo{5})) { echo “Foo is too short”$$ }
isset() 호출은 strlen()보다 빠릅니다. 왜냐하면 후자와 달리 isset()은 언어 구성이라는 의미입니다. 실행에는 함수 조회 및 문자 소문자가 필요하지 않습니다. 즉, 문자열 길이를 확인하는 최상위 코드에서는 실제로 많은 오버헤드를 소비하지 않습니다.
30. 파일 잠금 기능 무리의 상수 매개변수——.
공유 잠금(읽기 작업) - LOCK_SH
배타적 잠금(쓰기 작업) - LOCK_EX
해제 잠금(공유 또는 독점) - LOCK_UN
차단 방지 - —LOCK_NB
fclose() 함수를 통해 잠금 작업을 해제할 수 있습니다.
31. 문자열이 적법한 IP인지 확인하세요.
정규 표현식이 필요하지 않습니다. 적법하면 숫자를 반환하고, 적법하지 않으면 false를 반환합니다. .
32. PHP 5.3부터는 실제 경로(__FILE__) 없이도 __DIR__을 사용하여 현재 스크립트가 있는 디렉터리를 가져올 수 있습니다.
33. 도메인 이름의 존재를 통해 일부 이메일 주소의 유효성을 확인하려면 checkdnsrr()을 사용하세요.
이 내장 기능은 증분을 실행할 때 각 도메인 이름이 IP 주소와 일치하는지 확인할 수 있습니다. 또는 $i 변수를 감소시키면 $i++는 ++$i보다 느려집니다. 이 차이점은 PHP에만 해당되며 다른 언어에는 적용되지 않습니다. 따라서 C 또는 Java 코드를 수정하지 말고 즉시 더 빨라질 것으로 기대하십시오. 작동하지 않습니다. ++$i에는 3개의 명령어(opcode)만 필요하고 $i++에는 4개의 명령어가 필요하므로 더 빠릅니다. 사후 증가는 실제로 이후에 증가되는 임시 변수를 생성합니다. 접두사 증가는 원래 값에서 직접 증가합니다. 이는 Zend의 PHP 최적화 프로그램에서 수행되는 최적화 형태입니다. 모든 명령 최적화 프로그램이 동일한 최적화를 수행하는 것은 아니며 명령 최적화 프로그램을 갖추고 있지 않은 인터넷 서비스 공급자(ISP)와 서버가 많기 때문에 이 최적화를 염두에 두는 것이 좋습니다.
35. 객체 지향(OOP)일 필요는 없습니다. 객체 지향은 종종 비용이 많이 들고 각 메서드와 객체 호출은 많은 메모리를 소비합니다.
36. 모든 데이터 구조를 구현하기 위해 클래스를 사용할 필요는 없으며 배열도 매우 유용합니다.
37. 메소드를 너무 세분화하지 마세요. 실제로 어떤 코드를 재사용할지 신중히 생각해보세요.
38. 필요할 때 언제든지 코드를 메서드로 나눌 수 있습니다.
적절하게 메소드로 분해하세요. 라인 수가 적고 빈도가 높은 메소드의 경우 코드를 직접 작성해 보세요. 이렇게 하면 함수 스택 오버헤드를 줄일 수 있고 메소드 중첩이 너무 깊어서는 안 됩니다. 그렇지 않으면 PHP의 운영 효율성이 크게 영향을 받습니다.
39. PHP 내장 함수를 최대한 많이 사용해 보세요.
40. 코드에 시간이 많이 걸리는 함수가 많은 경우 C 확장을 사용하여 구현하는 것을 고려할 수 있습니다.
41. 코드를 프로파일링하세요. 검사기는 코드의 어느 부분에 시간이 얼마나 걸리는지 알려줍니다. Xdebug 디버거에는 코드의 전반적인 무결성을 평가하고 코드의 병목 현상을 찾아내는 검사 프로그램이 포함되어 있습니다.
42. mod_zip을 Apache 모듈로 사용하여 데이터를 즉시 압축하고 데이터 전송량을 80%까지 줄일 수 있습니다.
43. file, fopen, feof, fgets 및 기타 일련의 메서드 대신 file_get_contents를 사용할 수 있는 경우 훨씬 더 효율적이므로 file_get_contents를 사용해 보세요! file_get_contents는 파일 핸들이 성공적으로 열렸는지 확인할 필요가 없습니다. 하지만 URL 파일을 열 때 file_get_contents의 PHP 버전 문제에 주의하세요.
44. PHP의 파일 작업 효율성은 낮지 않지만, 가능한 경우 Select SQL 문을 최적화하세요. Insert 및 Update 작업을 최대한 적게 수행합니다(업데이트 페이지에서 비판을 받았습니다).
46. PHP 내부 함수를 최대한 사용합니다(그러나 PHP에 없는 함수를 찾는 데 시간을 낭비했습니다. 사용자 정의 함수를 작성하는 것은 경험의 문제입니다!
47. 특히 큰 변수를 선언하지 마십시오. (이것은 PHP에서만 문제가 아닌 것 같습니다.); 다차원 배열의 루프에 중첩 할당을 사용하려면
49. PHP의 내부 문자열 조작 함수를 사용할 수 있으면 정규식을 사용하지 마세요.
50. Foreach가 더 효율적입니다. while 및 for 루프를 사용해 보세요.
51. 문자열을 인용하려면 큰따옴표 대신 작은따옴표를 사용하세요.
52. "i=i+1 대신 i+=1을 사용하세요. 이는 c/C++의 습관을 따르며 더 효율적입니다." 전역 변수의 경우 사용 후 Unset()해야 합니다.
54. 중괄호 "{}"는 "[]"와 같은 문자열을 작동하여 지정된 위치의 문자를 가져옵니다.
55. PHP 태그 "bb9bd6d87db7f8730c53cb084e6b4d2d"는 독립형 PHP 스크립트에서 닫는 태그를 작성할 필요가 없습니다. 이는 실수로 인한 출력 및 보고 오류를 방지하기 위한 것입니다. 주석은 스크립트의 끝을 나타내는 데 사용될 수 있습니다.
56. 에코는 함수가 아니라 문법적 구조입니다. 여러 문자열이 뒤에 오는 경우 쉼표 ","를 사용하는 것이 더 효율적입니다.
57. 배열에서 1, '1', true가 인덱스인 경우 강제로 1로 변환됩니다. 그리고 '01'은 변환되지 않고 문자열로 처리됩니다.
58. 다른 PHP 태그에 클래스 코드를 작성하는 것은 불법이며 구문 오류가 보고됩니다. 기능에는 문제가 없습니다.
59. 세션과 쿠키의 차이점과 관계.
세션은 서버에 저장되고 쿠키는 클라이언트의 브라우저에 저장됩니다.
세션은 하드 드라이브의 파일, 데이터베이스 또는 memcached에 저장될 수 있으며 쿠키는 하드 드라이브에 저장될 수 있습니다. (영구 쿠키) 및 메모리(세션 쿠키)
session_id를 전달하는 방법에는 두 가지가 있는데, 하나는 쿠키이고 다른 하나는 get 메소드입니다(session.name 구성 항목을 통해 session_id를 저장할 변수 이름을 지정할 수 있습니다).
60. 현재 타임스탬프를 얻으려면 time() 대신 $_SERVER['REQUEST_TIME']을 사용하세요. 이렇게 하면 함수 호출을 한 번 줄일 수 있고 더 효율적입니다.
61. _REQUEST를 사용할 때는 주의하세요. 데이터를 얻기 위한 _REQUEST의 우선순위는 E(nv)G(et)P(ost)C(ookie)S(ession)입니다. 우선순위가 높은 데이터에 우선순위가 낮은 데이터를 덮어씁니다.
62. header() 함수 다음에 종료해야 합니다. 그렇지 않으면 후속 코드가 계속 실행됩니다.
63. 메모리 사용량을 줄이기 위해 큰 배열을 참조로 전달하며, 사용 시에는 unset()을 사용합니다.
64. set_time_limit()의 제한 사항. 스크립트 자체의 실행 시간만 제한할 수 있으며 system() 함수, 스트림 작업, 데이터베이스 쿼리 등 외부 실행 시간은 제어할 수 없습니다.
65. echo, print, print_r, var_dump 및 var_export의 차이점:
echo와 print는 함수가 아니라 기본 유형만 표시할 수 있으며 배열 및 객체는 표시할 수 없습니다.
echo는 쉼표로 구분된 여러 변수를 표시할 수 있습니다.
print_r 두 번째 매개변수는 변수를 출력할지 또는 변수를 반환 값으로 사용할지 결정할 수 있습니다.
var_dump는 길이, 유형 등의 변수 정보와 여러 변수를 매개변수로 전달할 수 있습니다.
var_export는 합법적인 PHP 코드 형식을 반환합니다. 66. 확인 이메일: filter_var($email, FILTER_VALIDATE_EMAIL);
67. 파일 확장자를 가져오는 방법:
1. pathinfo($filename), 또는 pathinfo($filename, PATHINFO_EXTENSION) ).
둘, end(explode('.',$filename)). 68. 삼항 연산자(?:)를 사용해 보세요.
69. 잠재적으로 민감한 정보가 사용자에게 표시되지 않도록 하려면 error_reporting(0) 함수를 사용하세요.
이상적으로는 php.ini 파일에서 오류 보고를 완전히 비활성화해야 합니다. 그러나 공유 가상 호스트를 사용하고 있고 php.ini를 수정할 수 없다면 error_reporting(0) 함수를 추가하고 이를 각 스크립트 파일의 첫 번째 줄에 넣는 것이 좋습니다(또는 require_once()를 사용하여 로드합니다).
70. 변수를 임의로 복사하지 마세요.
때때로 PHP 코드를 더 깔끔하게 만들기 위해 일부 PHP 초보자는 미리 정의된 변수를 사용합니다. 이름이 더 짧은 변수를 사용하면 실제로 메모리 소비가 두 배로 늘어나고 프로그램 속도가 느려질 뿐입니다. 다음 예에서 사용자가 텍스트 입력 상자에 512KB의 텍스트를 악의적으로 삽입하면 1MB의 메모리가 소모된다고 상상해 보십시오!
BAD: $description = $_POST['description']; echo $description; GOOD: echo $_POST['description'];
1.在可以用file_get_contents替代file、fopen、feof、fgets等系列方法的情况下,尽量用file_get_contents,因为他的效率高得多!但是要注意file_get_contents在打开一个URL文件时候的PHP版本问题; 2.尽量的少进行文件操作,虽然PHP的文件操作效率也不低的; 3.优化Select SQL语句,在可能的情况下尽量少的进行Insert、Update操作(在update上,我被恶批过); 4.尽可能的使用PHP内部函数(但是我却为了找个PHP里面不存在的函数,浪费了本可以写出一个自定义函数的时间,经验问题啊!); 5.循环内部不要声明变量,尤其是大变量:对象(这好像不只是PHP里面要注意的问题吧?); 6.多维数组尽量不要循环嵌套赋值; 7.在可以用PHP内部字符串操作函数的情况下,不要用正则表达式; 8.foreach效率更高,尽量用foreach代替while和for循环; 9.用单引号替代双引号引用字符串; 10.“用i+=1代替i=i+1。符合c/c++的习惯,效率还高”; 11.对global变量,应该用完就unset()掉; 以下是一篇关于提高PHP效率的文章
榨干 PHP,提高效率
这篇杂文翻译整理自网络各路文档资料(见最末的参考资料),尤其是 Ilia Alshanetsky (佩服之至) 在多个 PHP 会议上的演讲,主要是各类提高 PHP 性能的技巧。为求精准,很多部分都有详细的效率数据,以及对应的版本等等。偷懒,数据就不一一给出了,直接给结论。 ========================================================
静态调用的成员一定要定义成 static (PHP5 ONLY)
贴士:PHP 5 引入了静态成员的概念,作用和 PHP 4 的函数内部静态变量一致,但前者是作为类的成员来使用。静态变量和 Ruby 的类变量(class variable)差不多,所有类的实例共享同一个静态变量。
QUOTE: class foo { function bar() { echo 'foobar'; } } $foo = new foo; // instance way $foo->bar(); // static way foo::bar();
静态地调用非 static 成员,效率会比静态地调用 static 成员慢 50-60%。主要是因为前者会产生 E_STRICT 警告,内部也需要做转换。 ========================================================
使用类常量 (PHP5 ONLY)
贴士:PHP 5 新功能,类似于 C++ 的 const。 使用类常量的好处是: - 编译时解析,没有额外开销 - 杂凑表更小,所以内部查找更快 - 类常量仅存在于特定「命名空间」,所以杂凑名更短 - 代码更干净,使除错更方便 ======================================================== (暂时)不要使用 require/include_once require/include_once 每次被调用的时候都会打开目标文件! - 如果用绝对路径的话,PHP 5.2/6.0 不存在这个问题 - 新版的 APC 缓存系统已经解决这个问题 文件 I/O 增加 => 效率降低如果需要,可以自行检查文件是否已被 require/include。不要调用毫无意义的函数有对应的常量的时候,不要使用函数。
QUOTE: php_uname('s') == PHP_OS; php_version() == PHP_VERSION; php_sapi_name() == PHP_SAPI;
虽然使用不多,但是效率提升大概在 3500% 左右。 最快的 Win32 检查 $is_win = DIRECTORY_SEPARATOR == '\\'; ========================================================
- 不用函数
- Win98/NT/2000/XP/Vista/Longhorn/Shorthorn/Whistler…通用 - 一直可用 时间问题 (PHP>5.1.0 ONLY) 你如何在你的软件中得知现在的时间?简单,「time() time() again, you ask me…」。不过总归会调用函数,慢。现在好了,用 $_SERVER[‘REQUEST_TIME’],不用调用函数,又省了。
加速 PCRE
- 对于不用保存的结果,不用 (),一律用 (?。这样 PHP 不用为符合的内容分配内存,省。效率提升 15% 左右。 - 能不用正则,就不用正则,在分析的时候仔细阅读手册「字符串函数」部分。有没有你漏掉的好用的函数? 例如:
strpbrk() strncasecmp() strpos()/strrpos()/stripos()/strripos()
========================================================
加速 strtr
如果需要转换的全是单个字符的时候,用字符串而不是数组来做
strtr: $addr = strtr($addr, "abcd", "efgh"); // good $addr = strtr($addr, array('a' => 'e' ,//..)); // bad
效率提升:10 倍。 ========================================================
不要做无谓的替换
即使没有替换,str_replace 也会为其参数分配内存。很慢!解决办法: - 用 strpos 先查找(非常快),看是否需要替换,如果需要,再替换 效率: - 如果需要替换:效率几乎相等,差别在 0.1% 左右。 - 如果不需要替换:用 strpos 快 200%。 ========================================================
邪恶的 @ 操作符
不要滥用 @ 操作符。虽然 @ 看上去很简单,但是实际上后台有很多操作。用 @ 比起不用 @,效率差距:3 倍。 特别不要在循环中使用 @,在 5 次循环的测试中,即使是先用 error_reporting(0) 关掉错误,在循环完成后再打开,都比用 @ 快。 ========================================================
善用 strncmp
当需要对比「前 n 个字符」是否一样的时候,用 strncmp/strncasecmp,而不是 substr/strtolower,更不是 PCRE,更千万别提 ereg。strncmp/strncasecmp 效率最高(虽然高得不多)。 慎用 substr_compare (PHP5 ONLY),按照上面的道理,substr_compare 应该比先 substr 再比较快咯。答案是否定的,除非: - 无视大小写的比较 - 比较较大的字符串 不要用常量代替字符串 为什么: - 需要查询杂凑表两次 - 需要把常量名转换为小写(进行第二次查询的时候) - 生成 E_NOTICE 警告 - 会建立临时字符串 效率差别:700%。 ========================================================
不要把 count/strlen/sizeof 放到 for 循环的条件语句中
贴士:一个经典做法
QUOTE: for ($i = 0, $max = count($array);$i < $max; ++$i); ?>
效率提升相对于: - count 50% - strlen 75% ========================================================
短的代码不一定快
// longest if ($a == $b) { $str .= $a; } else { $str .= $b; } // longer if ($a == $b) { $str .= $a; } $str .= $b; // short $str .= ($a == $b ? $a : $b);
你觉得哪个快? 效率比较:
- longest: 4.27 - longer: 4.43 - short: 4.76
不可思议?再来一个:
// original $d = dir('.'); while (($entry = $d->read()) !== false) { if ($entry == '.' || $entry == '..') { continue; } } // versus glob('./*'); // versus (include . and ..) scandir('.');
哪个快? 效率比较: - original: 3.37 - glob: 6.28 - scandir: 3.42 - original without OO: 3.14 - SPL (PHP5): 3.95 画外音:从此也可以看出来 PHP5 的面向对象效率提高了很多,效率已经和纯函数差得不太多了。 ========================================================
提高 PHP 文件访问效率
需要包含其他 PHP 文件的时候,使用完整路径,或者容易转换的相对路径。
include 'file.php'; // bad approach incldue './file.php'; // good include '/path/to/file.php'; // ideal
========================================================
物尽其用
PHP 有很多扩展和函数可用,在实现一个功能的之前,应该看看 PHP 是否有了这个功能?是否有更简单的实现?
$filename = "./somepic.gif"; $handle = fopen($filename, "rb"); $contents = fread($handle, filesize($filename)); fclose($handle); // vs. much simpler file_get_contents('./somepic.gif');
========================================================
关于引用的技巧
引用可以: - 简化对复杂结构数据的访问 - 优化内存使用
$a['b']['c'] = array(); // slow 2 extra hash lookups per access for ($i = 0; $i < 5; ++$i) $a['b']['c'][$i] = $i; // much faster reference based approach $ref =& $a['b']['c']; for ($i = 0; $i < 5; ++$i) $ref[$i] = $i; ?> $a = 'large string'; // memory intensive approach function a($str){ return $str.'something'; } // more efficient solution function a(&$str){ $str .= 'something'; } Aug 25th, 2009 Comments
위 내용은 PHP의 효율성 향상 및 최적화 방법 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!