All Downloads are FREE. Search and download functionalities are using the official Maven repository.

stream.util.JavaSerializer Maven / Gradle / Ivy

The newest version!
/*
 *  streams library
 *
 *  Copyright (C) 2011-2014 by Christian Bockermann, Hendrik Blom
 * 
 *  streams is a library, API and runtime environment for processing high
 *  volume data streams. It is composed of three submodules "stream-api",
 *  "stream-core" and "stream-runtime".
 *
 *  The streams library (and its submodules) is free software: you can 
 *  redistribute it and/or modify it under the terms of the 
 *  GNU Affero General Public License as published by the Free Software 
 *  Foundation, either version 3 of the License, or (at your option) any 
 *  later version.
 *
 *  The stream.ai library (and its submodules) is distributed in the hope
 *  that it will be useful, but WITHOUT ANY WARRANTY; without even the implied 
 *  warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *  GNU Affero General Public License for more details.
 *
 *  You should have received a copy of the GNU Affero General Public License
 *  along with this program.  If not, see http://www.gnu.org/licenses/.
 */
package stream.util;

import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.io.OutputStream;
import java.io.Serializable;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import stream.io.Serializer;

/**
 * 

* An implementation of the Serializer interface that uses the plain built-in * Java serialization. *

* * @author Christian Bockermann <chris@jwall.org> * */ public class JavaSerializer implements Serializer { final static Logger log = LoggerFactory.getLogger(JavaSerializer.class); /** * @see stream.io.Serializer#clone(java.io.Serializable) */ @Override public Serializable clone(Serializable object) throws Exception { if (object == null) return null; try { ByteArrayOutputStream baos = new ByteArrayOutputStream(); write(object, baos); baos.flush(); baos.close(); ByteArrayInputStream bais = new ByteArrayInputStream( baos.toByteArray()); Serializable value = read(bais); bais.close(); return value; } catch (Exception e) { log.error("Cloning object {} failed: {}", object, e.getMessage()); throw new Exception(e.getMessage()); } } /** * @see stream.io.Serializer#read(java.io.InputStream) */ @Override public Serializable read(InputStream in) throws IOException { try { ObjectInputStream ois = new ObjectInputStream(in); Serializable value = (Serializable) ois.readObject(); return value; } catch (Exception e) { log.error( "De-serialization of object from input-stream {} failed: {}", in, e.getMessage()); throw new IOException(e.getMessage()); } } /** * @see stream.io.Serializer#write(java.io.Serializable, * java.io.OutputStream) */ @Override public void write(Serializable object, OutputStream out) throws IOException { try { ObjectOutputStream oos = new ObjectOutputStream(out); oos.writeObject(object); oos.flush(); } catch (Exception e) { log.error("Serialization of object {} failed: {}", object, e.getMessage()); throw new IOException(e.getMessage()); } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy