不兼容的类型:对象无法转换为 CoreLabel

incompatible types: Object cannot be converted to CoreLabel

我正在尝试将 Stanford 分词器与他们网站上的以下示例一起使用:

import java.io.FileReader;
import java.io.IOException;
import java.util.List;

import edu.stanford.nlp.ling.CoreLabel;
import edu.stanford.nlp.ling.HasWord;
import edu.stanford.nlp.process.CoreLabelTokenFactory;
import edu.stanford.nlp.process.DocumentPreprocessor;
import edu.stanford.nlp.process.PTBTokenizer;

public class TokenizerDemo {

  public static void main(String[] args) throws IOException {
    for (String arg : args) {
      // option #1: By sentence.
      DocumentPreprocessor dp = new DocumentPreprocessor(arg);
      for (List sentence : dp) {
        System.out.println(sentence);
      }
      // option #2: By token
      PTBTokenizer ptbt = new PTBTokenizer(new FileReader(arg),
              new CoreLabelTokenFactory(), "");
      for (CoreLabel label; ptbt.hasNext(); ) {
        label = ptbt.next();
        System.out.println(label);
      }
    }
  }
}

当我尝试编译它时出现以下错误:

TokenizerDemo.java:24: error: incompatible types: Object cannot be converted to CoreLabel
        label = ptbt.next();

有谁知道可能是什么原因吗?如果您有兴趣,我正在使用 Java 1.8 并确保 CLASSPATH 包含 jar 文件。

尝试参数化 PTBTokenizer class。例如:

PTBTokenizer<CoreLabel> ptbt = new PTBTokenizer<>(new FileReader(arg),
          new CoreLabelTokenFactory(), "");