偶然にも、コードはunsignedshortの最大値の正確な量で失敗するようです。
map<int,vector<string> > backofflist;
for (int k = backofflist.size(); k > 0; k--) // for ($i=$#backofflist;$i>0;$i--)
{
vector<string>::iterator backofflist_iter;
int i = 0;
for (backofflist_iter=backofflist[k].begin();
backofflist_iter!=backofflist[k].end();
backofflist_iter++) // foreach $x (@($backofflist[$i]))
{
cout << i++ << endl;
string x;
try
{
x = *backofflist_iter; //foreach $x (@{$backofflist[$i]})
}
catch (exception &e)
{
cout << e.what() << endl;
exit(1);
}
次の出力を生成します。
...
65532
65533
65534
65535
65536
{segfault}
ベクトルには無制限の容量があると思いましたか?足りないものはありますか?私はこのプログラムをSnowLeopardのXCodeで書いています。