- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在这里寻求一些帮助来理解加速 C++ 中提出的一些概念。这是我遇到问题的地方。
vector<Student_info> students; //Student_info is a structure we made
Student_info record;
string::size_type maxlen = 0;
// read and store all the records, and find the length of the longest name
while (read(cin, record)) { //Here is where I find hard to follow
maxlen = max(maxlen, record.name.size());
students.push_back(record);
}
read()的定义:
istream& read(istream& is, Student_info& s)
{
// read and store the student's name and midterm and final exam grades
is >> s.name >> s.midterm >> s.final;
read_hw(is, s.homework); // read and store all the student's homework grades
return is;
}
read_hw()的定义:
// read homework grades from an input stream into a vector<double>
istream& read_hw(istream& in, vector<double>& hw)
{
if (in) {
// get rid of previous contents
hw.clear() ;
// read homework grades
double x;
while (in >> x)
hw.push_back(x);
// clear the stream so that input will work for the next student
in.clear();
}
return in;
}
目前我的理解是,当我们调用:while (read(cin,record))
时,我们要求一个字符串:record.name
,并且两个 double
值:record.midterm
和 record.final
。在我们的用户输入该数据后,我们将进入我们的 read_hw()
函数,我们将在其中清除 vector 中可能存在的任何先前元素。然后我们将一系列值输入并记录到一个名为 record.homework
的家庭作业成绩 vector 中。我想我明白了这么多。如果没有,请告诉我。
我不明白我们的函数如何知道何时返回,并因此返回到我们的第一个 while
循环。编辑:啊,用户必须发出两次文件结束通知才能结束程序。所以我想我回答了我自己的问题......但是有人能够在我们的 read_hw()
函数中解释 if(in)
的目的吗,那将是非常有帮助。它将是if(cin)
,那么这是在等待我们的用户输入数据吗?还是 if(cin)
自动为真? (为什么?)
最佳答案
No if(cin)
不会等待 - 它会检查错误。只有运算符 >> 等待输入。在这种情况下,while(in >> x)
执行读取和等待。它在 while 循环条件内的原因是因为在 in >> x
完成后它返回对 in 的引用,它被隐式转换为 bool,用于发出错误信号,如 如果(cin)
。
在这两种情况下,如果没有错误,cin 将为真,如果有错误,则为假。
This可以更好地了解正在发生的事情,但可能并不欢迎。基本上,无论何时将 istream 视为 bool 值,如果没有错误则为 true,如果有错误则为 false。
基本上,istream(称之为 foo)到 bool 的转换总是 !foo.fail()。所以它与 fail() 相反。这意味着有两种方法可以实现(直接来自表 here :
所以文件末尾根本没有被覆盖。必须使用 eof() 或类似方法进行检查。
如果 istream 结果为假,您可以使用 bad() 区分 1 和 2。如果 bad 为真则为情况 2,如果 bad() 为假则为情况 1。(还有其他方法,请查看 rdstate())
关于c++ - if(cin) 的目的?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20961994/
我使用 cin.peek() 方法获得了这段代码。我注意到奇怪的行为,当程序输入看起来像 qwertyu$[Enter] 时,一切正常,但是当它看起来像 qwerty[Enter]$ 时,它仅在我键入
#include #include using namespace std; int main(){ ofstream fout("student.dat",ios::out); char name[
我是 C++ 编程新手,遇到了障碍。这是我的代码: #include using namespace std; int main(){ int sum = 0, a; cout >
我有一个简单的程序,当输入完全符合预期时,它名义上可以工作。 #include using namespace std; int main () { int a, b; char a
int main () { int num1, num2; int cnt = 1; if (cin >> num1){ while (cin >> num2){
我有这个程序,但 cin 随机跳过..我的意思是有时它会,有时它不会。有什么解决办法吗? int main(){ /** get course name, number of
我是一名正在准备期末考试的 C++ 初学者。我用两种方式写了一个程序。第一个代码使用 cin.getline() 并且不能正常工作。第二个代码使用 cin.get() 和 cin >> 并正确执行所有
据我所知,在 cin 之后使用 getline() 时,我们需要先刷新缓冲区中的换行符,然后再调用 getline(),我们通过调用 cin.ignore() 来完成此操作。 std::string
我正在尝试以下代码: int main() { char str1[20]; int a; cout > a; cout > 忽略空格(即 ' ', '\t', '\n
我刚开始阅读 C++ 11 入门书,目前在 if 语句部分。我以前有使用 Java 的经验,但 C++ 输入/输出确实让我感到困惑。为了方便起见,我将多个练习放在一个文件中。但是,似乎自从我调用了 w
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: c++ cin input not working? 我一直在尝试使用以下 C++ 代码在整数后输入字符串。
需要 I/O 重定向,我不能使用 fstream。我用 I/O通过使用 ">line)通过 I/O 读取文件重定向。然后我需要 cin>>x ,但这次是在运行时进行用户输入,但会被跳过。 我试过了 c
我正在尝试使用 getline() 但在输入第一个记录光标后不要等待第二个国家/地区名称,它会跳过并跳转到首都名称。我的错误在哪里。如果我输入 国家:印度 首都:德里 Capita:57382 它可以
我有以下循环。它应该读取数字直到 EndOfFile,或者用户输入 -999 int arr[100]; int index; for (index = 0; index > arr[index];
以下两个循环和每个循环什么时候停止有什么区别? #include #include #include using namespace std; int main() { int x,y;
在这个程序的每次输入中,我希望用户能够输入他们想要的任意数量的“单词”(意思是用空格/制表符分隔的文本)......但是不允许用户输入单词超出当前 cin。例如:如果我键入 John Smith Do
int main() { int oddeven = 1; int modulotwo; // Simple loop since no reason to check 0
我写了一个 switch 语句,并创建了一个默认值,它会简单地说用户选择了一个错误的选项并重复输入。我想确保如果出现问题,它会首先清除缓冲区,所以我使用了 cin.sync(),但输入 'a' 仍然会
我是一个新手程序员,正在练习下面的这个程序。无论出于何种原因,在我的程序结束时,cin.ignore() 被编译器完全跳过并直接移动到 cin.get(),但是之前已经有一个按键,所以编译器完全跳过它
关闭。这个问题需要debugging details .它目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and th
我是一名优秀的程序员,十分优秀!