কোনটি আসলে খুব দ্রুত ছিল তা দেখার জন্য আমি কৌতূহল ছিলাম তাই সেই ফাংশনগুলি বেনমার্ক করার জন্য আমি একটি সাধারণ স্ক্রিপ্ট তৈরি করেছিলাম।
<?php
function benchmark($name, $iterations, $action){
$time=microtime(true);
for($i=0;$i<=$iterations;++$i){
$action();
}
echo $name . ' ' . round(microtime(true)-$time, 6) . "\n";
}
$iterations = 1000000;
$x = array();
$y = range(0, 10000000);
$actions = array(
"Empty empty()" => function() use($x){
empty($x);
},
"Empty count()" => function() use($x){
count($x);
},
"Full empty()" => function() use($y){
empty($y);
},
"Full count()" => function() use($y){
count($y);
},
"IF empty empty()" => function() use($x){
if(empty($x)){ $t=1; }
},
"IF empty count()" => function() use($x){
if(count($x)){ $t=1; }
},
"IF full empty()" => function() use($y){
if(empty($y)){ $t=1; }
},
"IF full count()" => function() use($y){
if(count($y)){ $t=1; }
},
"OR empty empty()" => function() use($x){
empty($x) OR $t=1;
},
"OR empty count()" => function() use($x){
count($x) OR $t=1;
},
"OR full empty()" => function() use($y){
empty($y) OR $t=1;
},
"OR full count()" => function() use($y){
count($y) OR $t=1;
},
"IF/ELSE empty empty()" => function() use($x){
if(empty($x)){ $t=1; } else { $t=2; }
},
"IF/ELSE empty count()" => function() use($x){
if(count($x)){ $t=1; } else { $t=2; }
},
"IF/ELSE full empty()" => function() use($y){
if(empty($y)){ $t=1; } else { $t=2; }
},
"IF/ELSE full count()" => function() use($y){
if(count($y)){ $t=1; } else { $t=2; }
},
"( ? : ) empty empty()" => function() use($x){
$t = (empty($x) ? 1 : 2);
},
"( ? : ) empty count()" => function() use($x){
$t = (count($x) ? 1 : 2);
},
"( ? : ) full empty()" => function() use($y){
$t = (empty($y) ? 1 : 2);
},
"( ? : ) full count()" => function() use($y){
$t = (count($y) ? 1 : 2);
}
);
foreach($actions as $name => $action){
benchmark($name, $iterations, $action);
}
যেহেতু আমি এটি করছি তখন আমি কার্য সম্পাদনকারী ক্রিয়াকলাপগুলি পরীক্ষা করার চেষ্টা করেছি যা সাধারণত গণনা () / খালি () এর সাথে যুক্ত হবে
পিএইচপি 5.4.39 ব্যবহার:
Empty empty() 0.118691
Empty count() 0.218974
Full empty() 0.133747
Full count() 0.216424
IF empty empty() 0.166474
IF empty count() 0.235922
IF full empty() 0.120642
IF full count() 0.248273
OR empty empty() 0.123875
OR empty count() 0.258665
OR full empty() 0.157839
OR full count() 0.224869
IF/ELSE empty empty() 0.167004
IF/ELSE empty count() 0.263351
IF/ELSE full empty() 0.145794
IF/ELSE full count() 0.248425
( ? : ) empty empty() 0.169487
( ? : ) empty count() 0.265701
( ? : ) full empty() 0.149847
( ? : ) full count() 0.252891
হিপহপ ভিএম 3.6.1 (ডিবিজি) ব্যবহার করে
Empty empty() 0.210652
Empty count() 0.212123
Full empty() 0.206016
Full count() 0.204722
IF empty empty() 0.227852
IF empty count() 0.219821
IF full empty() 0.220823
IF full count() 0.221397
OR empty empty() 0.218813
OR empty count() 0.220105
OR full empty() 0.229118
OR full count() 0.221787
IF/ELSE empty empty() 0.221499
IF/ELSE empty count() 0.221274
IF/ELSE full empty() 0.221879
IF/ELSE full count() 0.228737
( ? : ) empty empty() 0.224143
( ? : ) empty count() 0.222459
( ? : ) full empty() 0.221606
( ? : ) full count() 0.231288
আপনি যদি পিএইচপি ব্যবহার করছেন তবে উপসংহার:
খালি () খালি এবং জনবহুল অ্যারে সহ উভয় পরিস্থিতিতে গণনার () চেয়ে অনেক বেশি দ্রুত
গণনা () সম্পূর্ণ বা খালি অ্যারে দিয়ে একই সম্পাদন করে।
একটি সাধারণ আইএফ বা কেবল একটি বুলিয়ান অপারেশন একই কাজ।
আইএফ / ইএলএসই (?:) এর চেয়ে খুব সামান্য দক্ষ। আপনি যদি মাঝখানে প্রকাশের সাথে কোটি কোটি পুনরাবৃত্তি না করেন এটি সম্পূর্ণ তুচ্ছ।
আপনি যদি এইচএইচভিএম ব্যবহার করেন তবে সিদ্ধান্ত:
খালি () গণনার তুলনায় এক কিশোর-মজাদার কিছুটা দ্রুত () তবে তুচ্ছ এটি।
[বাকিগুলি পিএইচপি-র মতোই]
উপসংহারের উপসংহারে, আপনার অ্যারেটি খালি কিনা তা যদি কেবল জানতে হয় তবে খালি () ব্যবহার করুন;
এটি কেবল একটি কৌতূহলী পরীক্ষা ছিল যা অনেকগুলি বিষয় বিবেচনায় না নিয়েই করা হয়েছিল। এটি ধারণার একটি প্রমাণ এবং এটি উত্পাদন অপারেশন প্রতিবিম্বিত নাও হতে পারে।