我的for循环中的计数器变量在首次进入循环时被设置为条件的值。我从来没有听说过这种情况,我在一个月前在同一个系统上编写了一个非常相似的代码版本,并且没有这个问题。
这是由64位Windows Vista计算机上的Microsoft Visual Studio 6.0 Visual C ++编译和构建的。我已经注释掉了所有不必要的代码,但它仍然导致了这个错误。删除了所有注释的代码如下:
main.cpp中:
#include "stdafx.h"
using namespace std;
int main(int argc, char* argv[])
{
cout<<"Simple Watch Region Test\n";
cout<<"-----------------------\n";
//get number of tracks
cout<<" Enter Number of Tracks to Run: ";
unsigned int totalNumberOfTracksToRun;
cin>>totalNumberOfTracksToRun;
unsigned short currentTrack = 0;
cout<<"currentTrack starts at "<<currentTrack<<endl;
for( currentTrack; currentTrack < totalNumberOfTracksToRun; currentTrack++);
{
cout<<"current is "<<currentTrack<<endl;
}
return 0;
}
stdafx.h中:
#if !defined(AFX_STDAFX_H__9455C912_1697_486F_A680_AAE1D0B22611__INCLUDED_)
#define AFX_STDAFX_H__9455C912_1697_486F_A680_AAE1D0B22611__INCLUDED_
#if _MSC_VER > 1000
#pragma once
#endif // _MSC_VER > 1000
#include <iostream>
#include <fstream>
#include <math.h>
#include <string>
输出是:
Simple Watch Region Test
-----------------------
Enter Number of Tracks to run: 5
currentTrack starts at 0
current is 5
Press Any Key to continue
感谢您的想法。
答案 0 :(得分:5)
你的for语句末尾有一个分号:
for( currentTrack; currentTrack < totalNumberOfTracksToRun; currentTrack++);
// get rid of this ---^
这意味着for循环运行,什么都不做,直到currentTrack
变为等于totalNumberOfTracksToRun
,然后才执行以下块。这就是currentTrack
似乎立即跳到5的原因。
答案 1 :(得分:4)
你有一个迷路;
:
for( currentTrack; currentTrack < totalNumberOfTracksToRun; currentTrack++);
// |
// here
这意味着for
只会增加currentTrack
,直到它到达totalNumberOfTracksToRun
才会转到下一行。