何故readdir()は返り値を明示的にFALSEと一致することを調べなければならないのか?

 指定したディレクトリのファイル一覧を取得する readdir() ですが、ファイル名を取得する while ループの条件判定で返り値が FALSE ではないことを、明確に調べなければなりません。「0(ゼロ)」や空文字を返す可能性があるということです。

実験

 「target」というフォルダを作り、中に次のようなフォルダ・ファイルを作成します。

20150611_1

以下のソースコードを test.php で PHP が動作する環境に保存し、同じフォルダに先ほどの「target」フォルダを保存します。

うまく動作しないです。これは、「0(ゼロ)」という名前のフォルダがあるためです。

20150611_2

while 文の判定式を PHP のマニュアルにあるように変更します。

実行結果は次のとおり。

20150611_3

ちゃんと動作します。

 言語のマニュアルや仕様書をよく読んでからソースコードを書かないと、こういうところがバグの原因になるんでしょうね。気をつけねばなりません。

応用

 readdir() が返す値には「.」と「..」が含まれますが、これを取り除く場合が多いようです。先ほどのソースにこの処理を追加すると、

実行結果です。

20150611_4

更に、フォルダは除外したい場合は if 文にフォルダを除外する処理を追加します。

実行結果です。

20150611_5

地味に間違う「!==」と「!=」

 ファイル名を取得する while ループの条件判定は、値が等しいだけでなく型も等しいかを調べる厳密な比較 (===) であることに注意してください。今回の判定式の場合、「!==」である必要があります。次のソースコードを実行すると、

20150611_6

という予期しない結果になってしまいます。これは文字列と「TRUE」を緩やかに比較するとTRUEが返されるからだと思われます。詳しい話は「緩やかな比較 (==) と厳密な比較 (===) の違い | PHP プログラミング解説」にあります。

「役に立った」と思ったら、記事のシェアをお願いします。

スポンサーリンク

Comment

コメント認証制です。反映されるまで時間が掛かる場合があります。
URLの記入はhttpのhを抜いて下さい(宣伝対策です)。
連続でコメントするとスパム扱いになる場合があります。
しばらく待ってからコメントしてください。


Warning: imagepng(/home/ogr25h81pde7/naokixtechnology.net/public_html/wordpress/wp-content/plugins/siteguard/really-simple-captcha/tmp/1325618380.png): failed to open stream: Permission denied in /home/ogr25h81pde7/naokixtechnology.net/public_html/wordpress/wp-content/plugins/siteguard/really-simple-captcha/siteguard-really-simple-captcha.php on line 221

Warning: Use of undefined constant __FILENAME__ - assumed '__FILENAME__' (this will throw an Error in a future version of PHP) in /home/ogr25h81pde7/naokixtechnology.net/public_html/wordpress/wp-content/plugins/siteguard/really-simple-captcha/siteguard-really-simple-captcha.php on line 254

CAPTCHA


TOP