我有以下代码,但是在这行代码中我有警告x[i] = (rhs[i] - x[i - 1]) / b;,编译器告诉我rhsi是一个垃圾值。为什么会这样?以及如何删除此警告?
double* getFirstControlPoints(double* rhs, const int n) {
double *x;
x = (double*)malloc(n * sizeof(double));
double *tmp; // Temp workspace.
tmp = (double*)malloc(n * sizeof(double));
double b = 2.0;
x[0] = rhs[0] / b;
for (int i = 1; i < n; i++) // Decomposition and forward substitution.
{
tmp[i] = 1 / b;
b = (i < n - 1 ? 4.0 : 3.5) - tmp[i];
x[i] = (rhs[i] - x[i - 1]) / b; //The left operand of '-' is a garbage value
}
for (int i = 1; i < n; i++) {
x[n - i - 1] -= tmp[n - i] * x[n - i]; // Backsubstitution.
}
free(tmp);
return x;
}


所有编译器警告和调用getFirstControlPoints,您可以在屏幕截图上看到。
发布于 2012-08-22 22:32:02
您需要检查以确保在points数组中至少有4个点,因为此循环(第333行):
for (NSInteger i = 1 ; i < n - 1 ; ++i) {
// initialisation stuff
}对于n= 0,1,2,根本不会执行。
假设points中有3个对象,在第311行将n设置为计数-1,即n == 2
则循环条件为i < 2 - 1,即i < 1。
我认为需要将循环条件设置为i < n
发布于 2012-08-22 21:10:46
如果points.count为0或1,您将面临一些问题,因为如果n为-1或0,您将访问rhsn-1,并且您将访问n*字节;
也许这就是问题所在。你在代码中加入了一些范围检查?
https://stackoverflow.com/questions/12073315
复制相似问题