ArrayIndexOutOfBounds
アプリケーションが実行されている PC に Windows リモート デスクトップを使用して接続すると、Swing アプリケーションが例外をスローしているようです。何がこれを引き起こしているのでしょうか?
Exception in thread "AWT-EventQueue-0" java.lang.ArrayIndexOutOfBoundsException: 3
at sun.awt.Win32GraphicsEnvironment.getDefaultScreenDevice(Win32GraphicsEnvironment.java:96)
at sun.awt.windows.WWindowPeer.updateGC(WWindowPeer.java:470)
at sun.awt.windows.WWindowPeer.displayChanged(WWindowPeer.java:508)
at sun.awt.windows.WWindowPeer$1.run(WWindowPeer.java:448)
at java.awt.event.InvocationEvent.dispatch(InvocationEvent.java:251)
at java.awt.EventQueue.dispatchEventImpl(EventQueue.java:733)
at java.awt.EventQueue.access$200(EventQueue.java:103)
at java.awt.EventQueue$3.run(EventQueue.java:694)
at java.awt.EventQueue$3.run(EventQueue.java:692)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:76)
at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:87)
at java.awt.EventQueue$4.run(EventQueue.java:708)
at java.awt.EventQueue$4.run(EventQueue.java:706)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:76)
at java.awt.EventQueue.dispatchEvent(EventQueue.java:705)
at java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:242)
at java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:161)
at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:150)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:146)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:138)
at java.awt.EventDispatchThread.run(EventDispatchThread.java:91)
これは、PC にリモート接続するときに 2 回見たことがありますが、他の状況では見たことがありません。これはすべてJava 7u25 Sun JDKの内部にあるため(以下のスタック トレースを参照)、これをデバッグする方法さえわかりません。考え?
その他の情報: マシンには 2 つのグラフィックス カードがあり、それぞれに 2 つのモニター ポートがあり、Windows は 4 つのモニターすべてがオンになるように構成されています。ただし、マシンにリモート接続すると、明らかにモニターが 1 つしかありません。スタート メニューのあるモニター (およびアプリを含むモニター) は、Windows によってモニター #4 として識別されます。
System.getProperties().list(System.out);
:
-- listing properties --
java.runtime.name=Java(TM) SE Runtime Environment
sun.boot.library.path=D:\Program Files\Java\jdk1.7.0_25\jre...
java.vm.version=23.25-b01
java.vm.vendor=Oracle Corporation
java.vendor.url=http://java.oracle.com/
path.separator=;
java.vm.name=Java HotSpot(TM) 64-Bit Server VM
file.encoding.pkg=sun.io
user.script=
user.country=US
sun.java.launcher=SUN_STANDARD
sun.os.patch.level=Service Pack 1
java.vm.specification.name=Java Virtual Machine Specification
user.dir=C:\Code\workspace\client
java.runtime.version=1.7.0_25-b16
java.awt.graphicsenv=sun.awt.Win32GraphicsEnvironment
java.endorsed.dirs=D:\Program Files\Java\jdk1.7.0_25\jre...
os.arch=amd64
java.io.tmpdir=XXXXXXXXXXXXXXXXXXXXXXXXXXXX
line.separator=
java.vm.specification.vendor=Oracle Corporation
user.variant=
os.name=Windows 7
sun.jnu.encoding=Cp1252
java.library.path=D:\Program Files\Java\jdk1.7.0_25\bin...
java.specification.name=Java Platform API Specification
java.class.version=51.0
sun.management.compiler=HotSpot 64-Bit Tiered Compilers
os.version=6.1
user.home=XXXXXXXXXXXXXXXXXXXXXXXXX
user.timezone=
java.awt.printerjob=sun.awt.windows.WPrinterJob
file.encoding=Cp1252
java.specification.version=1.7
user.name=XXXXXXXXXXXXXXXXXXXXXXXXX
java.class.path=C:\Code\workspace\client\target\class...
java.vm.specification.version=1.7
sun.arch.data.model=64
java.home=D:\Program Files\Java\jdk1.7.0_25\jre
sun.java.command=com.techemet.client.ClientMain
java.specification.vendor=Oracle Corporation
user.language=en
awt.toolkit=sun.awt.windows.WToolkit
java.vm.info=mixed mode
java.version=1.7.0_25
java.ext.dirs=D:\Program Files\Java\jdk1.7.0_25\jre...
sun.boot.class.path=D:\Program Files\Java\jdk1.7.0_25\jre...
java.vendor=Oracle Corporation
file.separator=\
java.vendor.url.bug=http://bugreport.sun.com/bugreport/
sun.cpu.endian=little
sun.io.unicode.encoding=UnicodeLittle
sun.desktop=windows
sun.cpu.isalist=amd64