blob: 84a51acf5d33730dab3c56b19f32da36677e8d4d [file] [log] [blame]
/* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package java.nio;
import org.apache.harmony.luni.platform.PlatformAddress;
/**
* Helper class for operations on direct ByteBuffer
*
* @see java.nio.ByteBuffer
*/
class DirectByteBuffers {
/**
* Explicitly frees the memory used by the given direct byte buffer.
* <p>
* If the memory is known to already have been freed then this is a no-op.
* Once the memory has been freed then operations requiring access to the
* memory will throw an <code>IllegalStateException</code>.
* <p>
* Note this is is possible that the memory is freed by code that reaches
* into the address and explicitly frees it 'beneith' us -- this is bad
* form.
*
* @param directBuffer
* the direct byte buffer memory to free
* @throws IllegalArgumentException
* if the buffer is <code>null</code> or is not a
* <em>direct</em> byte buffer.
*/
public static void free(ByteBuffer directBuffer) {
if ((directBuffer == null) || (!directBuffer.isDirect())) {
throw new IllegalArgumentException();
}
DirectByteBuffer buf = (DirectByteBuffer) directBuffer;
buf.free();
}
/**
* Returns the platform address of the start of this buffer instance.
* <em>You must not attempt to free the returned address!!</em> It may not
* be an address that was explicitly malloc'ed (i.e. if this buffer is the
* result of a split); and it may be memory shared by multiple buffers.
* <p>
* If you can guarantee that you want to free the underlying memory call the
* #free() method on this instance -- generally applications will rely on
* the garbage collector to autofree this memory.
*
* @param directBuffer
* the direct byte buffer
* @return the effective address of the start of the buffer.
* @throws IllegalStateException
* if this buffer address is known to have been freed
* previously.
*/
public static PlatformAddress getEffectiveAddress(ByteBuffer directBuffer) {
return toDirectBuffer(directBuffer).getEffectiveAddress();
}
private static DirectByteBuffer toDirectBuffer(ByteBuffer directBuffer) {
if ((directBuffer == null) || (!directBuffer.isDirect())) {
throw new IllegalArgumentException();
}
return (DirectByteBuffer) directBuffer;
}
}