Java serialization, ObjectInputStream.readObject(), check if will block

拈花ヽ惹草 提交于 2019-11-27 14:51:41

No. Although you could use the ObjectInputStream in another thread and check to see whether that has an object available. Generally polling isn't a great idea, particularly with the poor guarantees of InputStream.available.

The Java serialization API was not designed to support an available() function. If you implement your own object reader/writer functions, you can read any amount of data off the stream you like, and there is no reporting method.

So readObject() does not know how much data it will read, so it does not know how many objects are available.

As the other post suggested, your best bet is to move the reading into a separate thread.

I have an idea that by adding another InputStream into the chain one can make availability information readable by the client:

HACK!

InputStream is = ... // where we actually read the data
BufferedInputStream bis = new BufferedInputStream(is);
ObjectInputStream ois = new ObjectInputStream(bis);

if( bis.available() > N ) {
  Object o = ois.readObject();
}

The tricky point is value of N. It should be big enough to cover both serialization header and object data. If those are varying wildly, no luck.

The BufferedInputStream works for me, and why not just check if(bis.available() > 0) instead of a N value, this works perfectly for me. I think ObjectInputStream.readObject blocks(= waits until) when no input is to be read. So if there is any input at all in the stream aka if(bis.available() > 0) ObjectInputStream.readObject will not block. Keep in mind that ObjectInputStream.readObject might throw a ClassNotFoundException, and that is't a problem at all to me.

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!