C语言奇特的Bug


 请教一下,大神解释下面程序中bug,百思不得其解。程序意图:从文本中筛选出-> “;<Delay> 12000 ”->"12000"。

程序:

while((ch4=getc(fpGcode) )!= EOF)

......... #if 1
/*key: make sure only once -(ch3Enter == '\n')*/
if((ch3Enter == '\n'))
{
flagDelay = 0;

}

if((ch3Enter == '<')&& (ch1Cur == 'D'))
{
flagDelay = 1;
flagDelayRightSharp = 0;
flagTemp = 0;
/*Delay 无效,仅仅保留数字字符*/
memset(DelayBuf, '\0', GcodeBUFSIZE);
#if 0
printf("<lineDelay=%ld>#ch1Cur=%c\n", line, ch1Cur);
#endif
}

if(flagDelay == 1)
{
flagTemp++;
// printf("%c", ch1Cur);

#if 1
if((ch3Enter == 'y') &&ch1Cur == '>')
{
flagDelayRightSharp = 1;
posDelay = 0;
}
#if 1
if(ch1Cur == '>')
continue;
if(ch1Cur == ' ')
continue;
#endif
#endif

if(flagDelayRightSharp == 1 &&(ch1Cur != '\n'))
{
printf("[%c]", ch1Cur);
DelayBuf[posDelay] = ch1Cur;
printf("<%ld>\n", posDelay);
posDelay++;
}


if((ch1Cur == '\n'))
{
DelayBuf[posDelay-1] = '\0';
printf("<lineDelay=%ld><posDelay=%ld>DelayBuf=%s\n", line, (posDelay-1), DelayBuf);
printf("flagTemp=%d<<<<<<<<<<<\n\n", flagTemp);
}

}

#endif

运行:

<lineDelay=22415><posDelay=5>DelayBuf=
flagTemp=15<<<<<<<<<<<


[4]<0>
[8]<1>
[0]<2>
[0]<3>
]<4>
<lineDelay=22421><posDelay=4>DelayBuf=
flagTemp=13<<<<<<<<<<<


[1]<0>
[2]<1>
[0]<2>
[0]<3>
[0]<4>
]<5>
<lineDelay=22429><posDelay=5>DelayBuf=
flagTemp=15<<<<<<<<<<<


[4]<0>
[8]<1>
[0]<2>
[0]<3>
]<4>
<lineDelay=22435><posDelay=4>DelayBuf=

flagTemp=13<<<<<<<<<<<


bug1:“]<4>”.“[”丢失

bug2: "DelayBuf="字符数组无输出

Bug2算法是一种基本的移动机器人路径规划算法,它的实现相对简单,以下是C语言实现的基本框架: ```c #include <stdio.h> #include <stdlib.h> #include <math.h> #define PI 3.14159265358979323846 // 定义机器人的起始位置和目标位置 double start_x = 0.0, start_y = 0.0; double goal_x = 10.0, goal_y = 10.0; // 定义机器人的尺寸和最大速度等参数 double robot_radius = 1.0; double max_speed = 1.0; double max_rotation_speed = 0.5; // 计算机器人当前位置和目标位置之间的距离 double distance(double x1, double y1, double x2, double y2) { return sqrt(pow(x1 - x2, 2) + pow(y1 - y2, 2)); } // 计算机器人当前角度和目标角度之间的差值 double angle_diff(double angle1, double angle2) { double diff = angle2 - angle1; while (diff > PI) diff -= 2 * PI; while (diff < -PI) diff += 2 * PI; return diff; } // 计算机器人需要沿着的方向角度 double target_angle(double x, double y) { return atan2(goal_y - y, goal_x - x); } int main() { // 初始化机器人位置和角度 double robot_x = start_x, robot_y = start_y; double robot_angle = 0.0; while (distance(robot_x, robot_y, goal_x, goal_y) > robot_radius) { // 计算机器人需要沿着的方向角度 double target = target_angle(robot_x, robot_y); // 计算机器人需要旋转的角度和方向 double angle = angle_diff(robot_angle, target); int direction = angle > 0 ? 1 : -1; // 如果机器人需要旋转的角度大于最大旋转速度,则机器人只旋转最大旋转速度 if (fabs(angle) > max_rotation_speed) angle = max_rotation_speed * direction; // 机器人旋转并更新角度 robot_angle += angle; // 计算机器人需要移动的距离和方向 double distance_to_target = distance(robot_x, robot_y, goal_x, goal_y); double distance_to_move = fmin(max_speed, distance_to_target); double dx = distance_to_move * cos(robot_angle); double dy = distance_to_move * sin(robot_angle); // 机器人移动并更新位置 robot_x += dx; robot_y += dy; // 输出机器人当前位置 printf("Robot at (%.2f, %.2f)\n", robot_x, robot_y); } printf("Robot has reached the goal!\n"); return 0; } ``` 在以上代码中,我们首先定义了机器人的起始位置和目标位置、机器人的尺寸和最大速度等参数。然后在主循环中,我们不断计算机器人需要旋转的角度和方向,如果角度大于最大旋转速度,则机器人只旋转最大旋转速度;然后计算机器人需要移动的距离和方向,并更新机器人的位置。最后输出机器人到达目标点的信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值