开发者

XCode 4 only displaying cout statements with endl

I have a really weird issue with my cout statements. I've only tried this out with XCode 4. For instance, if I write,

cout << "this works" << endl;
cout << "this doesnt";
cout << memorySizeLimit << " blocks of memory available." << endl;

I see all three output statements in my debugger console. However, if I change the order to,

cout << memorySizeLimit << " blocks of memory available." << endl;
cout << "this wo开发者_如何转开发rks" << endl;
cout << "this doesn't";

I only see the first two couts. Even stranger, if I change the code to,

cout << memorySizeLimit << " blocks of memory available." << endl;
cout << "this works" << endl;
cout << "this doesn't" << endl;

I see all three statements.

Why would I not see that "this doesn't" cout statement when I change its position?


std::cout is an stream and normally it is buffered for performance. If you print endl the stream gets flushed (cout << endl is the same as cout << "\n" << flush.

You may flush the stream manually by cout << flush (or cout.flush()).

So that should print:

cout << "this doesn't" << flush;
0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜