[英]Does anyone know why gcc 4.8.4 optimizes this code in a infinite loop?
[英]Trying to know why is this code leading into an infinite loop
我一直在嘗試獲取數字的階乘(f.ex:4!= 24 [4(3)(2)(1)= 24])。
我編寫了以下代碼:
#include <stdio.h>
void TestAcomulador(int a, int factorizado, int *resultado);
int main(void) {
int a, resultado, factorizado, sacaroperacion;
printf("Introduzca un numero: ");
scanf("%d", &a);
TestAcomulador(a, factorizado, &resultado);
printf("%d", resultado);
}
void TestAcomulador(int a, int numprincipal, int *factorizado) {
numprincipal = --a;
do {
*factorizado = numprincipal * a;
printf("The loop is here\n"); //LOOP IN THIS LINE
} while (numprincipal > 0);
}
發生了什么,我在做什么錯? 我們將不勝感激,希望能避免以后再出現此問題,
提前致謝。
您不會在任何時候遞減數值,因此它將始終大於0(假設a> = 2)。
因此,while循環的條件始終為true。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.