本文整理匯總了Java中java.nio.ByteBuffer.putShort方法的典型用法代碼示例。如果您正苦於以下問題:Java ByteBuffer.putShort方法的具體用法?Java ByteBuffer.putShort怎麽用?Java ByteBuffer.putShort使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類java.nio.ByteBuffer
的用法示例。
在下文中一共展示了ByteBuffer.putShort方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: convert
import java.nio.ByteBuffer; //導入方法依賴的package包/類
public static ByteBuffer convert(byte[] audioData,
@IntRange(from = 0) int read,
@NonNull String requestId) {
String builder = PATH.getValue() + ": " + AUDIO.getValue() + CRLF.getValue() +
X_REQUEST_ID.getValue() + ": " + requestId + CRLF.getValue() +
X_TIMESTAMP.getValue() + ": " + CurrentTime.newTime() + CRLF.getValue() +
CONTENT_TYPE.getValue() + ": " + AUDIO_WAV.getValue() + CRLF.getValue() + CRLF.getValue();
byte[] header = builder.getBytes(UTF_8);
ByteBuffer byteBuffer = ByteBuffer.allocate(2 + header.length + read);
byteBuffer.putShort(toShort(header.length));
byteBuffer.put(header);
if (read > 0) byteBuffer.put(audioData, 0, read);
return byteBuffer;
}
示例2: serialize
import java.nio.ByteBuffer; //導入方法依賴的package包/類
/**
* Serialize this Membership Report.
*
* @param bb the ByteBuffer to write into, positioned at the next spot to be written to.
* @return serialized IGMP message.
*/
@Override
public byte[] serialize(ByteBuffer bb) {
bb.put(recordType);
bb.put(auxDataLength); // reserved
bb.putShort((short) sources.size());
bb.put(gaddr.toOctets());
for (IpAddress ipaddr : sources) {
bb.put(ipaddr.toOctets());
}
if (auxDataLength > 0) {
bb.put(auxData);
}
return bb.array();
}
示例3: createSocks4aMessage
import java.nio.ByteBuffer; //導入方法依賴的package包/類
private ByteBuffer[] createSocks4aMessage() {
ByteBuffer handshake = ByteBuffer.allocate( 256 + mapped_ip.length() ); //TODO convert to direct?
handshake.put( (byte)4 ); // socks 4(a)
handshake.put( (byte)1 ); // command = CONNECT
handshake.putShort( (short)remote_address.getPort() ); // port
handshake.put( (byte)0 );
handshake.put( (byte)0 );
handshake.put( (byte)0 );
handshake.put( (byte)1 ); // indicates socks 4a
if( socks_user.length() > 0 ) {
handshake.put( socks_user.getBytes() );
}
handshake.put( (byte)0 );
handshake.put( mapped_ip.getBytes() );
handshake.put( (byte)0 );
handshake.flip();
return new ByteBuffer[] { handshake, ByteBuffer.allocate( 8 ) }; //TODO convert to direct?
}
示例4: push0x20
import java.nio.ByteBuffer; //導入方法依賴的package包/類
private void push0x20() throws Exception{
if(has0x20Message() == false){
return;
}
if((this.lastAddr == null || (System.currentTimeMillis() - this.lastTick)>1000*PUSH_IM_AFTER_ACTIVE_SECOND) && this.getMessengerTask() == null ){
return;
}
byte[] data = new byte[Constant.SERVER_MESSAGE_MIN_LENGTH+message0x20Len];
ByteBuffer bb = ByteBuffer.wrap(data);
bb.put((byte)1);//version
bb.put((byte)0);//app id, 0 here
bb.put((byte)ClientStatMachine.CMD_0x20);//cmd
bb.putShort((short)message0x20Len);
bb.put(this.message0x20);
bb.flip();
ServerMessage sm = new ServerMessage(this.lastAddr, data);
if(this.lastAddr != null && (System.currentTimeMillis() - this.lastTick)<1000*PUSH_IM_AFTER_ACTIVE_SECOND){
IMServer.getInstance().pushInstanceMessage(sm);
}
if(this.getMessengerTask() != null){
try{this.getMessengerTask().pushInstanceMessage(sm);}catch(Exception e){};
}
}
示例5: writeFirstVideoTag
import java.nio.ByteBuffer; //導入方法依賴的package包/類
/**
* 第一個視頻Tag,需要寫入AVC視頻流的configuretion信息,這個信息根據pps、sps生成
* 8 bit configuration version ------ 版本號
* 8 bit AVC Profile Indication ------- sps[1]
* 8 bit Profile Compatibility ------- sps[2]
* 8 bit AVC Level Compatibility ------- sps[3]
* 6 bit Reserved ------- 111111
* 2 bit Length Size Minus One ------- NAL Unit Length長度為-1,一般為3
* 3 bit Reserved ------- 111
* 5 bit Num of Sequence Parameter Sets ------- sps個數,一般為1
* ? bit Sequence Parameter Set NAL Units ------- (sps_size + sps)的數組
* 8 bit Num of Picture Parameter Sets ------- pps個數,一般為1
* ? bit Picture Parameter Set NAL Units ------- (pps_size + pps)的數組
* @param sps
* @param pps
* @return
*/
public static void writeFirstVideoTag(ByteBuffer buffer, byte[] sps, byte[] pps) {
//寫入Flv Video Header
writeVideoHeader(buffer, FlvVideoFrameType.KeyFrame, FlvVideoCodecID.AVC, FlvVideoAVCPacketType.SequenceHeader);
buffer.put((byte)0x01);
buffer.put(sps[1]);
buffer.put(sps[2]);
buffer.put(sps[3]);
buffer.put((byte)0xff);
buffer.put((byte)0xe1);
buffer.putShort((short)sps.length);
buffer.put(sps);
buffer.put((byte)0x01);
buffer.putShort((short)pps.length);
buffer.put(pps);
}
示例6: toByteArray
import java.nio.ByteBuffer; //導入方法依賴的package包/類
@Override
public final byte[] toByteArray(boolean shrink) {
ByteBuffer buffer = ByteBuffer.allocate(size());
buffer.order(ByteOrder.LITTLE_ENDIAN);
buffer.putShort((short) headerSize());
buffer.putShort((short) flags());
buffer.putInt(keyIndex());
if (isComplex()) {
buffer.putInt(parentEntry());
buffer.putInt(values().size());
for (Map.Entry<Integer, ResourceValue> entry : values().entrySet()) {
buffer.putInt(entry.getKey());
buffer.put(entry.getValue().toByteArray(shrink));
}
} else {
ResourceValue value = value();
Preconditions.checkNotNull(value, "A non-complex TypeChunk entry must have a value.");
buffer.put(value.toByteArray());
}
return buffer.array();
}
示例7: stringToBuffer
import java.nio.ByteBuffer; //導入方法依賴的package包/類
public static ByteBuffer stringToBuffer(String message) {
byte[] bytes = message.getBytes(StandardCharsets.UTF_8);
ByteBuffer result = ByteBuffer.allocate(bytes.length + Short.BYTES);
result.putShort((short) bytes.length);
result.put(bytes);
result.flip();
return result;
}
示例8: fillHeader
import java.nio.ByteBuffer; //導入方法依賴的package包/類
public void fillHeader(ByteBuffer buffer)
{
buffer.put((byte) (this.version << 4 | this.IHL));
buffer.put((byte) this.typeOfService);
buffer.putShort((short) this.totalLength);
buffer.putInt(this.identificationAndFlagsAndFragmentOffset);
buffer.put((byte) this.TTL);
buffer.put((byte) this.protocol.getNumber());
buffer.putShort((short) this.headerChecksum);
buffer.put(this.sourceAddress.getAddress());
buffer.put(this.destinationAddress.getAddress());
}
示例9: create_joystick
import java.nio.ByteBuffer; //導入方法依賴的package包/類
public static byte[] create_joystick(short left_x, short left_y, short right_x, short right_y) {
ByteBuffer buffer = ByteBuffer.allocate(12);
buffer.putShort(0, Constants.COMMAND_INPUT_JOYSTICK); // type
buffer.putShort(2, (short) 8); // payload_size
buffer.putShort(4, left_x);
buffer.putShort(6, left_y);
buffer.putShort(8, right_x);
buffer.putShort(10, right_y);
return buffer.array();
}
示例10: serialize
import java.nio.ByteBuffer; //導入方法依賴的package包/類
public byte[] serialize() {
// type = 7 bits
// info string length 9 bits, each value == byte
// info string
short scratch = (short) (((0x7f & this.type) << 9) | (0x1ff & this.length));
byte[] data = new byte[2+this.length];
ByteBuffer bb = ByteBuffer.wrap(data);
bb.putShort(scratch);
if (this.value != null)
bb.put(this.value);
return data;
}
示例11: writeMap
import java.nio.ByteBuffer; //導入方法依賴的package包/類
public static void writeMap(ByteBuffer buffer, Map<Integer,Integer> map) {
if (map==null || map.isEmpty()){
buffer.putShort((byte)0);
return;
}
short size = (short) map.size();
buffer.putShort(size);
for (Integer key : map.keySet()){
buffer.putInt(key);
buffer.putInt(map.get(key));
}
}
示例12: createNoClose
import java.nio.ByteBuffer; //導入方法依賴的package包/類
private static SeekableByteChannel createNoClose(Path p)
throws IOException {
SeekableByteChannel newChan = Files.newByteChannel(
p, StandardOpenOption.CREATE,
StandardOpenOption.TRUNCATE_EXISTING,
StandardOpenOption.WRITE);
ByteBuffer buffer = ByteBuffer.allocate(6);
buffer.putShort((short)KRB5_RV_VNO);
buffer.order(ByteOrder.nativeOrder());
buffer.putInt(KerberosTime.getDefaultSkew());
buffer.flip();
newChan.write(buffer);
return newChan;
}
示例13: gen0x00Message
import java.nio.ByteBuffer; //導入方法依賴的package包/類
private void gen0x00Message(ClientMessage cm, ArrayList<ServerMessage> smList) throws Exception{
byte[] data = new byte[Constant.SERVER_MESSAGE_MIN_LENGTH];//5 bytes
ByteBuffer bb = ByteBuffer.wrap(data);
bb.put((byte)1);//version
bb.put(cm.getData()[1]);//app id
bb.put((byte)ClientStatMachine.CMD_0x00);//cmd
bb.putShort((short)0);//length 0
bb.flip();
ServerMessage sm = new ServerMessage(cm.getSocketAddress(), data);
smList.add(sm);
}
示例14: serialize
import java.nio.ByteBuffer; //導入方法依賴的package包/類
public byte[] serialize() {
byte[] payloadData = null;
if (payload != null) {
payload.setParent(this);
payloadData = payload.serialize();
}
int length = 14 + ((vlanID == VLAN_UNTAGGED) ? 0 : 4) +
((payloadData == null) ? 0 : payloadData.length);
if (pad && length < 60) {
length = 60;
}
byte[] data = new byte[length];
ByteBuffer bb = ByteBuffer.wrap(data);
bb.put(destinationMACAddress.getBytes());
bb.put(sourceMACAddress.getBytes());
if (vlanID != VLAN_UNTAGGED) {
bb.putShort((short) EthType.VLAN_FRAME.getValue());
bb.putShort((short) ((priorityCode << 13) | (vlanID & 0x0fff)));
}
bb.putShort((short) etherType.getValue());
if (payloadData != null)
bb.put(payloadData);
if (pad) {
Arrays.fill(data, bb.position(), data.length, (byte)0x0);
}
return data;
}
示例15: clearAllLocal
import java.nio.ByteBuffer; //導入方法依賴的package包/類
/**
* Remove all the local of a context (but keep global).
*
* @param context a counter context
* @return a version of {@code context} where no shards are local.
*/
public ByteBuffer clearAllLocal(ByteBuffer context)
{
int count = Math.abs(context.getShort(context.position()));
if (count == 0)
return context; // no local or global shards present.
List<Short> globalShardIndexes = new ArrayList<>(count);
for (int i = 0; i < count; i++)
{
short elt = context.getShort(context.position() + HEADER_SIZE_LENGTH + i * HEADER_ELT_LENGTH);
if (elt < 0)
globalShardIndexes.add(elt);
}
if (count == globalShardIndexes.size())
return context; // no local shards detected.
// allocate a smaller BB for the cleared context - with no local header elts.
ByteBuffer cleared = ByteBuffer.allocate(context.remaining() - (count - globalShardIndexes.size()) * HEADER_ELT_LENGTH);
cleared.putShort(cleared.position(), (short) globalShardIndexes.size());
for (int i = 0; i < globalShardIndexes.size(); i++)
cleared.putShort(cleared.position() + HEADER_SIZE_LENGTH + i * HEADER_ELT_LENGTH, globalShardIndexes.get(i));
int origHeaderLength = headerLength(context);
ByteBufferUtil.arrayCopy(context,
context.position() + origHeaderLength,
cleared,
cleared.position() + headerLength(cleared),
context.remaining() - origHeaderLength);
return cleared;
}