我收到一个错误,我完全不知道如何去修复它。看看周围的stackoverflow似乎这个错误是与损坏的文件或在不兼容的Java版本中编译的类有关。这是我一直在寻找到的一个问题:Causes of getting a java.lang.VerifyErrorjava.lang.VerifyError:不一致的堆栈映射帧
WARNING: Error for /clearnlp
java.lang.VerifyError: Inconsistent stackmap frames at branch target 60
Exception Details:
Location:
edu/emory/clir/clearnlp/util/DSUtils.createStringHashMap(Ljava/io/InputStream;Ledu/emory/clir/clearnlp/util/CharTokenizer;Z)Ljava/util/Map; @60: aload_1
Reason:
Type top (current frame, locals[5]) is not assignable to 'java/lang/String' (stack map, locals[5])
Current Frame:
bci: @39
flags: { }
locals: { 'java/io/InputStream', 'edu/emory/clir/clearnlp/util/CharTokenizer', integer, 'java/io/BufferedReader', 'java/util/Map', top, 'java/lang/String' }
stack: { integer }
Stackmap Frame:
bci: @60
flags: { }
locals: { 'java/io/InputStream', 'edu/emory/clir/clearnlp/util/CharTokenizer', integer, 'java/io/BufferedReader', 'java/util/Map', 'java/lang/String' }
stack: { }
Bytecode:
0x0000000: bb00 5159 bb00 6f59 2ab7 0074 b700 774e
0x0000010: bb00 8a59 0312 8c12 0b12 0db8 0013 b700
0x0000020: 8d3a 04a7 0045 1c99 0015 1905 b600 323a
0x0000030: 0519 05b6 0036 9900 06a7 002f 2b19 0503
0x0000040: 1295 120b 120d b800 13b6 0099 3a06 1904
0x0000050: 1906 0332 1906 0432 0312 9b12 0b12 0db8
0x0000060: 0013 b900 9f03 0057 2db6 005c 593a 05c7
0x0000070: ffb7 a700 0a3a 0719 07b6 0061 1904 b0
Exception Handler Table:
bci [35, 114] => handler: 117
Stackmap Table:
full_frame(@38,{Object[#143],Object[#145],Integer,Object[#81],Object[#147],Top,Object[#40]},{})
full_frame(@60,{Object[#143],Object[#145],Integer,Object[#81],Object[#147],Object[#40]},{})
chop_frame(@104,1)
same_locals_1_stack_item_frame(@117,Object[#71])
same_frame(@124)
at java.lang.Class.forName0(Native Method)
at java.lang.Class.forName(Class.java:264)
at com.google.appengine.tools.development.agent.runtime.RuntimeHelper.checkRestricted(RuntimeHelper.java:70)
at com.google.appengine.tools.development.agent.runtime.Runtime.checkRestricted(Runtime.java:65)
at edu.emory.clir.clearnlp.coreference.sieve.SpeakerIdentification.<init>(SpeakerIdentification.java:24)
at edu.emory.clir.clearnlp.coreference.config.SieveSystemCongiuration.loadDefaultSieves(SieveSystemCongiuration.java:63)
at edu.drexel.gameailab.ClearNLPServlet.doGet(ClearNLPServlet.java:66)
at edu.drexel.gameailab.ClearNLPServlet.doPost(ClearNLPServlet.java:44)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:637)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
at org.mortbay.jetty.servlet.ServletHolder.handle(ServletHolder.java:511)
为了关闭此类型的错误,我已经清理项目好几次,删除每一个.class文件,我发现。将所有依赖关系(JAR)更新为最新版本,对于更晦涩的JAR,我找不到新版本,因为我跟踪了源代码,并将其沿着我的源代码进行了转储,以确保它被JVM重新编译。
关于设置,这是使用servlet(Jetty)和Google App Engine的clearnlp解析器项目的Web界面。我知道GAE有一些限制,我已经重写了文件访问部分,这很麻烦。我已经用stanford corenlp完成了相同的过程,并且一旦改写就没有问题。
的at edu.emory.clir.clearnlp.coreference.sieve.SpeakerIdentification.<init>(SpeakerIdentification.java:24)
正在初始化一些集合:private final Set<String> firstPersonSingularPronouns = DSUtils.toHashSet("i", "me", "my", "mine");
及以下有来自DSUtils.java一些源代码:
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.lang.reflect.Field;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collection;
import java.util.Collections;
import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.PriorityQueue;
import java.util.Random;
import java.util.Set;
import java.util.regex.Pattern;
import edu.emory.clir.clearnlp.collection.list.FloatArrayList;
import edu.emory.clir.clearnlp.collection.pair.DoubleIntPair;
import edu.emory.clir.clearnlp.collection.pair.Pair;
public class DSUtils
{
[...]
@SuppressWarnings("unchecked")
static public <T>Set<T> toHashSet(T... items)
{
Set<T> set = new HashSet<T>(items.length);
for (T item : items) set.add(item);
return set;
}
任何人有什么我应该在下次找任何指针? GAE是否会破坏类文件?我怎么修复它?我没有源代码 com.google.appengine.tools.development.agent.runtime.RuntimeHelper.checkRestricted(RuntimeHelper.java:70)
或com.google.appengine.tools.development.agent.runtime.Runtime.checkRestricted(Runtime.java:65)
,那些属于GAE SDK,我目前在Release:1.9.30。 不确定是否相关,但我在使用Apple的jdk1.8.0_60的OSX 10.11.2上。
所以,在Eclipse 4.4中存在一些问题。当我在命令行中编译'DSUtils.java'并复制到classes目录时,一切正常。谢谢。 –