大佬教程收集整理的这篇文章主要介绍了如何在C中将结构存储和检索到共享存储区中,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
现在,我只是一次只关注它一个问题,而目前,我只是试图将我的循环列表放入共享内存区域.
到目前为止,我有:
typedef struct FILE { struct FILE *f_link; /* forWARD link for linked list */ char name[255]; /* name of the file */ } FILE_entry;
作为我的结构,它将保存对下一个@L_618_1@的引用(f_link).通过这种方式,我可以调用 – > f_link来获取列表中的下一个项目,并且第10个元素将使其f_link直接返回到第1个.我这样做的原因是我可以在没有迭代器的情况下简单地遍历列表(并且不必像使用数组那样检查列表的结尾).
我也知道我需要使用shmget来获取内存区域,我理解它,我传递shmget一个键,一个大小和一个标志(我没有得到),它返回一个int类型的标识符.
所以我的问题是2折.如何将链接列表存储到共享内存区域 – 如何从共享内存区域访问它?
int id; FILE_entry *entries; id = shmget(key,N * sizeof(FILE_entry),IPC_CREAT | 0644); entries = (FILE_entry *) shmat(id,NULL,0); // you can Now access entries as if it was a N-element array. // to turn it into a circular list,link the entries appropriately.
映射后,您可以像常规内存一样使用它 – 因为它是常规内存.这就是重点!
编辑:我忘了提一个重要的警告.将链接列表放入这样的共享内存段只有在所有相关进程将其映射到同一地址时才有效!所以你需要这样做(使用shmat的第二个参数)或者从指针切换到相对于共享内存范围的基地址的偏移量.这意味着将下一个字段从指针转换为ptrdiff_t,并在加载时添加映射内存范围的基地址(并在存储时减去它).
以上是大佬教程为你收集整理的如何在C中将结构存储和检索到共享存储区中全部内容,希望文章能够帮你解决如何在C中将结构存储和检索到共享存储区中所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。