답변:
$i++
가 빨간색 으로 올바르지 않습니다 . 그러나 더 느려 야한다!!
$i++
. 무슨 소리 야? "하지만 속도가 느려 야합니다!"라고 말할 때 당신은 무엇을 비교합니까?
의 차이에 대한주의 사항 한 가지 (int)
와 intval()
: intval()
취급 이미 변수 int
s와 float
(적어도 PHP 5.3.5 기준)에 관계없이 기본 인수, 어떤 변환을 필요로하지 않기 때문에이야. PHP 문서 페이지 의 주석에서 언급하고 여기에 뻔뻔스럽게 반복 된 것처럼이 동작은 가장 분명하지 않습니다 .
$test_int = 12;
$test_string = "12";
$test_float = 12.8;
echo (int) $test_int; // 12
echo (int) $test_string; // 12
echo (int) $test_float; // 12
echo intval($test_int, 8); // 12 <-- WOAH!
echo intval($test_string, 8); // 10
echo intval($test_float, 8) // 12 <-- HUH?
The base parameter has no effect unless the var parameter is a string.
그러면 다시 4 일 전에 페이지가 업데이트되었으므로 추가되었을 수 있습니다.
intval(12,8)
형식이없는 문자열로 변환 할 때 기본 8처럼 보일 것입니다. 숫자가 잘못되었습니다. intval(12,16)
int를 만들 수 없기 때문에 무엇을 기대할 수 c
있습니까?
괴로워서 미안합니다. PHP7 이이 질문에 어떤 영향을 미치는지 확인하고 싶었습니다.
$ php -v
PHP 7.0.4-5+deb.sury.org~trusty+1 (cli) ( NTS )
시험:
php > $start_ts = microtime(true); for($i = 0; $i < 100000000; $i++) { $a = (int) '1'; } var_dump((microtime(true) - $start_ts)*1000 . ' ms');
string(18) "3279.1121006012 ms"
php > $start_ts = microtime(true); for($i = 0; $i < 100000000; $i++) { $a = intval('1'); } var_dump((microtime(true) - $start_ts)*1000 . ' ms');
string(18) "5379.3351650238 ms"
보다시피, 캐스팅은 거의 100 % 빨라졌습니다.
그러나 차이가 몇 초가되기 전에 루프 카운트를 1 억으로 늘려야했는데, 실제로 대부분의 경우 성능에 관심을 갖기 시작했습니다.
intval
캐스팅은 약간의 언어 마술이기 때문에 함수 사용을 고수하겠습니다 . intval
배후에서 캐스팅을 사용 하더라도 캐스팅과 관련된 버그가 발견되고 어떤 이유로 든 수정할 수없는 경우 (이전 버전과의 호환성?) 최소한 intval
의무를 수행하도록 수정할 수 있습니다.
업데이트 (PHP 7.1 + 추가 사례) :
$ php -v
PHP 7.1.0RC6 (cli) (built: Nov 9 2016 04:45:59) ( NTS )
$ php -a
php > $start_ts = microtime(true); for($i = 0; $i < 100000000; $i++) { $a = (int) '1'; } var_dump((microtime(true) - $start_ts)*1000 . ' ms');
string(18) "3583.9052200317 ms"
php > $start_ts = microtime(true); for($i = 0; $i < 100000000; $i++) { $a = intval('1'); } var_dump((microtime(true) - $start_ts)*1000 . ' ms');
string(18) "3569.0960884094 ms"
php > $start_ts = microtime(true); for($i = 0; $i < 100000000; $i++) { $a = '1' + 0; } var_dump((microtime(true) - $start_ts)*1000 . ' ms');
string(18) "1641.7920589447 ms"
7.1 최적화 된 것처럼 보이며 intval
'1'+ 0 이이 스피드 콘테스트의 승자가되었습니다.) intval
어쨌든 계속 사용 하고 있습니다.
+0
는 var입니다 ... 여기의 암시 적 캐스팅이 명시 적 캐스팅보다 빠른지 확실하지 않습니다.
+0
v5.5.34
내 결과는 9191.0059452057 ms
, 23307.397127151 ms
그리고 11483.719110489 ms
각각. 따라서 PHP 7 이전에는 캐스팅이 가장 빠릅니다.
$a = '1' + 0;
생각하지 않았을 것입니다
적어도 하나의 차이점이 있다고 생각합니다. intval을 사용하면 두 번째 매개 변수 (기본적으로 10 진법)로 사용할 기준을 지정할 수 있습니다.
var_dump((int)"0123", intval("0123"), intval("0123", 8));
당신을 얻을 것입니다 :
int 123
int 123
int 83
intval("2g", 17) = 50 = 2*17 + 16
36
과 같습니다 intval("g", 36) //16
. 36보다 큰 값은 0을 반환합니다. 즉, 사용자 지정 기준에 대해 0-9와 az 문자를 모두 사용할 수 있습니다 (예 :) intval("z",36) //35
. 또한 첫 번째 매개 변수는 대소 문자를 구분하지 않습니다 .
유용한 속성 중 하나 intval
는 언어 구조가 아니라 함수이기 때문에 함수를 기대하는 함수에 인수로 전달할 수 있다는 것입니다. 으로이 작업을 수행 할 수 없습니다 (int)
.
예를 들어, 정수를 IN()
전달 하여 SQL 절에 포함시키기 위해 정수를 살균 했습니다 array_map
. 예를 들면 다음과 같습니다.
$ids = implode(",", array_map('intval', $_POST['array_of_integers']));
$sql = "SELECT * FROM table WHERE ids IN ($ids)";
array_map(function($n){return (int)$n;}, $_POST['array_of_integers'])
앰버가 옳고 유용한 정보 유형 캐스팅을 추가하면 (식 앞에 "(int)"추가) intval보다 300 ~ 600 % 빠릅니다. 따라서 귀하의 목적이 소수 이외의 다른 염기를 다루지 않는 경우 다음을 사용하는 것이 좋습니다.
(int) $something