while循环为什么会多循环一次?

shiguojie19892 飞思迈尔 闲杂人等  2013-01-25 08:40:13
代码如下:
//坐标转换
while( 2 <= id) //如果大于等于2,调用WordCoordinates
{
cos = idParam[id-2][0];
sin = idParam[id-2][1];
px = idParam[id-2][2];
py = idParam[id-2][3]; //读cos sin x y 参数【id-2】

xz = cos * *x - sin * *y - px * cos + py * sin;
yz = (cos * *y + sin * *x + px * sin - py * cos)/(cos * cos - sin * sin);

printf("\ntest\t%d\t%0.2f %0.2f\n",id,xz,yz);//test

id = id - 1;

if( 1 < id)
{
WordCoordinates(&xz,&yz,id,idParam); //递归调用转换函数,直到转换成世界坐标。
}
else
{
*x = xz;
*y = yz;
return;
}
}
return;

在这段代码中,当id运行到id = 1 的时候会进入:
*x = xz;
*y = yz;
return;
但是此时并没有结束循环,居然在id = 1 的时候又进入了while循环,并且id 变成了id = 2,请问各位老师这是什么情况?是我的逻辑有问题吗?
...全文
633 7 点赞 打赏 收藏 举报
写回复
7 条回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
赵4老师 2013-01-25
不要使用 while (条件) 更不要使用 while (组合条件) 要使用 while (1) { if (条件1) break; //... if (条件2) continue; //... if (条件3) return; //... } 因为前两种写法在语言表达意思的层面上有二义性,只有第三种才忠实反映了程序流的实际情况。 典型如: 下面两段的语义都是当文件未结束时读字符 whlie (!feof(f)) { a=fgetc(f); //... b=fgetc(f);//可能此时已经feof了! //... } 而这样写就没有问题: whlie (1) { a=fgetc(f); if (feof(f)) break; //... b=fgetc(f); if (feof(f)) break; //... } 类似的例子还可以举很多。
  • 打赏
  • 举报
回复
阿麦 2013-01-25
break是跳出与它最近的循环, return是从函数返回。 你所说的 "在else中的break,或者 return;不起作用", 建议你在else后加上花括号{} 《高质量C++编程》里,建议不管语句多少,都加上{} 我一直是这样坚持的,没发生过你说的这种情况。
  • 打赏
  • 举报
回复
shiguojie19892 2013-01-25
引用 2 楼 amoyman 的回复:
while (2 <= id) 多余了。已经在后面递归处理了,这里不要再做循环。 试试: C/C++ code?1234567891011121314151617181920//坐标转换 //while( 2 <= id) //如果大于等于2,调用WordCoordinates cos = idParam[id-2][0]; sin =……
您解决了我的问题了
  • 打赏
  • 举报
回复
shiguojie19892 2013-01-25
谢谢!您解决我的问题了。但是我十分疑惑的是: 在else中的break,或者 return;不起作用呢?
  • 打赏
  • 举报
回复
阿麦 2013-01-25
while (2 <= id) 多余了。已经在后面递归处理了,这里不要再做循环。 试试:

//坐标转换
	//while( 2 <= id)		//如果大于等于2,调用WordCoordinates
	cos = idParam[id-2][0];
	sin = idParam[id-2][1];
	px  = idParam[id-2][2];
	py  = idParam[id-2][3];	//读cos sin x y 参数【id-2】
	xz = cos * *x - sin * *y  - px * cos + py * sin;
	yz = (cos * *y + sin * *x + px * sin - py * cos)/(cos * cos - sin * sin);
	printf("\ntest\t%d\t%0.2f %0.2f\n",id,xz,yz);//test
	--id;
	if( 1 < id)
	{
		WordCoordinates(&xz,&yz,id,idParam);	//递归调用转换函数,直到转换成世界坐标。
	}
	else
	{
		*x = xz;
		*y = yz;
	}
	return;
  • 打赏
  • 举报
回复
startservice 2013-01-25
递归调用吧?
  • 打赏
  • 举报
回复
shiguojie19892 2013-01-25
引用 5 楼 amoyman 的回复:
break是跳出与它最近的循环, return是从函数返回。 你所说的 "在else中的break,或者 return;不起作用", 建议你在else后加上花括号{} 《高质量C++编程》里,建议不管语句多少,都加上{} 我一直是这样坚持的,没发生过你说的这种情况。
恩 我也一直是这么做的
  • 打赏
  • 举报
回复
相关推荐
发帖
C++ 语言
加入

6.0w+

社区成员

C++ 语言相关问题讨论,技术干货分享,前沿动态等
申请成为版主
帖子事件
创建了帖子
2013-01-25 08:40
社区公告
暂无公告