1、對(duì)于如下程序:
[csharp] view plaincopy
#include
using namespace std;
class A
{
public:
A()
{
cout<<"A"<
}
};
int main(void)
{
A a[4], b,*p;
}
會(huì)輸出多少個(gè)A?( C )
A、2 B、3 C、5 D、6
p只是一個(gè)對(duì)象指針,并沒有指向一個(gè)對(duì)象的內(nèi)存空間,所以沒有調(diào)用構(gòu)造函數(shù)。
2、頭文件中的 ifndef/define/endif 有什么作用?
答:防止該頭文件被重復(fù)引用,避免變量、類型等被重新定義。
3、const 有什么用途?(請(qǐng)至少說明兩種)
答:(1)可以定義 const 常量。
(2)const可以修飾函數(shù)的參數(shù)、返回值,甚至函數(shù)的定義體。被const修飾的東西都受到強(qiáng)制保護(hù),可以預(yù)防意外的變動(dòng),能提高程序的健壯性。
4、如下的字符串函數(shù),用于生存一個(gè)字符串 ”連接號(hào)碼異常” ,并返回它的指針
[cpp] view plaincopy
char* strfun()
{
char str[20];
strcpy(str, “連接號(hào)碼異常”);
printf(“%s \n”, str); //printf語(yǔ)句1
return str;
}
void main()
{
char *pstr = strfun();
printf("%s \n", pstr); //printf語(yǔ)句2
}
問題1 : printf語(yǔ)句1和printf語(yǔ)句2哪個(gè)能在屏幕上正在打印出來?
問題2 : 如果不能正常在屏幕上打印出字符串,請(qǐng)說明原因。
問題3 : 如果不修改strfun的聲明,請(qǐng)問該如何修改上述程序的錯(cuò)誤。
答:
問題1:語(yǔ)句1可以正常打印,語(yǔ)句2不能正常打印;
問題2:語(yǔ)句2使用的指針?biāo)赶虻膬?nèi)存空間str[20],在函數(shù)strfun返回時(shí)已經(jīng)被釋放了;
問題3:可以將函數(shù)strfun中的語(yǔ)句char str[20];改為char *str = new char[20];
5、下面是交換兩個(gè)double型數(shù)據(jù)的函數(shù),
[cpp] view plaincopy
void swap( double* p1, double* p2 )
{
double *p;
*p = *p1;
*p1 = *p2;
*p2 = *p;
}
void main()
{
double a = 0.1;
double b = 0.2;
swap( &a, &b );
}
請(qǐng)找出上述代碼的錯(cuò)誤,指出錯(cuò)誤的原因,并改正。
答:函數(shù)swap中混淆了double型指針與double型變量的差別,對(duì)于一個(gè)未初始化的指針訪問其內(nèi)存空間是非常危險(xiǎn)的。對(duì)swap函數(shù)修改如下:
[cpp] view plaincopy
void swap( double* p1, double* p2 )
{
double p;
p = *p1;
*p1 = *p2;
*p2 =p;
}
6、在電信業(yè)務(wù)的后臺(tái)處理程序中,經(jīng)常會(huì)涉及到處理字符串,除了用char *處理字符串之外,C++還為我們提供了封裝了的字符串類string,其本質(zhì)也是用一個(gè)動(dòng)態(tài)數(shù)組來保存字符串,類String的原型為:
[cpp] view plaincopy
class String
{
public:
String(const char *str = NULL); // 普通構(gòu)造函數(shù)
String(const String &other); // 拷貝構(gòu)造函數(shù)
~String(void); // 析構(gòu)函數(shù)
String & operator =(const String &other); // 賦值函數(shù)
private:
char *m_data; // 用于保存字符串
};
請(qǐng)編寫String的上述4個(gè)函數(shù)普通構(gòu)造函數(shù)、拷貝構(gòu)造函數(shù)、析構(gòu)函數(shù)和賦值函數(shù)。
代碼如下:
[cpp] view plaincopy
class String
{
private:
char *m_data; //私有成員,保存字符串
public:
String(const char *str = NULL); //普通構(gòu)造函數(shù)
String(const String &other); //復(fù)制構(gòu)造函數(shù)
~String(void); //析構(gòu)函數(shù)
String & operator =(const String &other); //賦值函數(shù)
};
String::String(const char *str = NULL) //帶一個(gè)指針的普通構(gòu)造函數(shù)
{
if(str == NULL)
{
m_data = new char[1]; //分配一個(gè)字節(jié)
assert(m_data != NULL);
*m_data = '\0';
}
else
{
m_data = new char[strlen(str)+1]; //分配空間容納str內(nèi)容
assert(m_data != NULL);
strcpy(m_data,str);
}
}
String::String(const String &other) //拷貝構(gòu)造函數(shù)
{
m_data = new char[strlen(other.m_data)+1];
assert(m_data != NULL);
strcpy(m_data,other.m_data);
}
String::~String(void) //析構(gòu)函數(shù)
{
if(m_data != NULL)
{
delete []m_data;
m_data = NULL;
}
}
String & String::operator=(const String &other) //賦值函數(shù)
{
if(&other == this) //如果對(duì)象與other是同一個(gè)對(duì)象
return *this;
delete []m_data; //釋放堆內(nèi)存
m_data = new char[strlen(other.m_data)+1];
assert(m_data != NULL);
strcpy(m_data,other.m_data);
return *this;
}