我正在尝试使用线程在 100m 跑道上与 6 只蜗牛比赛。这是完整的代码http://ideone.com/An30s4 。为什么有些蜗牛根本不跑?为什么 他们没有跑完100m跑道吗? (我实际上希望他们所有人都到达终点线。然后我将在程序结束时打印获胜者。)
struct snail_thread{
int move;
char snail_name[10];
char owner[10];
};
int sum = 0;
void printval(void *ptr) {
struct snail_thread *data;
data = (struct snail_thread *) ptr;
while(sum < 100) {
sum += data->move;
printf("%s moves %d mm, total: %d\n",data->snail_name, data->move, sum);
}
pthread_exit(0);
}
int main(void) {
pthread_t t[6];
struct snail_thread s[6];
int i;
srand(time(NULL));
for(i = 0; i < 6; i++)
s[i].move = rand() % ((5 + 1) - 1) + 1;
strcpy(s[0].snail_name, "Snail A");
strcpy(s[0].owner, "Jon");
strcpy(s[1].snail_name, "Snail B");
strcpy(s[1].owner, "Ben");
strcpy(s[2].snail_name, "Snail C");
strcpy(s[2].owner, "Mark");
strcpy(s[3].snail_name, "Snail D");
strcpy(s[3].owner, "Jon");
strcpy(s[4].snail_name, "Snail E");
strcpy(s[4].owner, "Mark");
strcpy(s[5].snail_name, "Snail F");
strcpy(s[5].owner, "Ben");
for(i = 0; i < 6; i++)
pthread_create(&t[i],NULL,(void *) &printval, (void *) &s[i]);
for(i = 0; i < 6; i++)
pthread_join(t[i], NULL);
return (0);
}
最佳答案
因为你的sum
是全局的,所有的蜗牛都在递增它。
将 sum
也放入 struct
中。
另一个小技巧,为了获得更好的结果,使每个步骤的移动
随机。现在移动
与速度相同,您无需比赛即可知道谁获胜。
(来吧,给你的蜗牛起一个比“蜗牛 A”更好的名字;-))。
关于c - 使用线程刺激赛车游戏,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20898874/