我创建了一个使用MAP_SHARED标志集调用mmap的进程,当我尝试将字符串复制到该地址时,我收到转储的Bus error core,请有人解释一下其原因以及如何解决。以下是我的代码
int main()
{
int fd=0;
char* ret = NULL;
void *map_addr = NULL;
fd = open("./shared_file.txt", O_RDWR, S_IRUSR | S_IWUSR);
if(fd == -1) {
printf("errno = %d\n",errno);
printf("Aborting process1###########\n");
abort();
}
map_addr = mmap(NULL, 5*sizeof(int), PROT_READ|PROT_WRITE, MAP_SHARED, fd, 0);
if(map_addr == MAP_FAILED) {
printf("mmap failed error no =%d\n",errno);
close(fd);
return -1;
}
printf("map_addr = %p#################\n",(int*)map_addr);
printf("processid = %d#################\n",(int)getpid());
ret = strcpy((char*)map_addr,"Stack Overflow");
if(ret == (char*)map_addr)
printf("strcpy success\n");
/*if(msync(map_addr, sizeof(int), MS_SYNC))
printf("msync failed errno = %d\n",errno);*/
close(fd);
sleep(120);
return (0);
}
最佳答案
总线错误的原因通常是试图取消引用尚未正确初始化的指针,该指针包含无法以4或1的倍数或与数据类型大小相关的不可访问的垃圾数据。
首先,您应该检查shared_file.txt
文件大小是否大于或等于20个字节(假设sizeof int为4个字节),如在以下行中的mmap()
length参数(在其中放置5*(sizeof(int))
所示)所指定的:
map_addr = mmap(NULL, 5*sizeof(int), PROT_READ|PROT_WRITE, MAP_SHARED, fd, 0);
如果文件大小小于20个字节,则可以使用
fallocate
调用来预分配内存。如果
shared_file.txt
文件大小为access to an undefined portion of a memory。在这种情况下,在内存初始化期间将不返回MMAP_FAILED。快速检查是看是否可以在mmap
char*
指针中写入单个字符。如果不能(您将获得SIGBUS),则意味着文件大小为零。关于c - strcpy到mmap地址重新调整总线错误,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/25337876/