在写股票软件过程中, 我希望把读取数据和显示数据的过程分离,他们的数据交换通过一个共享的链表来解决。
通过shmget,可以获得一块共享的内存,但通常的情况下,一般申请的都是连续的空间,也就是说,我需要把数据存成一个数组,放在共享中。这个不是我的初衷。
最初,我希望能只共享一个头指针,以为这样就可以直接共享链表了。但是结果是不可行的。
经过一番实验和google,最终找到了解决办法。
关键点:
1.通常每个节点node,其中的next域存储的是*node, 即指向下个节点的指针。在这里,我们不能使用*node,否则读取程序是没法正确读取的。具体原因不清楚,但是经过实践证明,不可行。所以我们使用一个节点内存对应的shmid来当作先个节点的指示符,他的类型是int.
2.由于共享的是整个链表,所以每次为新节点开辟内存时,不能使用malloc,而应该使用shmget. malloc是进程相关的,只有开辟内存的进程才有权限读取内容。
注意:
今天在使用一个节点较多的链表时,发现会导致chrome 工作问题,同时,如果忘记释放掉申请的共享空间,第一次还可以运行,第二次一半就挂掉,第三次完全开辟不出新的shmid.
搜索了一阵得出的结果是:共享内存的块数是有限制的。因此,链表并适合共享,共享一个数组才是最科学的办法。
网络上有文章说共享内存的块数是128,这个结论应该是错的。实际结果估计在4000-5000块。但是这个数目仍然是有限的。因此还是尽量使用数组来共享数据。这个链表的方法,只是一个work around.
/*
* =====================================================================================
*
* Filename: writer.c
*
* Description: show create linked list in share memory
*
* Version: 1.0
* Created: 08/20/2012 09:55:21 PM
* Revision: none
* Compil