一个CString类和小技巧

来源:互联网 发布:mac软件下载网站 编辑:程序博客网 时间:2024/05/16 12:48


编写类String的构造函数、析构函数和赋值函数,已知类String的原型为:


class String
{  
public:
    String(const char *str = NULL); // 普通构造函数   
    String(const String &other); // 拷贝构造函数   
    ~String(void); // 析构函数   
    String &operate =(const String &other); // 赋值函数
private:
    char *m_data; // 用于保存字符串
}; 

//普通构造函数
String::String(const char *str)
{
 if(str==NULL)
 {
  m_data = new char[1]; // 得分点:对空字符串自动 申请 存放结束标志'/0'的空
  *m_data = '/0'; //加分点:对m_data加NULL 判断

 }
 else
 {
  int length = strlen(str);
  m_data = new char[length+1]; // 若能加 NULL 判断则更好
  strcpy(m_data, str);
 }
}

// String的析构函数

String::~String(void)
{
 delete [] m_data; // 或delete m_data;
}

//拷贝构造函数

String::String(const String &other)    // 得分点:输入参数为const型
{
 int length = strlen(other.m_data);
 m_data = new char[length+1];     //加分点:对m_data加NULL 判断
 strcpy(m_data, other.m_data);
}

//赋值函数

String & String::operate =(const String &other) // 得分点:输入参数为const型
{
 if(this == &other)   //得分点: 检查 自赋值
  return *this;
 delete [] m_data;     //得分点:释放原有的内存资源
 int length = strlen( other.m_data );
 m_data = new char[length+1];  //加分点:对m_data加NULL 判断
 strcpy( m_data, other.m_data );
 return *this;         //得分点:返回本对象的引用
}


能够准确无误地编写出String类的构造函数、拷贝构造函数、赋值函数和析构函数的面试者至少已经具备了C++基本功的60%以上!

  在这个类中包括了指针类成员变量m_data,当类中包括指针类成员变量时,一定要重载其拷贝构造函数、赋值函数和析构函数,这既是对C++程序员的基本要求,也是《Effective C++》中特别强调的条款。

  仔细学习这个类,特别注意加注释的得分点和加分点的意义,这样就具备了60%以上的C++基本功!
--------------------------------------------------------------------------------------------------------------------------------------------------------------------
一个C函数,若处理器是Big_endian的,则返回0;若是Little_endian的,则返回1
int checkCPU()
{
 {
  union w
  {
   int a;
   char b;
  } c;
  c.a = 1;
  return (c.b == 1);
 }
}

嵌入式系统开发者应该对Little-endian和Big-endian模式非常了解。采用Little-endian模式的CPU对操作数的存放方式是从低字节到高字节,而Big-endian模式对操作数的存放方式是从高字节到低字节
Little-endian:int i=0x1234;
存放在内存是34 12 .低字节在前,高字节在后
Big-endian:正相反,存放在内存是12 34
联合体union的存放顺序是所有成员都从低地址开始存放,面试者的解答利用该特性,轻松地获得了CPU对内存采用Little-endian还是Big-endian模式读写。如果谁能当场给出这个解答,那简直就是一个天才的程序员。
--------------------------------------------------------------------------------------------------------------------------------------------------------------------
一个函数返回1+2+3+…+n的值(假定结果不会超过长整型变量的范围)
int Sum( int n )
{
 return ( (long)1 + n) * n / 2;
}

对于这个题,只能说,也许最简单的答案就是最好的答案。下面的解答,或者基于下面的解答思路去优化,不管怎么“折腾”,其效率也不可能与直接return ( 1 l + n ) * n / 2相比!
原创粉丝点击