VimStudio


VimStudioVim及一些常用插件(主要针对C/C++语言)打包在一起,通过执行install.py完成安装,免去了安装配置插件的麻烦。项目地址:https://github.com/xushvai/VimStudio 

VimStudio不会对当前的Vim ...


封装MySQL的C语言API

为方便使用,对MySQL提供的C语言API进行包装。考虑到在实际使用时,会对多个数据库服务器进行访问,将访问句柄组织成链表进行管理。

封装后的函数有如下几个,函数名均已MY作为前缀:
其中的重要参数,MySQLConnLink是一个链表,其元素为MySQLConnection,该结构中包含了一个数据库连接相关的信息。如:数据库的账号,密码,数据库名字等 ...


逐步实现TCP服务端Step05-1:实现Proxy

Proxy的基本功能是将收到的消息原封不动地转发给单个或多个目标实体。可用“类型+ID”的方式来标识一个实体。这样,源实体只要提供目标实体的类型、ID以及转发方式,Proxy就可完成转发工作。

转发方式可细分为如下几种:

  • 一对一(P2P):一个源实体对应一个目标实体。此种情况,源实体需要提供目标实体的实体类型和实体ID。

  • 一对多(P2G):一个源实体对应一组(Group)目标实体 ...


逐步实现TCP服务端Step04-9:IOCP

IOCP是Windows平台特有的机制,在Windows平台上,它与epoll在Linux上的地位相当。二者常放在一起讨论,不过,它俩完全不是一类东西。

selectpollepoll系列,属于I/O多路复用机制。通过这种机制,就可在单一流程(单线程)中一次性找出,当前I/O已就绪的文件描述符。这大大降低了,程序因不知道哪些I/O已就绪,而无休止地轮询(调用recv/send等)所有文件描述符所产生的大量无用功。当然,多路复用是用在单线程处理多路I/O的场景中,若一路I/O独占一个线程的话,就没必要轮询了,线程直接阻塞在I/O上就行了。

IOCP是配合Overlapped I/O来使用的,这种所谓的重叠I/O是Windows平台上的异步I/O机制。说到同步、异步的概念,在不同场合下有不同解释。单说异步I/O的话 ...


实测epoll的LT和ET模式

epoll有两种工作模式:LT(Level-Trigge)和ET(Edge-Trigger),LT为缺省模式。

  • LT:无限次地“驱动”事件处理逻辑去处理事件,直到事件被处理“干净”。未被处理“干净”的事件是指,事件未被处理,或事件被处理了,但尚未处理完全。例如,接收缓冲区有数据就绪,此时,事件处理逻辑不recv该数据,或只recv了一部分,都属于处理不干净。

  • ET:一个事件发生时,只”驱动“一次事件处理逻辑。处理逻辑若不把此事处理”干净“,以后将不再有机会。当然 ...


逐步实现TCP服务端Step04-8:epoll

epoll是对selectpoll的强化,是Linux(2.6内核开始支持)特有的机制。它有这么几个特点:1. 内核维护了一个事件列表用于记录各描述符上注册的事件,某个文件描述符上的事件只需向内核注册一次,不必像selectpoll那样每次调用都要向内核注册一遍;2. 监测结果集中只会给出就绪了的文件描述符;3. 支持ET工作模式。

这是在目前的程序(netio)结构下,使用select ...