なぜstd::io::copy
は、リーダとライターの両方の引数を可変参照として渡す必要があるのですか?なぜio :: copyは読み取りと書き込みの両方に可変参照が必要ですか?
私は、書き込まれているデータに対応して内部状態を変更するためにライターを変更する必要がある理由を理解できます。
しかし、なぜ読者も可変参照としてフラグを立てる必要がありますか?私がデータを読んでいるだけなのであれば、私はちょうど特定の型への参照であり、可変参照ではないでしょうか?
なぜstd::io::copy
は、リーダとライターの両方の引数を可変参照として渡す必要があるのですか?なぜio :: copyは読み取りと書き込みの両方に可変参照が必要ですか?
私は、書き込まれているデータに対応して内部状態を変更するためにライターを変更する必要がある理由を理解できます。
しかし、なぜ読者も可変参照としてフラグを立てる必要がありますか?私がデータを読んでいるだけなのであれば、私はちょうど特定の型への参照であり、可変参照ではないでしょうか?
Read
タイプは、一般的にワンショット:それから読むことによって、はです。
標準入力を考慮してください:これは一度しか読み取ることができないので、何かを変更する必要があります。ソケットから読み取った場合、入手したネットワークパケットと、いつでも読み取るデータの量の違いを説明するために使用される内部バッファーを突然変異させることになります。読み込み可能なもの同士をつなぎ合わせるために使用されるChain
からの読み込みはどうですか?突然変異がなければ、読んでいるはずのものを追跡することはできません。
確かに、それは可能が読み取りを実行するために変更可能なアクセスを必要としないRead
タイプを持っているのですが、それは普遍真実ではない、それが普遍的真実ではないので、Read
形質が変更可能なアクセスを要求しています。
これは実際にはっきりとしたクリスタルの説明です。ありがとう! –
'File'でも、現在の読み取りオフセットを更新しています。 –