mina buffer
mina的buffer相比较java NIO的buffer可以自动扩展大小,但是,查看代码发现,mina的实现是建立在复制数据到新的buffer来实现的。在数据量小的情况下,这或许还可以容忍的(考虑到数据传输是最基本的操作,即使数据量小,对CPU也是一种浪费,因此实际上也不应该是可以容忍的),但是在数据量很大的情况下,则需要很大的CPU消耗(当然,用system的copy实现,可能会有绕过cpu,直接在内存中完成,但不管怎么说,感觉还是不好)。因此参照lwIP等其他C代码的实现,可以在buffer预留一定空间(尤其是头部,这地方往往需要封装协议用),这样,向bufer写入数据时,就可以免除复制buffer原有的数据。虽然可能浪费了了一定的空间,由于协议头比较固定,浪费的可能性还是比较小的,而且一个输出操作周期并不会太长,因此即使浪费也不会浪费许多。