在操作系统中,每个进程都有自己独立的虚拟地址空间。由于每个进程的虚拟地址空间都是独立的,因此在不同的进程之间可以将相同的物理地址映射为不同的虚拟地址。
下面是一个C语言程序的示例,演示了不同进程中将相同的物理地址映射为不同的虚拟地址的方法:
#include
#include
#include
#include
#include
#define SHM_SIZE 1024
int main()
{
int *shm;
pid_t pid;
shm = mmap(NULL, SHM_SIZE, PROT_READ|PROT_WRITE, MAP_ANONYMOUS|MAP_SHARED, -1, 0);
if (shm == MAP_FAILED) {
perror("mmap failed");
exit(1);
}
pid = fork();
if (pid == 0) {
printf("child process: shm=%p\n", shm);
*shm = 3;
}
else {
printf("parent process: shm=%p\n", shm);
*shm = 5;
waitpid(pid, NULL, 0);
printf("after wait, shm=%p, *shm=%d\n", shm, *shm);
}
munmap(shm, SHM_SIZE);
return 0;
}
在这个示例中,使用了mmap函数将一片大小为1024字节的匿名共享内存映射到了进程的虚拟地址空间中。然后,通过fork函数创建了一个子进程,子进程和父进程都可以访问这块共享内存。父进程将共享内存中的值设为5,子进程将共享内存中的值设为3。最后,父进程等待子进程结束并输出共享内存的地址和值。
可以看到,不同进程中访问同一片物理内存,并将其映射到不同的虚拟地址空间中。这也证明了,可以在不同进程中将相同的物理地址映射为不同的虚拟地址。
上一篇:不同进程中的阻塞和非阻塞赋值