當前位置: 首頁>>代碼示例>>Java>>正文


Java Kryo.writeObject方法代碼示例

本文整理匯總了Java中com.esotericsoftware.kryo.Kryo.writeObject方法的典型用法代碼示例。如果您正苦於以下問題:Java Kryo.writeObject方法的具體用法?Java Kryo.writeObject怎麽用?Java Kryo.writeObject使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在com.esotericsoftware.kryo.Kryo的用法示例。


在下文中一共展示了Kryo.writeObject方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: serialize

import com.esotericsoftware.kryo.Kryo; //導入方法依賴的package包/類
/**
 * 序列化
 *
 * @param obj 需要序更列化的對象
 * @return 序列化後的byte 數組
 * @throws TransactionException
 */
@Override
public byte[] serialize(Object obj) throws TransactionException {
    byte[] bytes;
    ByteArrayOutputStream outputStream = new ByteArrayOutputStream();
    try {
        //獲取kryo對象
        Kryo kryo = new Kryo();
        Output output = new Output(outputStream);
        kryo.writeObject(output, obj);
        bytes = output.toBytes();
        output.flush();
    } catch (Exception ex) {
        throw new TransactionException("kryo serialize error" + ex.getMessage());
    } finally {
        try {
            outputStream.flush();
            outputStream.close();
        } catch (IOException e) {

        }
    }
    return bytes;
}
 
開發者ID:yu199195,項目名稱:happylifeplat-transaction,代碼行數:31,代碼來源:KryoSerializer.java

示例2: serialize

import com.esotericsoftware.kryo.Kryo; //導入方法依賴的package包/類
/**
 * 序列化
 *
 * @param obj 需要序更列化的對象
 * @return 序列化後的byte 數組
 * @throws TccException
 */
@Override
public byte[] serialize(Object obj) throws TccException {
    byte[] bytes;
    try (ByteArrayOutputStream outputStream = new ByteArrayOutputStream()) {
        //獲取kryo對象
        Kryo kryo = new Kryo();
        Output output = new Output(outputStream);
        kryo.writeObject(output, obj);
        bytes = output.toBytes();
        output.flush();
    } catch (Exception ex) {
        throw new TccException("kryo serialize error" + ex.getMessage());
    }
    return bytes;
}
 
開發者ID:yu199195,項目名稱:happylifeplat-tcc,代碼行數:23,代碼來源:KryoSerializer.java

示例3: write

import com.esotericsoftware.kryo.Kryo; //導入方法依賴的package包/類
public void write (Kryo kryo, Output output, ObjectIntMap map) {
    int length = map.size;
    output.writeVarInt(length, true);
    output.writeBoolean(false); // whether type is written (in case future version of ObjectIntMap supports type awareness)

    Serializer keySerializer = null;
    if (keyGenericType != null) {
        if (keySerializer == null) keySerializer = kryo.getSerializer(keyGenericType);
        keyGenericType = null;
    }

    for (Iterator iter = map.iterator(); iter.hasNext();) {
        ObjectIntMap.Entry entry = (ObjectIntMap.Entry)iter.next();
        if (keySerializer != null) {
            kryo.writeObject(output, entry.key, keySerializer);
        } else
            kryo.writeClassAndObject(output, entry.key);
        output.writeInt(entry.value);
    }
}
 
開發者ID:CypherCove,項目名稱:gdx-cclibs,代碼行數:21,代碼來源:ObjectIntMapSerializer.java

示例4: encode

import com.esotericsoftware.kryo.Kryo; //導入方法依賴的package包/類
protected void encode(ChannelHandlerContext channelHandlerContext, Object o, ByteBuf byteBuf) throws Exception {
    if(clazz.isInstance(o)){
        Kryo kryo = null;
        try{
        	kryo = pool.borrow();
        	ByteArrayOutputStream baos = new ByteArrayOutputStream();  
            Output output = new Output(baos);  
            kryo.writeObject(output, o);  
            output.flush();  
            output.close();  
           
            byte[] data = baos.toByteArray(); 
            byteBuf.writeInt(data.length);
            byteBuf.writeBytes(data);
            baos.close();
        }catch(Exception e){
        	LOG.warn("MessageEncoder happen exception.", e);
        }finally{
        	if(kryo != null){
        		 pool.release(kryo);
        	}
        }
        
    }

}
 
開發者ID:islittlechen,項目名稱:lionrpc,代碼行數:27,代碼來源:MessageEncoder.java

示例5: save

import com.esotericsoftware.kryo.Kryo; //導入方法依賴的package包/類
public void save(@NonNull Context context)
{
	Kryo serialiser = createSerialiser();

	Log.d(TAG, "Save geofencing state... ");
	String path = context.getFilesDir().getAbsolutePath() + "/" + CACHE_FILE;
	Log.d(TAG, "Saving geofencing state to" + path);
	try
	{
		Output output = new Output(new FileOutputStream(path));
		serialiser.writeObject(output, this);
		output.close();
	}
	catch (FileNotFoundException e)
	{
		Log.e(TAG, "Could not serialise geofencing data", e);
	}
}
 
開發者ID:martijndeh,項目名稱:react-native-region-monitor,代碼行數:19,代碼來源:PersistableData.java

示例6: serialize

import com.esotericsoftware.kryo.Kryo; //導入方法依賴的package包/類
/**
 * 序列化
 *
 * @param obj 需要序更列化的對象
 * @return 序列化後的byte 數組
 * @throws MythException 異常
 */
@Override
public byte[] serialize(Object obj) throws MythException {
    byte[] bytes;
    try (ByteArrayOutputStream outputStream = new ByteArrayOutputStream()) {
        //獲取kryo對象
        Kryo kryo = new Kryo();
        Output output = new Output(outputStream);
        kryo.writeObject(output, obj);
        bytes = output.toBytes();
        output.flush();
    } catch (Exception ex) {
        throw new MythException("kryo serialize error" + ex.getMessage());
    }
    return bytes;
}
 
開發者ID:yu199195,項目名稱:myth,代碼行數:23,代碼來源:KryoSerializer.java

示例7: write

import com.esotericsoftware.kryo.Kryo; //導入方法依賴的package包/類
@Override
public void write(final Kryo kryo, final Output output, final TableMetadata table) {
  try{
    Preconditions.checkArgument(!table.isPruned(), "Cannot serialize a pruned table.");
  }catch(NamespaceException ex){
    throw Throwables.propagate(ex);
  }

  kryo.writeObject(output, table.getName().getPathComponents());
}
 
開發者ID:dremio,項目名稱:dremio-oss,代碼行數:11,代碼來源:TableMetadataSerializer.java

示例8: serialize

import com.esotericsoftware.kryo.Kryo; //導入方法依賴的package包/類
@Test
    public void serialize() throws Exception {
        String testFilePath = getClass().getClassLoader().getResource("lstm_har-data").getFile();
        String inputFilePath =
                testFilePath + File.separator + "test_data" + File.separator + "sensor";
        final float[][][] inputs;

        final Kryo kryo = new Kryo();
        kryo.register(float[][][].class);
        final File dataBinFile = new File("data-small.bin");
        if (dataBinFile.exists()) {
            Input input = new Input(new FileInputStream(dataBinFile));
            inputs = kryo.readObject(input, float[][][].class);
            input.close();
        } else {
            inputs = DataUtil.parseInputData(inputFilePath);
            Output output = new Output(new FileOutputStream(dataBinFile));

            kryo.writeObject(output, inputs);
            output.close();
        }

//        Gson gson = new Gson();
//        final File dataBinFile = new File("data.json");
//        if (dataBinFile.exists()) {
//            inputs = gson.fromJson(FileUtils.readFileToString(dataBinFile), float[][][].class);
//        } else {
//            inputs = DataUtil.parseInputData(inputFilePath);
//            String result = gson.toJson(inputs);
//            FileUtils.writeStringToFile(new File("data.json"), result);
//        }


    }
 
開發者ID:csarron,項目名稱:MobiRNN-EMDL17,代碼行數:35,代碼來源:DataUtilTest.java

示例9: write

import com.esotericsoftware.kryo.Kryo; //導入方法依賴的package包/類
@Override
public void write(final Kryo kryo, final Output output, final T operator) {
  final int identity = System.identityHashCode(operator);
  final Integer ordinal = OperatorPopulator.FORWARD.get(identity);
  final boolean isKnown = ordinal != null;
  kryo.writeObject(output, isKnown);
  if (isKnown) {
    kryo.writeObject(output, ordinal);
    return;
  }

  super.write(kryo, output, operator);
}
 
開發者ID:dremio,項目名稱:dremio-oss,代碼行數:14,代碼來源:SqlOperatorSerializer.java

示例10: write

import com.esotericsoftware.kryo.Kryo; //導入方法依賴的package包/類
@Override
public void write(Kryo kryo, Output output, ImmutableMap<?, ?> object) {
    // wrapping with unmodifiableMap proxy
    // to avoid Kryo from writing only the reference marker of this instance,
    // which will be embedded right before this method call.
    kryo.writeObject(output, Collections.unmodifiableMap(object), mapSerializer);
}
 
開發者ID:shlee89,項目名稱:athena,代碼行數:8,代碼來源:ImmutableMapSerializer.java

示例11: write

import com.esotericsoftware.kryo.Kryo; //導入方法依賴的package包/類
public void write (Kryo kryo, Output output, T map) {
    int length = map.size;
    output.writeVarInt(length, true);
    output.writeBoolean(false); // whether type is written (in case future version of ObjectMap supports type awareness)

    Serializer keySerializer = null;
    if (keyGenericType != null) {
        if (keySerializer == null) keySerializer = kryo.getSerializer(keyGenericType);
        keyGenericType = null;
    }
    Serializer valueSerializer = null;
    if (valueGenericType != null) {
        if (valueSerializer == null) valueSerializer = kryo.getSerializer(valueGenericType);
        valueGenericType = null;
    }

    for (Iterator iter = map.iterator(); iter.hasNext();) {
        ObjectMap.Entry entry = (ObjectMap.Entry)iter.next();
        if (keySerializer != null) {
            kryo.writeObject(output, entry.key, keySerializer);
        } else
            kryo.writeClassAndObject(output, entry.key);
        if (valueSerializer != null) {
            kryo.writeObjectOrNull(output, entry.value, valueSerializer);
        } else
            kryo.writeClassAndObject(output, entry.value);
    }
}
 
開發者ID:CypherCove,項目名稱:gdx-cclibs,代碼行數:29,代碼來源:ObjectMapSerializer.java

示例12: write

import com.esotericsoftware.kryo.Kryo; //導入方法依賴的package包/類
@Override
public void write(Kryo kryo, Output output, EncodedDiscreteResources object) {
    List<ClosedOpenRange> ranges = object.rangeSet().asRanges().stream()
            .map(ClosedOpenRange::of)
            .collect(Collectors.toList());
    kryo.writeObject(output, ranges);
    kryo.writeClassAndObject(output, object.codec());
}
 
開發者ID:shlee89,項目名稱:athena,代碼行數:9,代碼來源:EncodedResourcesSerializer.java

示例13: write

import com.esotericsoftware.kryo.Kryo; //導入方法依賴的package包/類
@Override
public void write(final Kryo kryo, final Output output, final T object) {
  final boolean isKnown = collationSet.contains(object);
  kryo.writeObject(output, isKnown);
  if (isKnown) {
    kryo.writeObject(output, object.equals(RelCollations.EMPTY) ? 0 : 1);
    return;
  }

  super.write(kryo, output, object);
}
 
開發者ID:dremio,項目名稱:dremio-oss,代碼行數:12,代碼來源:RelTraitSerializers.java

示例14: write

import com.esotericsoftware.kryo.Kryo; //導入方法依賴的package包/類
@Override
public void write(final Kryo kryo, final Output output, final URL url) {
    kryo.writeObject(output, url.toExternalForm());
}
 
開發者ID:hsj-xiaokang,項目名稱:springboot-shiro-cas-mybatis,代碼行數:5,代碼來源:URLSerializer.java

示例15: write

import com.esotericsoftware.kryo.Kryo; //導入方法依賴的package包/類
@Override
public void write(final Kryo kryo, final Output output, final ZonedDateTime dateTime) {
    kryo.writeObject(output, dateTime.toInstant().toEpochMilli());
    kryo.writeObject(output, dateTime.getZone().getId());
}
 
開發者ID:mrluo735,項目名稱:cas-5.1.0,代碼行數:6,代碼來源:ZonedDateTimeTranscoder.java


注:本文中的com.esotericsoftware.kryo.Kryo.writeObject方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。