thread-delaylisted
Install: claude install-skill ncaq/konoka
# `threadDelay`
## 乱用を避ける
`threadDelay`はスレッドを指定した時間だけ遅延させる関数です。
`threadDelay`を乱用するのはやめましょう。
時間に依存するコードは安定性や移植性が低いためです。
次の実行でも同じ時間で処理が完了するとは限りません。
他のマシンでは同じ時間で処理が完了しないかもしれません。
また必然的にその時間だけ実行がストップしてしまうので、
待つように命令した分だけ実行が遅くなります。
## 代替手段
別のスレッドの実行を待つ必要がある場合などは、
`TMVar`などの同期変数を使って正確に同期するのが望ましいです。
言語外部のデータやイベントに依存する場合は、
[retry: Retry combinators for monadic actions that may fail](https://hackage.haskell.org/package/retry)
パッケージの`exponentialBackoff`などを使って、
短い単位の繰り返しの待機をしてください。
固定の待機をするよりは実行のストップが短くなることが見込めます。
また最大待機時間の値を固定値より大きくすることが許容できるため、
実行の安定も見込めます。
## 永久的な停止の意図
以下のように意図的に永久的にスレッドを停止する場合は問題ありません。
```haskell
forever $ threadDelay maxBound
```
そのスレッドが持つリソースを、
GCに回収されないように保持するために、
こういった永久的なsleepが必要な時もあります。
## テストコードでの利用
テストコードを書く時に、
ロジックに実行を待つ部分が実装されていない場合などは、
同期変数を組み込むとロジックを複雑にしてしまうことがあるので仕方ない時もあります。
テストコードなら壊れても致命的ではないので許容することもありますが、
やはり他の方法を使えないか検討するべきです。
とりあえずretry系統を使えばだいたいの場合は`threadDelay`を使うよりはマシになるでしょう。