- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我有这样的十六进制数范围
0xabcd****
0xabdc**89
0x****abcd
0xde****ab
# 50 or so more entries like these
# where * is any hex number
我需要一个散列函数,它将接受一个 4 字节的值并为成员生成 Y/N 答案。
我尝试使用 gperf 但遗憾的是它不会将 * 解释为通配符。有没有人遇到过这个问题?我的代码在 C 中。
最佳答案
如果我可以相信我的算法,每个 ****
都有 16^4 个可能的值,所以四个通配符规范枚举 3 * 16^4 + 16^2
值 - 大约 200,000 - 有点超出 gperf 的范围(它的文档说“大” key 集是 15,000)。
通配符对我来说意味着正则表达式,为什么不试试呢?这是将“4 字节值”定义为 uint32_t 的尝试,并将此类值的文本编码呈现给 regex(3)
机制。这可能不是您要找的东西,但拼凑起来很有趣,给您吧。
#include <sys/types.h>
#include <regex.h>
#include <stdint.h>
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <unistd.h>
static regex_t the_re;
int
matcher_init(void)
{
static const char the_re_string[] = "(abcd....|abdc..89|....abcd|de....ab|"
/* OP's 4, plus 46 more... */
"..d80a..|..7bc5..|c6..514a|..b7585a|"
"4732ecc4|7c22e4da|5a5e..63|....e866|"
"..fdc367|ac....b4|70249edc|..e97e32|"
"....94d8|....fa6c|4591..ff|..e4..67|"
"aab285..|....f81b|15bb22ba|3cf4....|"
"57d3ad86|..bd..1e|..ec67b7|..693aaf|"
"323c..18|cab237cb|d4b2c6b4|2a15..2f|"
"....d196|..5e..10|....b1f1|b54e9838|"
"..0cf1..|5c1a..fb|....f34d|19..d34c|"
"..cacb48|..4c2d09|48..bc..|f98cc7..|"
"ac..2b1a|..beb5..|98..03..|..61c35e|"
"....1245|61..5ca8)";
int res;
if ((res = regcomp(&the_re, the_re_string, REG_EXTENDED|REG_NOSUB)) != 0) {
char ebuf[256];
(void) regerror(res, &the_re, ebuf, sizeof ebuf);
(void) fprintf(stderr, "regcomp failed: %s\n", ebuf);
return -1;
}
return 0;
}
int
matcher_matches(uint32_t u)
{
char ubuf[9];
(void) sprintf(ubuf, "%08x", u);
return regexec(&the_re, ubuf, 0, 0, 0) == 0;
}
int
main(void)
{
int i;
unsigned tf, iterations, matches;
time_t start;
uint32_t tvals[] = {
0xabcd0000, 0xabdc0089, 0x0000abcd, 0xde0000ab,
0x00d80a00, 0x007bc500, 0xc600514a, 0x00b7585a,
0x4732ecc4, 0x7c22e4da, 0x5a5e0063, 0x0000e866,
0x00fdc367, 0xac0000b4, 0x70249edc, 0x00e97e32,
0x000094d8, 0x0000fa6c, 0x459100ff, 0x00e40067,
0xaab28500, 0x0000f81b, 0x15bb22ba, 0x3cf40000,
0x57d3ad86, 0x00bd001e, 0x00ec67b7, 0x00693aaf,
0x323c0018, 0xcab237cb, 0xd4b2c6b4, 0x2a15002f,
0x0000d196, 0x005e0010, 0x0000b1f1, 0xb54e9838,
0x000cf100, 0x5c1a00fb, 0x0000f34d, 0x1900d34c,
0x00cacb48, 0x004c2d09, 0x4800bc00, 0xf98cc700,
0xac002b1a, 0x00beb500, 0x98000300, 0x0061c35e,
0x00001245, 0x61005ca8 };
if (matcher_init() == -1) {
return 1;
}
/* test known values */
tf = 0;
for (i = 0; i < sizeof(tvals) / sizeof(tvals[0]); i++) {
if (!matcher_matches(tvals[i])) {
(void) printf("0x%08x should match; didn't...\n", tvals[i]);
tf = 1;
}
}
if (tf) {
return 1;
}
/* some random probes */
srand((time(0) << 16) | (getpid() & 0xFFFF));
iterations = matches = 0;
(void) time(&start);
for (i = 0; i < 1000000; i++) {
uint32_t u = (uint32_t) ((rand() << 16) | (rand() & 0xFFFF));
/* printf("Test: 0x%08x\n", u); */
if (matcher_matches(u)) {
(void) printf("Match: %08x\n", u);
(void) fflush(stdout);
matches++;
}
iterations++;
}
printf("iterations: %d; matches: %d (%u seconds)\n",
iterations, matches,
(unsigned) (time(0) - start));
return 0;
}
对此的回答让我想起了问题本身,经过反射(reflection),我想到了一个更直接的方法。为什么更好的答案不会首先出现,我永远不会知道。
无论如何,不要使用正则表达式,只需一个值和一个掩码。上面的代码丢失了它的 matcher_init
调用(以及所有与正则表达式相关的内容),并且 matcher_matches
调用支持可能如下所示。查找的值与我为第一个答案生成的额外 46 匹配,因此第一个答案的 main
中的相同测试代码将继续工作。
我想您可以对 struct vm 数组进行排序,以便首先出现掩码中设置的位数较少的条目,并获得适度的性能提升,但即使如此,第二次尝试也比基于正则表达式的尝试快大约五倍我。
static struct {
uint32_t val, mask;
} vm [] = {
{ 0xabcd0000, 0xffff0000 },
{ 0xabdc0089, 0xffff00ff },
{ 0x0000abcd, 0x0000ffff },
{ 0xde0000ab, 0xff0000ff },
{ 0x00d80a00, 0x00ffff00 },
{ 0x007bc500, 0x00ffff00 },
{ 0xc600514a, 0xff00ffff },
{ 0x00b7585a, 0x00ffffff },
{ 0x4732ecc4, 0xffffffff },
{ 0x7c22e4da, 0xffffffff },
{ 0x5a5e0063, 0xffff00ff },
{ 0x0000e866, 0x0000ffff },
{ 0x00fdc367, 0x00ffffff },
{ 0xac0000b4, 0xff0000ff },
{ 0x70249edc, 0xffffffff },
{ 0x00e97e32, 0x00ffffff },
{ 0x000094d8, 0x0000ffff },
{ 0x0000fa6c, 0x0000ffff },
{ 0x459100ff, 0xffff00ff },
{ 0x00e40067, 0x00ff00ff },
{ 0xaab28500, 0xffffff00 },
{ 0x0000f81b, 0x0000ffff },
{ 0x15bb22ba, 0xffffffff },
{ 0x3cf40000, 0xffff0000 },
{ 0x57d3ad86, 0xffffffff },
{ 0x00bd001e, 0x00ff00ff },
{ 0x00ec67b7, 0x00ffffff },
{ 0x00693aaf, 0x00ffffff },
{ 0x323c0018, 0xffff00ff },
{ 0xcab237cb, 0xffffffff },
{ 0xd4b2c6b4, 0xffffffff },
{ 0x2a15002f, 0xffff00ff },
{ 0x0000d196, 0x0000ffff },
{ 0x005e0010, 0x00ff00ff },
{ 0x0000b1f1, 0x0000ffff },
{ 0xb54e9838, 0xffffffff },
{ 0x000cf100, 0x00ffff00 },
{ 0x5c1a00fb, 0xffff00ff },
{ 0x0000f34d, 0x0000ffff },
{ 0x1900d34c, 0xff00ffff },
{ 0x00cacb48, 0x00ffffff },
{ 0x004c2d09, 0x00ffffff },
{ 0x4800bc00, 0xff00ff00 },
{ 0xf98cc700, 0xffffff00 },
{ 0xac002b1a, 0xff00ffff },
{ 0x00beb500, 0x00ffff00 },
{ 0x98000300, 0xff00ff00 },
{ 0x0061c35e, 0x00ffffff },
{ 0x00001245, 0x0000ffff },
{ 0x61005ca8, 0xff00ffff }
};
int
matcher_matches(uint32_t u)
{
size_t i;
for (i = 0; i < sizeof(vm) / sizeof(vm[0]); i++) {
if ((u & vm[i].mask) == vm[i].val) {
return 1;
}
}
return 0;
}
通配符现在是结构的 mask
字段中的零,val
字段中相应的位“无关”值(设置为零)。
关于c - 如何使用 gperf 为一系列值创建散列?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18387314/
#include using namespace std; class C{ private: int value; public: C(){ value = 0;
这个问题已经有答案了: What is the difference between char a[] = ?string?; and char *p = ?string?;? (8 个回答) 已关闭
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 7 年前。 此帖子已于 8 个月
除了调试之外,是否有任何针对 c、c++ 或 c# 的测试工具,其工作原理类似于将独立函数复制粘贴到某个文本框,然后在其他文本框中输入参数? 最佳答案 也许您会考虑单元测试。我推荐你谷歌测试和谷歌模拟
我想在第二台显示器中移动一个窗口 (HWND)。问题是我尝试了很多方法,例如将分辨率加倍或输入负值,但它永远无法将窗口放在我的第二台显示器上。 关于如何在 C/C++/c# 中执行此操作的任何线索 最
我正在寻找 C/C++/C## 中不同类型 DES 的现有实现。我的运行平台是Windows XP/Vista/7。 我正在尝试编写一个 C# 程序,它将使用 DES 算法进行加密和解密。我需要一些实
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
有没有办法强制将另一个 窗口置于顶部? 不是应用程序的窗口,而是另一个已经在系统上运行的窗口。 (Windows, C/C++/C#) 最佳答案 SetWindowPos(that_window_ha
假设您可以在 C/C++ 或 Csharp 之间做出选择,并且您打算在 Windows 和 Linux 服务器上运行同一服务器的多个实例,那么构建套接字服务器应用程序的最明智选择是什么? 最佳答案 如
你们能告诉我它们之间的区别吗? 顺便问一下,有什么叫C++库或C库的吗? 最佳答案 C++ 标准库 和 C 标准库 是 C++ 和 C 标准定义的库,提供给 C++ 和 C 程序使用。那是那些词的共同
下面的测试代码,我将输出信息放在注释中。我使用的是 gcc 4.8.5 和 Centos 7.2。 #include #include class C { public:
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我的客户将使用名为 annoucement 的结构/类与客户通信。我想我会用 C++ 编写服务器。会有很多不同的类继承annoucement。我的问题是通过网络将这些类发送给客户端 我想也许我应该使用
我在 C# 中有以下函数: public Matrix ConcatDescriptors(IList> descriptors) { int cols = descriptors[0].Co
我有一个项目要编写一个函数来对某些数据执行某些操作。我可以用 C/C++ 编写代码,但我不想与雇主共享该函数的代码。相反,我只想让他有权在他自己的代码中调用该函数。是否可以?我想到了这两种方法 - 在
我使用的是编写糟糕的第 3 方 (C/C++) Api。我从托管代码(C++/CLI)中使用它。有时会出现“访问冲突错误”。这使整个应用程序崩溃。我知道我无法处理这些错误[如果指针访问非法内存位置等,
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 7 年前。
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,因为
我有一些 C 代码,将使用 P/Invoke 从 C# 调用。我正在尝试为这个 C 函数定义一个 C# 等效项。 SomeData* DoSomething(); struct SomeData {
这个问题已经有答案了: Why are these constructs using pre and post-increment undefined behavior? (14 个回答) 已关闭 6
我是一名优秀的程序员,十分优秀!