我的应用程序中处理图形的ArgumentOutOfRange异常(索引超出范围。必须是非负的且小于集合的大小。)但我想这并不重要错误的地方)。
这是我的方法:
public void InverznaFunkcia2(double a, double b, int n, List<Point> F, int m)
{
int i = 0;
double yj = F[0].Y;
double KrokX = (b - a) / n;
double KrokY = (F[0].Y - F[n].Y) / m;
for (int j = 0; j < m - 1; j++)
{
while (yj > F[i + 1].Y)
{
i = i + 1;
if (F[i].Y > 200)
{
break;
}
}
invF.Add(j);
//EXCEPTION THROWN ON THE FOLLOWING LINE:
invF[j] =( a + (j + ((yj - F[i].Y) / (F[i + 1].Y - F[i].Y)) * KrokX));
// invF[j].X = a + (j + ((yj - F[i].Y) / (F[i + 1].Y - F[i].Y)) * KrokX);
yj = yj + KrokY;
pomocneX.Add(j);
double ux = F[i].X -F[i+1].X;
double uy = F[i].Y - F[i+1].Y;
double t = (invF[j] - F[i].Y) / uy;
pomocneX[j] = F[i].X + (t * ux);
//pomocneX[j] = ( a + (j + ((yj - F[i].X) / (F[i + 1].X - F[i].X)) * KrokX));
textBox3.Text += "invF" + j + "\t" + (invF[j] + "\r\n");
textBox4.Text += "X" + j + "\t" + (pomocneX[j] + "\r\n");
}
//invF.Add(m);
// invF[m] = (double)b;
}
我知道这里讨论过这种类型的异常,但我不知道如何解决这个问题。谢谢。
答案 0 :(得分:2)
K表;所以让我们剖析:
//EXCEPTION THROWN ON THE FOLLOWING LINE:
invF[j] =( a + (j + ((yj - F[i].Y) / (F[i + 1].Y - F[i].Y)) * KrokX));
现在;我可以开始询问&#34; j
受m
限制;我们怎么知道invF[j]
是否有意义?&#34 ;;但是,添加一些调试代码会更容易:
try {
invF[j] =( a + (j + ((yj - F[i].Y) / (F[i + 1].Y - F[i].Y)) * KrokX));
} catch(ArgumentOutOfRangeException) {
Console.WriteLine("i={0},j={1},|invF|={2},|F|={3}",
i, j, invF.Length, F.Length);
throw;
}
那应该会告诉你问题所在。