给定一个字节数组,我如何在其中找到(较小)字节数组的位置?
使用ArrayUtils
,该文档看起来很有希望,但是如果我正确的话,那只会让我在要搜索的数组中找到一个单独的字节。
(我认为这并不重要,但以防万一:有时搜索字节数组将是常规的ASCII字符,有时是控制字符或扩展的ASCII字符。因此使用String操作并不总是合适的)
大数组可能在10到10000个字节之间,而小数组大约在10个字节。在某些情况下,我会通过一次搜索在大数组中找到几个较小的数组。我有时会想要查找实例的最后一个索引,而不是第一个。
Java字符串由16位char
而不是8位组成byte
。A
char
可以容纳一个byte
,因此您始终可以将字节数组变成字符串,并使用indexOf
:ASCII字符,控制字符,甚至零个字符都可以正常工作。
这是一个演示:
byte[] big = new byte[] {1,2,3,0,4,5,6,7,0,8,9,0,0,1,2,3,4};
byte[] small = new byte[] {7,0,8,9,0,0,1};
String bigStr = new String(big, StandardCharsets.UTF_8);
String smallStr = new String(small, StandardCharsets.UTF_8);
System.out.println(bigStr.indexOf(smallStr));
打印7
。
但是,考虑到大数组最多可以容纳10,000个字节,而小数组只有十个字节,此解决方案可能不是最有效的,原因有两个:
char
代替byte
)。这使您的内存需求增加了三倍。我想知道是否可以将一个数组查找到另一个数组中。我不感兴趣的是寻找数组的单个元素,而是数组作为一个整体。我试过一些代码 编辑:使用的原因是我的数组的大小,粗略计算,可能是大约1000万。我想要一种高效的搜索技术。 我不确定我的代码是否应该工作。我有很多错误 bm.cpp:12:20:error:“make_boyer_moore_searcher”不是“std”std::make_boyer_moo
问题内容: 我有两个numpy数组A和B。A包含唯一值,而B是A的子数组。 例如: 问题答案: 您可以使用带有- 如果您关心维护订单,也可以使用- 对于一般情况,当&是未排序的数组时,您可以在中引入选项,就像这样- 为了解决一般情况,我还会添加我最喜欢的内容- 样品运行-
我是一名编程初学者,并尝试使用处理来实现简单的数据可视化。为了测试,我创建了一个csv文件,其中列出了三列数据,其中第二列和第三列是数字。我分析了这些列,并尝试将第二列数字与第三列数字分开。但不幸的是,结果显示为零。 代码是
问题内容: 最近有人要求我为一份工作编写3个测试程序。它们将仅使用核心Java API和我选择的任何测试框架来编写。应在适当的地方实施单元测试。 尽管我根本没有收到任何反馈,但我想他们不喜欢我的解决方案(否则我会收到他们的来信),所以我决定在这里展示我的程序,并询问这种实现是否可以认为是好的,并且,如果没有,那为什么呢? 为避免混淆,我现在只问第一个。 实现一个函数,以在另一个更大的数组中查找一个
问题内容: 在Java中,如何获取byte []数组并从数组中删除前16个字节?我知道我可能必须通过将阵列复制到新阵列中来执行此操作。任何例子或帮助将不胜感激。 问题答案: 参见Java库中的类:
本文向大家介绍用Java在一行中比较两个字节的数组,包括了用Java在一行中比较两个字节的数组的使用技巧和注意事项,需要的朋友参考一下 可以使用java.util.Arrays.equals()方法在Java中比较两个字节数组。如果数组相等,则此方法返回true,否则返回false。如果两个数组以相同顺序包含相同数量的元素,则它们相等。给出了一个使用Arrays.equals()方法比较两个字节数