一个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++基本功!
--------------------------------------------------------------------------------------------------------------------------------------------------------------------
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模式读写。如果谁能当场给出这个解答,那简直就是一个天才的程序员。
--------------------------------------------------------------------------------------------------------------------------------------------------------------------
int Sum( int n )
{
return ( (long)1 + n) * n / 2;
}
对于这个题,只能说,也许最简单的答案就是最好的答案。下面的解答,或者基于下面的解答思路去优化,不管怎么“折腾”,其效率也不可能与直接return ( 1 l + n ) * n / 2相比!
- 一个CString类和小技巧
- CString类的转化(高级)及小技巧
- 一个注册表小技巧
- 的一个小技巧
- preparedStatement一个小技巧
- 一个mysql小技巧
- 分享一个小技巧
- 一个小技巧
- 一个小技巧
- 一个小技巧
- 一个JS小技巧
- 一个小技巧
- vim 一个小技巧
- CString类的转化(高级)及小技巧(转)
- CString类的转化(高级)及小技巧(转)
- dll的导出和导入的一个小技巧
- 一个oracle sql 小技巧
- 请问大家一个小技巧?
- tcl/tk参考——变量和过程proc
- 画图程序 橡皮线技术一(拖拽显示)
- tcl/tk参考——变量和过程rename
- 防止迅雷上传的方法
- http://localhost/6-4.php
- 一个CString类和小技巧
- Tomcat的启动脚本浅析(一)
- 网络视频监控领域的名词解释
- Tomcat的启动脚本浅析(二)
- Fedora 8 安装笔记
- Tomcat的启动脚本浅析(三)
- http://localhost/Untitled-3.php
- python用swig调dll是个伪命题
- Vector使用