为什么这个gson解析没有完成?

2w3kk1z5  于 2021-07-12  发布在  Java
关注(0)|答案(0)|浏览(248)

在服务器端,我使用以下方法将对象格式化为json:

String typeJson = new Gson().toJson(typeContainer);

在客户端,我使用以下方法打开它:

JSONContainer<CommonNoun> typeContainer = new Gson().fromJson(result,
                             new TypeToken<JSONContainer<CommonNoun>>(){}.getType());

在执行中,线程永远不会超过上面的行(后面有一个println)。
我已经检查了客户端接收的“result”字符串是否与服务器上生成的“typejson”相同。看起来是这样的:

{"myObject":{"cid":{"oid":129},"name":"technology","form":1},"children":[]}

组成被发送对象的4个类是:

public class JSONContainer<T> {

    private T myObject;
    private ArrayList<JSONContainer<T>> children;

    public JSONContainer() {

    }

    public JSONContainer(T anObject) {
        myObject = anObject;
        children = new ArrayList<JSONContainer<T>>();
    }

    public void addChildren(ArrayList<JSONContainer<T>> newChildren) {
        children.addAll(newChildren);
    }

    public void addChild(T concept) {
        children.add(new JSONContainer<T>(concept));
    }

    public ArrayList<JSONContainer<T>> getChildren() {
        return children;
    }

    public T getValue() {
        return myObject;
    }

    public boolean hasChildren() {
        if (children.size() > 0) return true;
        else return false;
    }

    public String toString() {
        return myObject.toString();
    }
}

public class CommonNoun extends Concept {

    /**
     * 
     */
    private static final long serialVersionUID = 6444629581712454049L;

    public CommonNoun() {
        super();
    }

    public CommonNoun(String name, ConceptID cidIn) {
        super(name, cidIn);
        this.form = ConceptDefs.COMMON_NOUN;
    }

}

public class Concept implements Serializable {

    /**
     * 
     */
    private static final long serialVersionUID = 2561549161503772431L;
    private ConceptID cid = null;
    private final String name;
    Integer form = 0;

//    ArrayList<ProperRelationship> myRelationships = null;

/*  @Deprecated
    public Concept(String name) {
        this.name = name;
    }*/

    public Concept() {
        name = "";
    }

    public Concept(String name, ConceptID cidIn) {
       // this(name);
        this.name = name;
        cid = cidIn;
    }

    /*
     * This should be over-ridden by any subclasses
     */
    public Integer getForm() {
        return form;
    } 

    public ConceptID getID() {
        return cid;
    }

    public void setID(ConceptID cidIn) {
        cid = cidIn;
    }

    //this doesn't make any sense.  Throw exception?
    public String getName() {
        return name;
    }

    public boolean isCommon() {
        return true;
    }

    /**
     *
     * @return
     */
    @Override
    public String toString() {
        return getName() + "(" + cid.toString() + ")";
    }

    public boolean equals(Concept other) {
        return ((getID().equals(other.getID())));
    }

}

public class ConceptID implements Serializable {

    long oid;

    public ConceptID() {
        oid = -1;
    }
    public ConceptID(long oid) {
        this.oid = oid;
    }

    public long getValue() {
        return oid;
    }

    /**
     *
     * @return
     */
    @Override
    public String toString() {
        return Long.toString(oid);
    }

    public Long toLong() {
        return Long.valueOf(oid);
    }

    public boolean equals(ConceptID other) {
        return (oid == other.getValue());
    }

    /**
     * Factory model for generating ConceptIDs
     * 
     * This one is here as a convenience as many IDs come in as a String from web POSTs
     * @param idAsString
     * @return
     */
    static public ConceptID parseIntoID(String idAsString) {
        ConceptID returnID = null;
        try {
            returnID = new ConceptID( Long.parseLong(idAsString) );
        } catch (Exception e) {
            System.err.println("Expected the string, " + idAsString + ", to be Long parsable.");
            e.printStackTrace();
        }
        return returnID;

    }
}

为了解决这个问题,我尽了最大的努力使变量最小化。现在,我在两边使用相同的json解析器,并且以一种在引用泛型时不会产生类型警告的方式编写fromjson()语句。我已经研究了gson的api(还有gsonbuilder()的组合有待完善),并且用“gson”“json”“parsing”“lock”“not complete”等术语搜索了stackoverflow和google。
更新:
@paranoidandroid在他的环境中分享了解析工作之后,我尝试解析json服务器端,在那里它确实工作。那么我的服务器和客户端有什么不同呢?服务器项目是通过在eclipse中选择一个项目向导选项生成的,客户机是libgdx项目。另一个潜在的线索是libgdx为json操作实现了自己的类,称为json—这样做是为了解决这种情况吗?
为什么我不使用本机json类?我是这样开始的,但格式不匹配。json显然是非标准的,尽管尝试了setoutputtype(outputtype)中所有可用的选项。
如何从json中正确读取这个泛型?
接下来,我尝试使用json服务器端,但无法使配置正常工作:甚至出现了classdefnotfound错误。
我控制的另一个变量是复制和替换通过json从服务器传递到客户机项目的所有类,以确保每个人都使用相同的版本(我确信有某种方法可以让项目引用彼此的类,但我还不知道)。
(最终?)更新:
尝试按请求创建线程转储,但java任务控制没有任何线程转储。
找到的文档说,如果我想在libgdx之外使用本机json类,我应该使用jsonbeans:https://github.com/esotericsoftware/jsonbeans/
用jsonbeans替换了json序列化服务器端,现在可以使用本机json类客户端。
对于“为什么这个gson解析没有完成”这个问题,这是一个糟糕的答案:
因为在libgdx中,在某些情况下只有本机json解析器可以工作。此外,如果希望该类与非libgdx项目一起工作,最好使用它的配套类jsonbeans。”

暂无答案!

目前还没有任何答案,快来回答吧!

相关问题