- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
如果已知它是其他缓冲区?
我知道这可以通过非直接数组支持的 ByteBuffer
使用 arrayOffset()
方法来完成,如下所示:
int getRelativeBufferOffset(ByteBuffer parentBuffer, ByteBuffer childBuffer)
{
return childBuffer.arrayOffset() - parentBuffer.arrayOffset();
}
void example()
{
ByteBuffer buffer1 = ByteBuffer.allocate(10000);
buffer1 .position(22);
ByteBuffer buffer2 = buffer1.slice();
buffer2.position(55);
ByteBuffer buffer3 = buffer2.slice();
// returns 22
getRelativeBufferOffset(buffer1, buffer2);
// returns 55
getRelativeBufferOffset(buffer2, buffer3);
// returns 77
getRelativeBufferOffset(buffer1, buffer3);
}
我认为没有任何东西可以免费用于直接缓冲区。为了获得类似的东西,我能想到的最佳选择是扩展 ByteBuffer
以存储对创建它的缓冲区(父缓冲区)的引用以及相对于父缓冲区的零位置它的创建位置。
编辑:令人恼火的是,我似乎无法扩展 ByteBuffer
,因为它的构造函数都不可见。我想我将不得不编写某种包装类。
最佳答案
这是可能的,使用反射。但根据您想要实现的目标,您应该考虑替代解决方案。目前尚不清楚您需要此偏移量的目的。 “务实”的建议是将缓冲区包装到一个简单的、自己的类中,比如
class SlicedBuffer {
int getBuffer() { ... }
Buffer getParent() { ... }
int getOffsetToParent() { ... }
}
并使用这个,但不清楚这是否适用于您的情况。
我将在此处发布使用反射的代码,但请注意
// Many things...
// ... can go ...
// ... wrong when...
// ... using reflection
所以这只是一个演示:
import java.lang.reflect.Field;
import java.nio.Buffer;
import java.nio.ByteBuffer;
public class DirectByteBufferSliceOffsetsTest
{
public static void main(String[] args)
{
testArray();
testDirect();
}
private static void testArray()
{
System.out.println("Array: ");
ByteBuffer buffer1 = ByteBuffer.allocate(10000);
buffer1.position(22);
ByteBuffer buffer2 = buffer1.slice();
buffer2.position(55);
ByteBuffer buffer3 = buffer2.slice();
// prints 22
System.out.println(getRelativeBufferOffsetArray(buffer1, buffer2));
// prints 55
System.out.println(getRelativeBufferOffsetArray(buffer2, buffer3));
// prints 77
System.out.println(getRelativeBufferOffsetArray(buffer1, buffer3));
}
private static int getRelativeBufferOffsetArray(
ByteBuffer parentBuffer, ByteBuffer childBuffer)
{
return childBuffer.arrayOffset() - parentBuffer.arrayOffset();
}
private static void testDirect()
{
System.out.println("Direct: ");
ByteBuffer buffer1 = ByteBuffer.allocateDirect(10000);
buffer1.position(22);
ByteBuffer buffer2 = buffer1.slice();
buffer2.position(55);
ByteBuffer buffer3 = buffer2.slice();
// prints 22
System.out.println(getRelativeBufferOffsetDirect(buffer1, buffer2));
// prints 55
System.out.println(getRelativeBufferOffsetDirect(buffer2, buffer3));
// prints 77
System.out.println(getRelativeBufferOffsetDirect(buffer1, buffer3));
}
private static int getRelativeBufferOffsetDirect(
ByteBuffer parentBuffer, ByteBuffer childBuffer)
{
long parentAddress = getAddress(parentBuffer);
long childAddress = getAddress(childBuffer);
int offset = (int)(childAddress - parentAddress);
return offset;
}
private static long getAddress(Buffer buffer)
{
Field f = null;
try
{
f = Buffer.class.getDeclaredField("address");
f.setAccessible(true);
return f.getLong(buffer);
}
catch (NoSuchFieldException e)
{
// Many things...
e.printStackTrace();
}
catch (SecurityException e)
{
// ... can go ...
e.printStackTrace();
}
catch (IllegalArgumentException e)
{
// ... wrong when...
e.printStackTrace();
}
catch (IllegalAccessException e)
{
// ... using reflection
e.printStackTrace();
}
finally
{
if (f != null)
{
f.setAccessible(false);
}
}
return 0;
}
}
关于java - 获取相对于原始 ByteBuffer 的直接 ByteBuffer 切片位置,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25566539/
简而言之: 我怎样才能切片?也就是说,能够指定我想从多个索引(例如 y = x[(2, 5, 11)] )中提取,而不仅仅是单个索引(例如 y = x[2] )。 简单示例 : 说我有这个数据: d
是否可以在 F# 中对 Array2D 进行切片? 说,let tmp =Array2D.init 100 100 (fun x y -> x * 100 + y) 如何从 tmp 中检索某些列或某些
例如,我希望文本仅显示“此处”,但它不起作用。文本经常变化,但我需要的单词保持在固定位置。我想访问该词。 我做错了什么? function myFunction() { var x = doc
当尝试使用spring的分页或切片来迭代非常大的mongodb集合时,程序运行正常,但在某些时候下一页/切片为空,并且在调试时出现“包含未知实例的页面/切片”消息. 这是代码示例: do { Pa
有人能给我一个关于如何分割 ListView 的例子吗?我正在使用 SimpleCursorAdapter 在 ListView 中显示数据.. 我的代码是这样的。 private WordDbAda
这个问题在这里已经有了答案: C++ slicing causing leak / undefined behavior / crash (3 个答案) 关闭 8 年前。 如果我有如下代码: cla
这个问题在这里已经有了答案: Understanding slicing (38 个答案) 关闭 5 年前。 我目前有 500 行数据。我想使用前五十行,然后跳过 50 行,依此类推。我该如何继续这
为什么对一行或一列进行切片会产生“无量纲数组”?例如: import numpy as np arr = np.zeros((10,10)) print arr.shape # (10, 10) 但是
我有以下 pandas 数据框: Shortcut_Dimension_4_Code Stage_Code 10225003 2 8225003
如何通过数组为 ruby 中的散列创建切片,如下所示: info = { :key1 => "Lorem", :key2 => "something...", :key3 => "
这个问题在这里已经有了答案: regex to get all text outside of brackets (4 个答案) 关闭 5 年前。 我正在编写的这个程序接收到一个大小不同的字符串,其
我尝试使用 tf.Tensor.getitem 对张量进行切片功能如下: indices = [0, 5] data[:,:,indices] 但是我得到以下错误: TypeError: can on
这个问题在这里已经有了答案: Can I create a "view" on a Python list? (10 个答案) 关闭 7 年前。 有没有一种方法可以在 Python 3 中创建序列的
我想弄清楚如何从多维数组中获取单个维度(为了论证,假设它是二维的),我有一个多维数组: double[,] d = new double[,] { { 1, 2, 3, 4, 5 }, { 5, 4,
我有一个 std::vector。我想创建代表该 vector 切片的迭代器。我该怎么做?在伪 C++ 中: class InterestingType; void doSomething(slice
写在前面 前面的文章介绍了Go的一些基本类型,本文开始涉及Go的一些容器类型,它们都是可以包含多个元素的数据结构,如数组、切片、map 数组 数组是具有相同类型且长度固定的一组元素集合,定义的格式:v
给定一个 numpy 数组和一个 __getitem__ 类型的索引,是否有一种惯用的方法来获取数组的相应切片,总是返回一个数组而不是标量? 有效索引的示例包括:int、slice、省略号或上述的元组
我创建了一个继承自 pandas.DataFrame 的类。在此类中添加了元数据(不是添加到列中,而是添加到类实例中): class MeasurementPoint(pandas.DataFrame
我想在空间上剪切视频以生成 N x M 个文件。 例如,我想把 test.video 拆分成 NxM 的瓦片? Video tiles 最佳答案 您可以使用 ffmpeg 及其 crop filter
这是一个示例代码。比如我想拉德国 在页面加载时切片。在这段代码中,它拉取第一个切片。 无功图; var 传说; var chartData = [{ 国家:“立陶宛”, 值:260}, { 国家:“爱
我是一名优秀的程序员,十分优秀!