分类 C语言 下的文章

Linux c 开发 - libevent

Libevent介绍 libevent是一个事件触发的网络库,适用于windows、linux、bsd等多种平台,内部使用select、epoll、kqueue等系统调用管理事件机制。著名分布式缓存软件memcached也是libevent based,而且libevent在使用上可以做到跨平台,而且根据libevent官方网站上公布的数据统计,似乎也有着非凡的性能。 libevent官方网...

memory   2015-04-06  1 条评论

Linux c 开发 - Memcached源码分析之总结篇(8)

Memcached源码分析共8篇文章,前7篇文章主要分析每个模块的c源代码。这一篇文章主要是将之前的流程串起来,总结和回顾。同时通过这篇文章可以全局去看Memcached的结构。 Memcache的网络模型 1. Memcached主要是基于Libevent 网络事件库进行开发的。 2. Memcached的网络模型分为两部分:主线程和工作线程。主线程主要用来接收客户端的连接信息;工作线程主...

memory   2015-04-06  暂无评论

Linux c 开发 - Memcached源码分析之存储机制Slabs(7)

前言 前几章节我们介绍了Memcached的网络模型,命令行的解析,消息回应,HashTable,Memcached的增删改查操作以及LRU算法模块。 这一章我们重点讲解Memcached的存储机制Slabs。Memcached存储Item的代码都是在slabs.c中来实现的。 在解读这一章前,我们必须先了解几个概念。 Item 缓存数据存储的基本单元 1. Item是Memcached存储...

memory   2015-04-06  暂无评论

Linux c 开发 - Memcached源码分析之LRU算法(6)

前言 上一章《Linux c 开发 - Memcached源码分析之增删改查操作(5) 》中,我们讲到了SET命令的操作。当客户端向Memcached服务端SET一条缓存数据的时候,会将生成的Item地址挂到LRU的链表结构上。这一章节,我们主要讲一下Memcached是如何使用LRU算法的。LRU:是Least Recently Used 近期最少使用算法。Memcached的LRU算法分...

memory   2015-04-06  暂无评论

Linux c 开发 - Memcached源码分析之增删改查操作(5)

前言 在第二章《Linux c 开发 - Memcached源码分析之命令解析(2)》 和第三章《Linux c 开发 - Memcached源码分析之消息回应(3)》 中我们主要通过Memcached的get命令,分析了Memcached的命令解析和消息回应的模块功能。这一章,我们主要来详细看一下Memcached常用的增删改查操作。在看Memcached的增删改查操作前,我们先来看一下p...

memory   2015-04-06  暂无评论

Linux c 开发 - Memcached源码分析之HashTable(4)

前言 上一章我们讲解了Memcached的消息回应机制《Linux c 开发 - Memcached源码分析之消息回应(3)》。从这一章开始我们慢慢讲解Memcached是如何存储数据的。 讲解本章前,我们先看一个Memcached存储数据的item的基本结构。 //item的具体结构 typedef struct _stritem { //记录下一...

memory   2015-04-06  暂无评论

Linux c 开发 - Memcached源码分析之消息回应(3)

前言 上一章《Linux c 开发 - Memcached源码分析之命令解析(2)》,我们花了很大的力气去讲解Memcached如何从客户端读取命令,并且解析命令,然后处理命令并且向客户端回应消息。 这一章,我们主要来讲解Memcached回应消息的技术细节。 本章前,我们先需要了解几个知识点(msghdr和iovc)。 msghdr结构:struct msghdr { vo...

memory   2015-04-06  暂无评论

Linux c 开发 - Memcached源码分析之命令解析(2)

前言 从我们上一章《Linux c 开发 - Memcached源码分析之基于Libevent的网络模型(1)》我们基本了解了Memcached的网络模型。这一章节,我们需要详细解读Memcached的命令解析。 我们回顾上一章发现Memcached会分成主线程和N个工作线程。主线程主要用于监听accpet客户端的Socket连接,而工作线程主要用于接管具体的客户端连接。 主线程和工作线程之...

memory   2015-04-06  暂无评论

Linux c 开发 - Memcached源码分析之基于Libevent的网络模型(1)

关于Memcached: memcached是一款非常普及的服务器端缓存软件,memcached主要是基于Libevent库进行开发的。Memcached分析 1.  网络模型流程分析 Memcached主要是基于Libevent的事件库来实现网络线程模型的。我们先需要下载memcached的源码包,上面我们已经给出了源码包下载地址。 Memcached的网络线程模型主要涉及两个主...

memory   2015-04-06  暂无评论

Linux c 开发 - 结构体

实际的项目开发中,有比较复杂的数据结构。例如学生,有姓名、年龄等属性参数。这个时候使用传统的类型就无法满足我们的需要。C语言的结构体就可以解决这个问题。 1. 定义结构体 结构体都是通过关键字 struct 来定义。例如我们定义一个结构体,包含学生的姓名和年龄:struct student { char *username; int age; }...

memory   2015-04-06  暂无评论

Linux c 开发 - Makefile工具

Makefile是一个c语言的编译工具。如果学过Java,可能会认识Maven工具,makefile也是类似的工作。 Makefile能帮助c语言建立自动化的编译。一旦写好,执行一个make命令就可以编译整个工程。当然编写Makefile文件的时候有很多知识点在里面。这篇文章主要讲解如何编写基础性以及常用的Makefile文件。 1. 没有makefile的编译 我们先看一个例子: val....

memory   2015-04-06  暂无评论

Linux c 开发 - 文件操作

介绍文件操作的基本用法。 常用API 1. 打开文件fopen()FILE *fopen(const char *filename,const char *mode); 打开文件。参数filename指向要打开的文件名,mode表示打开状态的字符串。 mode表:"r" 打开一个用于读取的文本文件 "w" 创建一个用于写入的文本文件 "a" 附加到一个文本文件 ...

memory   2015-04-06  暂无评论

Linux c 开发 - Socket

Socket的英文原义是“孔”或“插座”。作为BSD UNIX的进程通信机制,取后一种意思。通常也称作"套接字",用于描述IP地址和端口,是一个通信链的句柄。在Internet上的主机一般运行了多个 服务软件,同时提供几种服务。每种服务都打开一个Socket,并绑定到一个端口上,不同的端口对应于不同的服务。服务端例子 先看一个支持多线程,多用户连接的阻塞式IO模式的SOCKET例子。 因为使...

memory   2015-04-06  暂无评论

Linux c 开发 - 常用基础

1. 制表符 C语言手册连接 http://c.biancheng.net/cpp/u/hs10/ 32位编译器char :1个字节 char*(即指针变量): 4个字节(32位的寻址空间是2^32, 即32个bit,也就是4个字节。同理64位编译器) short int : 2个字节int: 4个字节 unsigned int : 4个字节 float: 4个字节 ...

memory   2015-04-06  暂无评论

8.文件操作小结

C系统把文件当作一个“流”,按字节进行处理。C文件按编码方式分为二进制文件和ASCII文件。C语言中,用文件指针标识文件,当一个文件被打开时,可取得该文件指针。文件在读写之前必须打开,读写结束必须关闭。文件可按只读、只写、读写、追加四种操作方式打开,同时还必须指定文件的类型是二进制文件还是文本文件。文件可按字节,字符串,数据块为单位读写,文件也可按指定的格式进行读写。文件内部的位置指针可指示...

memory   2014-04-21  暂无评论