1. 함수 매개변수를 원하는 만큼 전달하세요.
.NET 또는 JAVA 프로그래밍에서 함수 매개변수의 수는 일반적으로 고정되어 있지만 PHP에서는 매개변수를 원하는 수만큼 사용할 수 있습니다. 다음 예에서는 PHP 함수의 기본 매개변수를 보여줍니다.
1
3 4
|
//두 개의 기본 매개변수가 있는 함수
함수 foo( $arg1 = ”, $arg2 = ”) {
에코 "arg1: $arg1 n";
에코 "arg2: $arg2 n";
}
foo('hello','world');
/* 출력:
arg1: 안녕하세요
arg2: 세계
*/
foo();
/* 출력:
arg1:
arg2:
*/
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 |
//예, 매개변수 목록이 비어 있습니다
함수 foo() {
//수신되는 모든 매개변수의 배열 가져오기
$args = func_get_args();
foreach ( $args as $k => ; $v ) {
echo "arg".( $k +1).": 코드> 코드><code>$v n”;
}
}
foo();
/* 아무것도 출력되지 않습니다 */
foo('안녕하세요');
/* 출력
arg1: 안녕하세요
*/
foo('hello', 'world', '다시');
/* 출력
arg1: 안녕하세요
arg2: 세계
arg3: 다시
*/
|
2. glob()을 사용하여 파일 찾기
대부분의 PHP 함수의 함수 이름은 문자 그대로 그 목적을 이해할 수 있지만, ?glob()을 보면 실제로 어떤 용도로 사용되는지 알 수 없습니다. 실제로 glob() 및 scandir()을 사용하여 검색할 수 있습니다. 파일의 경우 다음 사용법을 참조하세요.
3
4
6 7
10
11
|
//접미사 PHP가 포함된 모든 파일 가져오기
$files = glob ('*.php');
print_r( $files );
/* 출력:
배열
(
[0] => phptest.php
[1] =>pi.php
[2] => post_output.php
[3] => test.php
)
*/
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
//PHP 파일 및 TXT 파일 가져오기
$files = glob ('*.{php,txt}', GLOB_BRACE);
print_r( $files );
/* 출력:
배열
(
[0] => phptest.php
[1] =>pi.php
[2] => post_output.php
[3] => test.php
[4] =>log.txt
[5] => test.txt
)
*/
|
1 2 3 4 5 6 7 8 9 10 |
$files = glob ('../images/a*.jpg');
print_r( $files );
/* 출력:
배열
(
[0] => ../images/apple.jpg
[1] => ../images/art.jpg
)
*/
|
1 2 3 4 5 6 7 8 9 10 11 12 13 |
$files = glob ('../images/a*.jpg');
// 각 배열 요소에 함수를 적용합니다
$files = array_map (' realpath 코드>', $files );
print_r( $files );
/* 출력은 다음과 같습니다:
배열
(
[0] => C:wampwwwimagesapple.jpg
[1] => C:wampwwwimagesart.jpg
)
*/
|
3. 메모리 사용량 정보 얻기
PHP의 메모리 재활용 메커니즘은 이미 매우 강력합니다. PHP 스크립트를 사용하여 현재 메모리 사용량을 얻을 수도 있습니다. memory_get_usage() 함수를 호출하여 현재 메모리 사용량을 얻고, memory_get_peak_usage() 함수를 호출하여 최대 메모리를 얻을 수도 있습니다. 용법. 참조 코드는 다음과 같습니다.
3 4
5
|
echo “초기: “.memory_get_usage().” 바이트 n”;
/* 출력
초기: 361400바이트
*/
//메모리 사용
( $i = 0; $i < 100000; $i ++) { <🎜>
<🎜> $array []= md5( $i ); < 🎜>
<🎜> } <🎜>
<🎜> <🎜>
<🎜>//메모리 절반 삭제 <🎜>
<🎜> ( $i = 0; $i < 100000; $i ++) { <🎜>
<🎜> 설정 해제( $array [ $i ]) ; <🎜>
<🎜> } <🎜>
<🎜> <🎜>
<🎜>echo “최종: “.memory_get_usage().” 바이트 n”; <🎜>
<🎜> /* 인쇄 <🎜>
<🎜> 최종: 885912바이트 <🎜>
<🎜> */ <🎜>
<🎜> <🎜>
<🎜>echo “피크: “.memory_get_peak_usage().” 바이트 n”; <🎜>
<🎜> /* 출력 피크 값 <🎜>
<🎜>최대: 13687072바이트 <🎜>
<🎜> */ <🎜>
<🎜>
|
<🎜>1<🎜> <🎜>2<🎜> <🎜>3<🎜> <🎜>4<🎜> <🎜>5<🎜> <🎜>6<🎜> <🎜>7<🎜> <🎜>8<🎜> <🎜>9<🎜> <🎜>10<🎜> <🎜>11<🎜> <🎜>12<🎜> <🎜>13<🎜> <🎜>14<🎜> <🎜>15<🎜> <🎜>16<🎜> <🎜>17<🎜> <🎜>18<🎜> <🎜>19<🎜> <🎜>20<🎜> <🎜>21<🎜> <🎜>22<🎜> <🎜>23<🎜> <🎜>24<🎜> |
<🎜>
<🎜>print_r( getrusage ()); <🎜>
<🎜> /* 출력 <🎜>
<🎜>배열 <🎜>
<🎜> ( <🎜>
<🎜> [ru_oublock] => 0
[ru_inblock] => 0
[ru_msgsnd] => 2
[ru_msgrcv] =>3
[ru_maxrss] =>12692
[ru_ixrss] =>764
[ru_idrss] =>3864
[ru_minflt] => 94
[ru_majflt] => 0
[ru_nsignals] => 1
[ru_nvcsw] => 67
[ru_nivcsw] => 4
[ru_nswap] => 0
[ru_utime.tv_usec] => 0
[ru_utime.tv_sec] => 0
[ru_stime.tv_usec] =>6269
[ru_stime.tv_sec] => 0
)
*/
|
이 구조는 CPU를 잘 알지 않는 이상 매우 모호해 보입니다. 아래에 몇 가지 설명이 있습니다:
스크립트가 CPU를 얼마나 소비하는지 확인하려면 "사용자 모드 시간"과 "시스템 커널 시간" 값을 살펴봐야 합니다. 초와 마이크로초 부분은 별도로 제공됩니다. 마이크로초 값을 100만으로 나누어 초 값에 더하면 소수 부분으로 초 수를 구할 수 있습니다.
3
4
|
<🎜>
<🎜>// 3초 동안 절전 모드(바쁨 없음) <🎜>
<🎜> 수면(3); <🎜>
<🎜> <🎜>
<🎜>$data = getrusage (); <🎜>
<🎜> echo “사용자 시간: “. <🎜>
<🎜> ( $data [ 'ru_utime.tv_sec' ] + <🎜>
<🎜> $data [ 'ru_utime.tv_usec' ] / 1000000);</code ><🎜>
<🎜><code> echo “시스템 시간: “. <🎜>
<🎜> ( $data [ 'ru_stime.tv_sec' ] + <🎜>
<🎜> $data [ 'ru_stime.tv_usec' ] / 1000000);</code ><🎜>
<🎜> <🎜>
<🎜><code>/* 출력 <🎜>
<🎜>사용자 시간: 0.011552 <🎜>
<🎜> 시스템 시간: 0 <🎜>
<🎜> */ <🎜>
<🎜>
|
<🎜>1<🎜> <🎜>2<🎜> <🎜>3<🎜> <🎜>4<🎜> <🎜>5<🎜> <🎜>6<🎜> <🎜>7<🎜> <🎜>8<🎜> <🎜>9<🎜> <🎜>10<🎜> <🎜>11<🎜> <🎜>12<🎜> <🎜>13<🎜> <🎜>14<🎜> <🎜>15<🎜> <🎜>16<🎜> <🎜>17<🎜> |
<🎜>
<🎜>// 1천만 번 반복(사용 중) <🎜>
<🎜> for ( $i =0; $i <10000000; $i ++) { <🎜>
<🎜> <🎜>
<🎜>} <🎜>
<🎜> <🎜>
<🎜>$data = getrusage (); <🎜>
<🎜> echo “사용자 시간: “. <🎜>
<🎜> ( $data [ 'ru_utime.tv_sec' ] + <🎜>
<🎜> $data [ 'ru_utime.tv_usec' ] / 1000000);</code ><🎜>
<🎜><code> echo “시스템 시간: “. <🎜>
<🎜> ( $data [ 'ru_stime.tv_sec' ] + <🎜>
<🎜> $data [ 'ru_stime.tv_usec' ] / 1000000);</code ><🎜>
<🎜> <🎜>
<🎜><code>/* 출력 <🎜>
<🎜>사용자 시간: 1.424592 <🎜>
<🎜> 시스템 시간: 0.004204 <🎜>
<🎜> */ <🎜>
<🎜>
|
CPU 시간은 약 14초가 소요되었으며, 시스템 호출이 없었기 때문에 거의 모두 사용자 시간이었습니다.
시스템 시간은 CPU가 시스템 호출 시 커널 명령을 실행하는 데 소비한 시간입니다. 예를 들면 다음과 같습니다.
3 4 5 6
7
9 10
|
<🎜>
<🎜>$start = 마이크로타임(true); <🎜>
<🎜> // 약 3초 동안 마이크로타임을 계속 호출 <🎜>
<🎜> while (microtime(true) – $start < 3) { 코드><🎜>
<🎜> <🎜>
<🎜> |
<🎜>1<🎜> <🎜>2<🎜> <🎜>3<🎜> <🎜>4<🎜> <🎜>5<🎜> <🎜>6<🎜> <🎜>7<🎜> |
<🎜>
<🎜>// 로드된 스크립트의 경로에 상대적입니다 <🎜>
<🎜> // 다른 디렉토리에서 스크립트를 실행할 때 문제가 발생할 수 있습니다 <🎜>
<🎜> require_once ('config/database.php'); <🎜>
<🎜> <🎜>
<🎜>// 항상 이 파일의 경로에 상대적입니다 <🎜>
<🎜> // 어디에 포함되었든 상관없음 <🎜>
<🎜> require_once (dirname( __FILE__ ) . '/config/database.php') ; <🎜>
<🎜>
|
<🎜>1<🎜> <🎜>2<🎜> <🎜>3<🎜> <🎜>4<🎜> <🎜>5<🎜> <🎜>6<🎜> <🎜>7<🎜> <🎜>8<🎜> <🎜>9<🎜> <🎜>10<🎜> <🎜>11<🎜> <🎜>12<🎜> <🎜>13<🎜> <🎜>14<🎜> <🎜>15<🎜> <🎜>16<🎜> <🎜>17<🎜> |
<🎜>
<🎜>// 일부 코드 <🎜>
<🎜> // … <🎜>
<🎜>my_debug(“일부 디버그 메시지”, __LINE__ ); <🎜>
<🎜> /* 출력 <🎜>
<🎜>4행: 일부 디버그 메시지 <🎜>
<🎜> */ <🎜>
<🎜> <🎜>
<🎜>// 추가 코드 <🎜>
<🎜> // … <🎜>
<🎜>my_debug(“또 다른 디버그 메시지”, __LINE__ ); <🎜>
<🎜> /* 출력 <🎜>
<🎜>11행: 또 다른 디버그 메시지 <🎜>
<🎜> */ <🎜>
<🎜> <🎜>
<🎜>함수 my_debug( $msg , $line ) { <🎜>
<🎜> echo “라인 $line : $msg< /code><code>n”; <🎜>
<🎜> } <🎜>
<🎜>
|
6. 고유 ID 생성
많은 친구들이 md5()를 사용하여 고유한 숫자를 생성하지만 md5()에는 몇 가지 단점이 있습니다. 1. 혼란으로 인해 데이터베이스 정렬 성능이 저하됩니다. 2. 너무 길어서 더 많은 저장 공간이 필요합니다. 실제로 PHP에는 고유 ID를 생성하는 함수가 있습니다. 이 함수는 uniqid()입니다. 사용 방법은 다음과 같습니다.
3
4
6 7 8
|
// 고유 문자열 생성
echo uniqid();
/* 출력
4bd67c947233e
*/
// 또 다른 고유 문자열 생성
echo uniqid();
/* 출력
4bd67c9472340
*/
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |
// 접두어
echo uniqid('foo_');
/* 출력
foo_4bd67d6cd8b8f
*/
// 엔트로피 증가
echo uniqid(”,true);
/* 출력
4bd67d6cd8b926.12135106
*/
//전체
echo uniqid('bar_',true);
/* 출력
bar_4bd67da367b650.43684647
*/
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 |
//복잡한 배열
$myvar = 배열 (
'안녕하세요',
42,
배열 (1,'two'),
'사과'
);
//직렬화
$string = serialize( $myvar );
에코 $string ;
/* 출력
a:4:{i:0;s:5:"안녕하세요";i:1;i:42;i:2;a:2:{i:0;i:1;i: 1;s:3:"two";}i:3;s:5:"apple";}
*/
//역직렬화
$newvar = unserialize( $string );
print_r( $newvar );
/* 출력
배열
(
[0] => 안녕하세요
[1] => 42
[2] => 배열
(
[0] =>1
[1] => 두 개
)
[3] =>사과
)
*/
|
json 형식으로 직렬화하는 방법은 걱정하지 마세요. PHP 5.2 이상을 사용하는 사용자는 json_encode() 및 json_decode() 함수를 사용하여 json 형식을 직렬화할 수 있습니다. :
|
//복잡한 배열
$myvar = 배열 (
'안녕하세요',
42,
배열 (1,'two'),
'사과'
);
// 문자열로 변환
$string = json_encode( $myvar );
에코 $string ;
/* 인쇄
["hello",42,[1,"two"],"apple"]
*/
//원래 변수를 재현할 수 있습니다
$newvar = json_decode( $string );
print_r( $newvar );
/* 인쇄
배열
(
[0] => 안녕하세요
[1] => 42
[2] => 배열
(
[0] =>1
[1] => 두 개
)
[3] =>사과
)
*/
|
8. 문자열 압축
압축이라고 하면 파일 압축을 떠올릴 수도 있습니다. 사실 문자열도 압축할 수 있습니다. PHP는 ?gzcompress() 및 gzuncompress() 함수를 제공합니다.
3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 |
$string =
“Lorem ipsum dolor sit amet, consectetur
adipiscing elit. Nunc ut elit id mi ultricies
Adipiscing.Praesent pulvinar,
sapien vel feugiat 현관, nulla dui pretium orci,
non ultricies elit lacus quis ante. Lorem ipsum dolor
sit amet, consectetur adipiscing elit.
Pretium ullamcorper urna quis iaculis.Etiam ac Massa
sed turpis tempor luctus. Curabitur sed nibh eu elit
mollis congue. Praesent ipsum diam, consectetur vitae
ornare a, aliquam a nunc. In id magna pellentesque
tellus posuere adipiscing. Sed non mi metus, at lacinia
ague. Sed magna nisi, ornare in mollis in, mollis
sed nunc. Etiam at justo in leo congue mollis.
Nullam in neque eget metus hendrerit scelerisque
eu non enim. Ut Malesuada lacus eu nulla bibendum
id euismod urna sodales “;
$compressed = gzcompress( $string );
echo “원본 크기: “. strlen ( $string ).”n”;
/* 출력 원본 크기
원본 크기: 800
*/
echo “압축 크기: “. strlen ( $compressed )."n";
/* 압축된 크기를 출력
압축 크기: 418
*/
//압축해제
$original = gzuncompress( $compressed );
|