2019年6月9日日曜日

php の文字列は、シングルクォートとダブルクオートでどれだけパフォーマンスに差があるのか。

php の文字列は、シングルクォートとダブルクオートでどれだけパフォーマンスに差があるのか。
6:09 by Jumpei Tanaka

背景

どんなライブラリを見ても、php の文字列はだいたいシングルクォートで定義されている。パフォーマンスに差があるのはわかるが、変数を入れ込みたいときに面倒になる。

'{$hoge}' と書いて実行して、間違いに気づきあとで "{$hoge}" に変更する... という作業を何度やったことか。個人的には "" で統一したい派なので実際にどれぐらいの差があるか測定してみたかった。

調べてみると

測定しているサイトがあった。なるほど大して変わらないらしい。
ただちょっと記事が古い。php は 7 で大分変ったので手法はそのまま使わせていただき実測してみることに

php のシングルクォートはほんとうに早いのか
http://takuya-1st.hatenablog.jp/entry/2013/09/10/221859

実測

コードは参考サイトから拝借させていただき、まんま同じコードを流します。

foreach (range(1,1000*1000) as $cnt ) {
    $str = '人は「考え方」を手に入れたとたん頭のよくなる生き物である';
}

結果がこれ。シングルクォート版は 46.3441ms


ダブルクオート版を流します。
foreach (range(1,1000*1000) as $cnt ) {
    $str = "人は「考え方」を手に入れたとたん頭のよくなる生き物である";
}

結果がこれ。ダブルクオート版は 49.5017ms

その差 3.1576ms 。
ちなみに、これは「シングルクォート版」と「ダブルクオート版」を交互に実行して、一番それっぽく差が出た数値を採用しました。
どういう事かというと、同じダブルクオート版を実行しただけでも誤差の範囲でこれぐらいのブレがあります。

  • 49.01ms
  • 47.0376ms
  • 50.2956ms
シングルクォート版だけでも、これぐらいのブレがでます。
  • 48.038ms
  • 49.675ms
  • 49.3508ms

1回1回の差分を見ると、1-2ms あるかないかぐらいですね。その程度ということです。
その程度のことにまでくまなく神経を行き届かせるのが我々の仕事ですが、何を重視するかの方針次第だと思いました。私は面倒くさがりなので全部 " に統一したい派です。

文字列結合バージョン

ちなみに文字列結合バージョンはこんな感じの結果でした。
foreach (range(1,1000*1000) as $cnt ) {
    $str = "人は「考え方」を手に入れたとたん頭のよくなる生き物である{$cnt}";
}
  • 84.2508ms
  • 85.6132ms
  • 80.1787ms
foreach (range(1,1000*1000) as $cnt ) {
    $str = "人は「考え方」を手に入れたとたん頭のよくなる生き物である".$cnt;
}
  • 84.6025ms
  • 81.3242ms
  • 80.8663ms

うーん、ほとんど変わりがありません。

実行環境

Windows10 の php 7.3.5 でした。


以上。

2019年6月2日日曜日

Windows 10 の 検索BOXが真っ白になったら…

Windows 10 の 検索BOXが真っ白になったら…
2:28 by Jumpei Tanaka

ある日突然、Windows 10 の検索 BOX が真っ白になりました。
「ここに入力して検索」と書いてあるやつですね。


こんな状態になってしまいました。

調べてみると、コマンドを打てとかインデックスを再構築しろとかレジストリを、、、とか、おそらく現象が微妙にことなる問題の解決策が混じって面倒だったので、画像と共に記録しておきます。

はいそうです。Crotana を強制終了したら治りました。

何度も再起動しても治らなかったのに、タスクの終了で治りました。
そう、Windows10 の再起動はこちらが思うような再起動をしてくれません。
Windows10 は基本好きですが、再起動周りだけは好きになれません。

以上。