【问题标题】:Java serialization. Field changes value [duplicate]Java 序列化。字段更改值[重复]
【发布时间】:2012-02-15 22:04:41
【问题描述】:

我有以下问题。我可以将事务状态设置为“开始、结束或正在进行”。我设置了这个,然后将我的 Transaction 对象序列化到服务器,由服务器检索它。第一次像魅力一样工作(当事务处于启动模式时),但是当我重新发送对象时,这次处于“正在进行”模式,服务器继续在“启动”模式下看到它。我已经在序列化之前的那一行和反序列化之后的那一行测试了代码,这绝对是问题所在。任何帮助将不胜感激。相关代码sn-ps如下:

序列化

        if ((query instanceof Transaction) && !(trx.getTransactionState()==Consts.trx_start)) System.out.println("Not start");
        oos.writeObject(query);
        oos.flush();

反序列化

    while (true) {
                Object statement = null;

                try {

                    statement = ois.readObject();
                    if ((statement instanceof Transaction) && !(((Transaction) statement).getTransactionState()==Consts.trx_start)) System.out.println("Not start 2");
                    handle_statement(statement, socket);
                } catch (IOException e) {

以及事务类:

    public class Transaction extends Statement{

/**
 * 
 */
private static final long serialVersionUID = -2284996855537430822L;
Statement statement_list;
int trx_state; 


/**
 * 
 */
public Transaction() {
    trx_state = Consts.trx_start;; 
}

/**
 * @param statement
 */
public void setStatement(Statement statement ) { 
    statement_list = statement; 
} 


public void setTransactionState(int state) {
        trx_state = state; 
}

public int getTransactionState() {
    return trx_state; 
}
/**
 * @return
 */
public Statement getStatement() {
    return statement_list;
}

【问题讨论】:

    标签: java serialization client-server serializable objectoutputstream


    【解决方案1】:

    ObjectOutputStream 缓存它通过网络发送的实例(不一定是最佳设计)。但无论如何,如果您打算使用它来(重新)发送相同的对象实例,则需要在调用之间reset 输出流。

    public void reset() 抛出 IOException

    重置将忽略任何对象的状态 写入流。状态被重置为 与新的 ObjectOutputStream 相同。流中的当前点是 标记为重置,因此相应的 ObjectInputStream 将被重置 在同一点。之前写入流的对象不会 被称为已经在流中。他们将被写入 再次流。

    Another SO thread discussing this very same issue.

    【讨论】:

    • 护脸。我认为冲洗可以解决问题......不知道重置。谢谢。像魅力一样工作
    • 鉴于保留对象图的设计目标,它是唯一可能的设计。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2016-06-16
    • 2015-02-12
    • 1970-01-01
    • 2015-10-04
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多