我想分配虚拟连续的范围内存,以便在访问数据时可以使用局部性属性(空间局部性),同时考虑到更好的性能。我在下一页发现我需要使用 vmalloc 来更好地访问内存位置(如果我错了并且必须使用 kmalloc ,请纠正我)。
What is the difference between vmalloc and kmalloc?
我从http://www2.research.att.com/~gsf/cgi-bin/download.cgi?action=list&name=vmalloc下载了vmalloc包
我按照安装过程从源文件构建 libmalloc.a 静态库,然后将生成的 libvmalloc.a 库复制到我的 mac 上的/usr/local/lib 和/usr/lib 目录。
在我的C程序中,我尝试通过以下各种方法包含vmalloc.h头文件:
#include <vmalloc.h>
.
#include <linux/vmalloc.h>
.
#include "vmalloc.h"
但它们都不起作用。我总是收到 vmalloc.h:没有这样的文件或目录 错误消息。
我在编译 C++ 程序时使用了 -L/usr/local/lib -lvmalloc 标志。
在我的台式计算机上(在 CentOS 操作系统下)尝试相同的操作时,我也遇到了同样的错误。
这是我的 makefile:
SHELL = /bin/sh
PROJECT = hw2
TARGET = mkhashtbl
CFLAGS = -O3
LFLAGS = -O3 -L/usr/local/lib -lvmalloc
TFILE = $(PROJECT).tgz
ZFILE = $(PROJECT).zip
PACKFILES = Makefile hashtbl.h hashtbl.c mkhashtbl.c timer.c
all: $(TARGET)
run: all
- ./$(TARGET)
我还尝试修改我的链接器标志,如下所示:
LFLAGS = -O3 -L/usr/local/lib -lvmalloc
我仍然遇到同样的错误。 在这种情况下可能出了什么问题?我链接库的方式是否有问题,或者 vmalloc 只适用于某些版本的 Linux?如果是后一种情况,我确信我至少应该仍然能够包含头文件。
编辑
我真正的问题实际上如下:
hashtbl_cache * hashTable_cache; /* Hash table cache */
int i;
hashTable_cache = (hashtbl_cache*)malloc(tbl_size* sizeof(hashtbl_cache));
for( i = 0 ; i < tbl_size; i++ )
{
hashTable_cache[i]. ht_elements = (hashelt_cache*)malloc( hashTable->data_total_size[i] * sizeof(hashelt_cache) ) ;
}
我想确保每个缓存中的所有 ht_elements 都是按顺序创建的。我从论坛上了解到,vmalloc 非常适合创建缓存感知应用程序,因为数据是在虚拟内存中创建的。是否有其他方法可以确保缓存数组的所有元素的分配都是按连续顺序创建的,从而使我能够进行快速查找?还有一件事,每个缓存中每个元素的大小都不一样,所以我猜使用 calloc 不是一个解决方案,但我可能是错的。
最佳答案
Nemo 的评论应该作为答案给出:
The
vmalloc
in that question is a Linux kernel function. Unless you are hacking the kernel or writing a device driver, it is not relevant to you. Thevmalloc
at the AT&T Research site is something else entirely. Neither one does what you think it does. Just usemalloc
.
很明显,您不知道“虚拟连续范围”的含义,或者您会意识到malloc
必须为您提供这一点;否则根本无法工作。
过早的优化是万恶之源。特别是当您不知道您尝试进行的优化意味着什么时。
关于c - 在 Mac 和 CentOS 上使用 vmalloc (libvmalloc.a) - 无法包含 vmalloc header ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6740950/