memory.h头文件封装

原创 2006年06月02日 16:28:00

#ifndef _UNIX_LIB_MEMORY_HPP
#define _UNIX_LIB_MEMORY_HPP

/* author: piboye
 * email : piboye@yahoo.com.cn
 * date  : 2006.06.2
 */

//头文件
#include<memory.h>
#include<assert.h>

namespace UNIX {

class Mem //提供内存操作,但不提供内存管理;
{
private:
    void  *i_start; //内存开始的位置
    unsigned int i_length; //内存的长度,用unsigned 是为了保持与C接口的一致性;
public:
    typedef enum {less=-1,great=1,equal=0} CmpT;//内存比较需要的结果 类型;
    Mem(void *add,unsigned int len):i_start(add),i_length(len){assert(i_start&&i_length);} //add 不可以使用无效指针,但这是用户的责任;
    Mem const & operator=(Mem const & rhs) // 封装了void* __cdecl memmove (void*, const void*, size_t); 如果内存可以重叠。
    {
            unsigned int const min=(i_length>rhs.i_length)?rhs.i_length:i_length;
            memmove(i_start,rhs.i_start,min);
            return *this;
    }
    Mem const & copy(Mem const &rhs)// 封装了 void* __cdecl memcpy (void*, const void*, size_t);内存拷贝,内存不允许重叠。
    {
            unsigned int min=(i_length>rhs.i_length)?rhs.i_length:i_length;
            memcpy(i_start,rhs.i_start,min);
            return *this;      
    }
    Mem const & ccopy(Mem const &rhs,int ch) // 封装了 void* __cdecl memccpy (void*, const void*, int, size_t);内存拷贝,直到遇到ch字符为止。不会拷贝ch字符,也不会添加'/0'到i_start,内存上内存不允许重叠。
    {
            unsigned int min=(i_length>rhs.i_length)?rhs.i_length:i_length;
            memccpy(i_start,rhs.i_start,ch,min);
            return *this;      
    }
    CmpT compare(Mem const& rhs) const //区分大小写的内存比较函数,封装了int __cdecl memcmp (const void*, const void*, size_t)
    {
            unsigned int min=(i_length>rhs.i_length)?rhs.i_length:i_length;
            return static_cast<CmpT> (memcmp(i_start,rhs.i_start,min));
    }
    CmpT icompare(Mem const& rhs) const //忽略大小写的比较函数,封装了int __cdecl memicmp (const void*, const void*, size_t)
    {
        unsigned int min=(i_length>rhs.i_length)?rhs.i_length:i_length;
        return static_cast<CmpT>(memicmp(i_start,rhs.i_start,min));
    }
    void*   find(int ch)  // 查找ch字符所在的位置,封装了 void* __cdecl memchr (const void*, int, size_t) 函数
    {
        return menchr(i_start,ch,i_length);
    }
//比较运算符用的是 没有忽略大小写的 compare;
#define CMP(OP) const/
    bool operator OP (Mem const & rhs) /
    {  /
         return compare(rhs) OP 0; /
    }
CMP(<)
CMP(>)
CMP(==)
CMP(<=)
CMP(>=)
CMP(!=)
#undef CMP
  Mem const & operator =(char ch) //内存初始话为 ch值,封装了 void* __cdecl memset (void*, int, size_t);
  {
      memset(i_start,ch,i_length);
      return *this;
  }
  operator void *() const //转换为地址;
  {
      return i_start;
  }
  unsigned int length() const //内存大小;
  {
      return i_length;
  }
  void * address() const //返回内存地址;
  {
      return i_start;
  }
  void set(void * ptr,unsigned int len) //重置 内存块;ptr不可以使用无效指针,但这是用户责任。
  {
    assert((ptr&& len));
    i_start=ptr;
    i_length=len;
  }
}; //Mem类定义结束

}// 结束Unix名字空间
#endif //文件_UNIX_LIB_MEMORY_HPP宏结束

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

如何封装.h和.a静态库使得头文件中不含有暴露内部实现的private成员变量

参考:C++类怎么将一些成员的声明定义都放到cpp文件中 http://bbs.csdn.net/topics/350125990实现:分为四个文件: 最终需要交给别人的只有network....

atlapp.h头文件

  • 2016-05-15 23:46
  • 43KB
  • 下载

hidsdi.h Hid通信用头文件

  • 2015-02-06 16:54
  • 12KB
  • 下载

C/C++笔试必须熟悉掌握的头文件系列(十)——iomanip.h/iomanip

iomanip.h是I/O流控制头文件,就像C里面的格式化输出一样,主要是对cin和cout操纵的云算子。需要注意C++中替代iomanip.h并不是cipmanip,而是直接ipmanip,与cma...

头文件stdafx.h

自学QT之QApplication类和<qapplication.h>头文件

QApplication类管理图形用户界面应用程序的控制流和主要设置。 它包含主事件循环,在其中来自窗口系统和其它资源的所有事件被处理和调度。它也处理应用程序的初始化和结束,并且提供对话管理。它...

glaux.h头文件

  • 2014-06-26 18:37
  • 12KB
  • 下载

netcon.h头文件

  • 2015-05-04 21:08
  • 33KB
  • 下载

stdio.h c头文件

一般会把用来#include的文件的扩展名叫 .h,称其为头文件。 #include文件的目的就是把多个编译单元(也就是c或者cpp文件)公用的内容,单独放在一个文件里减少整体代码尺寸;或者提供跨...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)