こんにちは、私は誰かが以下のコードのこの振る舞いを理解するのを手伝ってくれることを望んでいました。
#include <iostream>
#include <algorithm>
#include <string>
#include <limits>
#include <fstream>
#include <iterator>
#include <stdexcept>
struct asound_stanza
{
unsigned index;
std::string name;
friend std::istream &operator>>(std::istream &is, asound_stanza &stan)
{
is >> stan.index;
if(!is.good())
return is;
std::getline(is, stan.name);
std::string::const_iterator
eol = stan.name.cend(),
start = std::find(stan.name.cbegin(), eol, '['),
end = std::find(start, eol, ' ');
stan.name = std::string(++start, end);
is.ignore(std::numeric_limits<std::streamsize>::max(), '\n');
// std::istream_iterator<char> it;
// while(*it++!=0x0a);
return is;
}
};
int main()
{
std::ifstream is("/proc/asound/cards", std::ifstream::in);
std::istream_iterator<asound_stanza> it(is), end;
unsigned devid = 0;
std::for_each(it, end, [&](const asound_stanza &stan)->void{
if(stan.name!="CODEC")
return;
devid = stan.index;
});
std::cout << devid;
return 0;
}
これは機能しますが、いくつか質問があります。すべての有効な反復が行われた後、それは頭に行き、必然的に失敗する別の反復を解析しようとします(したがってif(!is.good())...
_)。解析を試みますが、最終的な不正な構造体をラムダ式に渡すことはありません。なんでそうじゃないの?ストリームがgood()ではないので、わざわざそれを渡そうとしないからですか?
また、最終的な構造体をわざわざ解析しようとしないようにするにはどうすればよいですか(各スタンザは改行(0x0a)で終わるので、改行までストリームを無視すると、最後の有効な反復でEOFが発生すると思いましたしかし、そうではありません。
ご指導ありがとうございます。
また、別のコーディングの正しさのコメントを自由に渡してください。
PS:私のファイルはこのように見えます
0 [Intel ]: HDA-Intel - HDA Intel
HDA Intel at 0xfc500000 irq 46
1 [HDMI ]: HDA-Intel - HDA ATI HDMI
HDA ATI HDMI at 0xfc010000 irq 47
2 [CODEC ]: USB-Audio - USB Audio CODEC
Burr-Brown from TI USB Audio CODEC at usb-0000:00:1d.7-3.1, full speed