当前位置:  技术问答>linux和unix

如何写一个单向循环链表作缓存

    来源: 互联网  发布时间:2016-10-02

    本文导语:  我也不知道是否应该用单向循环链表作,先说说我想要实现的功能。 一个存储区,两个线程。 一个线程住里面写数据,一个线程从里面读数据。 写数据的时候,如果读进程没有写进程快,则会出现存储区被写满,...

我也不知道是否应该用单向循环链表作,先说说我想要实现的功能。

一个存储区,两个线程。
一个线程住里面写数据,一个线程从里面读数据。

写数据的时候,如果读进程没有写进程快,则会出现存储区被写满,这个时候写进程继续写,但是要写去最早写进去的而末被读出来的数据。

读数据的时候,是要读最早写进去的数据,读完了数据之后,要使那个存储区有用,使写进程可以往里面写数据。




请问类似实现这样的功能,要注意哪些问题,
比如,如果用单向循环链表,感觉如果循环不次,会忘记头在哪里啦。
写的时间是不是要加锁?
有哪个开源项目例子可以参考一下(最好是C的)。

|
不用链表这么复杂吧?
我感觉用一个数组就可以。设一个读指针和写指针,分别记录当前读/写的位置。初值都是0,每次读/写之后加1,到达最大位置就回0

|
lz可以参考一下linux内核中的缓存的实现过程

分配一块内存 然后把内存分成N个块 每个块作为一块小buffer来使用
同时设置一个struct buffer_head来管理这些内存 可以用链表或者hash表都组织这些buffer_head

|
感觉循环链表的想法不错
加锁肯定是需要的了

|
以前也写过类似的,就按照1楼的方法,应该没什么问题

    
 
 

您可能感兴趣的文章:

  • 用C++实现单向循环链表的解决方法
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 单向光传输方案
  • 为什么我的网卡是单向通讯?急用!谢谢
  • 单向链表能否用快速排序??如果能如何实现??
  • 使用ssh-keygen打通两台主机间通道,只能单向跳转
  • 如何使用递归和非递归方式反转单向链表
  • mysql iis7站长之家
  • 为什么libnids只能捕获单向数据流,而不是双向的
  • win2003 mysql单向同步配置步骤[已测]
  • Windows服务器下MySql数据库单向主从备份详细实现步骤分享
  • Oracle简单stream一个用户单向复制配置
  • C语言单向链表的表示与实现实例详解
  • windows环境下mysql数据库的主从同步备份步骤(单向同步)
  • linux下mysql数据库单向同步配置方法分享


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3