📄 sendmessage.java
字号:
/* * @(#)$Id: SendMessage.java,v 1.8 2004/11/23 22:33:17 huebsch Exp $ * * Copyright (c) 2001-2004 Regents of the University of California. * All rights reserved. * * This file is distributed under the terms in the attached BERKELEY-LICENSE * file. If you do not find these files, copies can be found by writing to: * Computer Science Division, Database Group, Universite of California, * 617 Soda Hall #1776, Berkeley, CA 94720-1776. Attention: Berkeley License * * Copyright (c) 2003-2004 Intel Corporation. All rights reserved. * * This file is distributed under the terms in the attached INTEL-LICENSE file. * If you do not find these files, copies can be found by writing to: * Intel Research Berkeley, 2150 Shattuck Avenue, Suite 1300, * Berkeley, CA, 94704. Attention: Intel License Inquiry. */package overlay.provider.basic;import services.network.Payload;import util.BitID;import util.FreeList;import util.FreeListFactory;import util.network.serialization.GenericByteBuffer;import util.network.serialization.SerializationManager;import util.network.serialization.SerializeBool;/** * Class SendMessage * */public class SendMessage extends ProviderMessage { public static long serialVersionUID = SerializationManager.getSerialUID("overlay.provider.basic.SendMessage"); // the instance ID of the item private int iid; // the item's lifetime private long lifetime; private boolean sendLocal; // the actual item private Payload item; // free list of objects for better memory management private static FreeList freeList = new FreeList(new SendMessageFactory()); /** * DeSerialize the object from the provided GenericByteBuffer. * * @param inputBuffer */ public SendMessage(GenericByteBuffer inputBuffer) { super(inputBuffer); this.iid = inputBuffer.getInt(); this.lifetime = inputBuffer.getLong(); this.sendLocal = SerializeBool.deSerialize(inputBuffer); this.item = SerializationManager.deSerialize(inputBuffer); this.size += Payload.INT_SIZE + Payload.LONG_SIZE; if (this.item != null) { this.size += SerializationManager.getPayloadSize(this.item); } } /** * Serialize the object into the provided GenericByteBuffer. * * @param outputBuffer * @return */ public long serialize(GenericByteBuffer outputBuffer) { super.serialize(outputBuffer); outputBuffer.putInt(iid); outputBuffer.putLong(lifetime); SerializeBool.serialize(outputBuffer, sendLocal); SerializationManager.serialize(outputBuffer, item); return serialVersionUID; } /** * Constructor SendMessage */ protected SendMessage() {} private void init(Integer messageID, String ns, String rid, BitID locationID, int iid, long lifetime, boolean sendLocal, Payload item) { super.init(messageID, ns, rid, locationID); this.iid = iid; this.lifetime = lifetime; this.sendLocal = sendLocal; this.item = item; // set the size size += Payload.INT_SIZE + Payload.LONG_SIZE; if (item != null) { size += SerializationManager.getPayloadSize(item); } } /** * Method getIID * @return */ public int getIID() { return iid; } /** * Method getLifetime * @return */ public long getLifetime() { return lifetime; } /** * Method getSendLocal * @return */ public boolean getSendLocal() { return sendLocal; } /** * Method getItem * @return */ public Payload getItem() { return item; } /** * Method allocate * * @param messageID * @param ns * @param rid * @param locationID * @param iid * @param lifetime * @param sendLocal * @param item * @return */ public static SendMessage allocate(Integer messageID, String ns, String rid, BitID locationID, int iid, long lifetime, boolean sendLocal, Payload item) { SendMessage message = (SendMessage) freeList.allocate(); message.init(messageID, ns, rid, locationID, iid, lifetime, sendLocal, item); return message; } /** * Method free * * @param message */ public static void free(SendMessage message) { freeList.free(message); }}/** * Class SendMessageFactory * */class SendMessageFactory implements FreeListFactory { /** * Method create * @return */ public Object create() { return new SendMessage(); }}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -