0

我目前正试图让我的头缠在 imagej 上,只是试图复制图像并吐出输出。总体思路是获取图像,从图像处理器中获取像素阵列,将其复制到新阵列中,然后从该阵列构建新图像。

现在在这里,存在 aPixels_org[0] 的值,正如您在控制台输出中看到的那样。但即使我进行了所有检查,它仍然会抛出 arrayoutofbounds 异常。

这是代码...(顺便说一句。只是一个记录器对象,只是一个健全性检查,以检查数组值是否存在于下面的 if 条件中。请告知是否有更好的方法,因为我是一个 C++ 人, 并且习惯于直接检查东西,因为 java 不允许 if(int){} 检查)

我从一个函数中获取 aPixels_org,一个 dthe aPixels_dup 就是这样创建的

int[] aPixels_dup = new int[iWidth*iHeight];

其中 iWidth*iHeight 是所需数组的大小。我还尝试使用 array.length() 选项直接生成大小。问题代码是

System.out.println(">>>>>>>>>>>>>>>>>>>>>." + aPixels_dup[0] +"  " + aPixels_org[0] + "  " + iWidth + "  " + iHeight);
    if(Integer.toString(aPixels_org[0]) != null &&  Integer.toString(aPixels_dup[0]) != null )
    {
        l.info("Arrays exsist");
        System.arraycopy(aPixels_org,0,aPixels_dup,0,iWidth*iHeight);
        l.info("Array Copied");
    }
    else{l.warn("Something is NULL");}
    l.info("");

这是错误

java.lang.ArrayIndexOutOfBoundsException
at java.lang.System.arraycopy(Native Method)
at Alpha_.DuplicateCurrentImage(Alpha_.java:64)
at Alpha_.run(Alpha_.java:81)
at ij.IJ.runUserPlugIn(IJ.java:185)
at ij.IJ.runPlugIn(IJ.java:152)
at ij.Executer.runCommand(Executer.java:127)
at ij.Executer.run(Executer.java:64)
at java.lang.Thread.run(Thread.java:679)

这是控制台输出

[INFO] % FILE: Alpha_.java % CLASS: Alpha_ % FUNCTION: DuplicateCurrentImage % LINE: 59    % COMMENT: OK % % % TIMESTAMP: 2013-01-17 00:26:55,942
 0  -1393202  466  466
[INFO] % FILE: Alpha_.java % CLASS: Alpha_ % FUNCTION: DuplicateCurrentImage % LINE: 63 % COMMENT: Arrays exsist % % % TIMESTAMP: 2013-01-17 00:26:55,942

我的输出到此结束,程序因上述错误而崩溃。如您所见,所有 4 个值都以某种形式存在。我用谷歌搜索了错误,发现错误是

抛出以指示已使用非法索引访问数组。索引为负数或大于或等于数组的大小。

我在这里遗漏了一些明显的东西吗?

关于

4

2 回答 2

2

两个数组 -aPixels_orgaPixels_dup- 都必须至少有长度iWidth*iHeight(根据您的控制台输出,它是 217156)。一个(或两个)数组必须比那个短,这就是你得到异常的原因。还要确保 的值在分配和调用iWidth*iHeight之间没有增加。aPixels_dupSystem.arraycopy

Math.min(aPixels_org.length, aPixels_dup.length)将其用作 . 的最后一个参数会更安全System.arraycopy。但是,这会隐藏代码中的任何长度错误。您可能希望assert两个数组都具有预期的长度。

此外,您的支票似乎毫无意义。两个数组中都存在索引 0 处的元素这一事实有点无关紧要。此外,Integer.toString(int)永不返回null。这是您的代码的一个版本,可以进行一些合理的检查:

if (aPixels_org != null &&
    aPixels_dup != null &&
    aPixels_org.length == aPixels_dup.length &&
    aPixels_org.length == iWidth*iHeight )
{
    l.info("Array sizes match");
    System.arraycopy(aPixels_org,0,aPixels_dup,0,iWidth*iHeight);
    l.info("Array Copied");
}
else{l.warn("Something is NULL or dimensions are off");}
l.info("");
于 2013-01-17T00:50:07.393 回答
0

这一切都在JavaDoc中。强调了我认为是您错误的原因。

 public static void arraycopy(Object src,
             int srcPos,
             Object dest,
             int destPos,
             int length)
 ...

否则,如果以下任何一项为真,IndexOutOfBoundsException则抛出 an 并且不修改目标:

  • srcPos论据是否定的。
  • destPos论据是否定的。
  • length论据是否定的。
  • srcPos+length大于src.length,源数组的长度。
  • destPos+length大于dest.length,目标数组的长度。
于 2013-01-17T00:50:44.450 回答