程序员网络面试题.docx程序员网络面试题
程序员网络面试题2016-07-22浏览:分享人:方邦茂手机版
分析:答案是不可以。C++编译器在实现const的成员 函数的时候为了确保该函数不能修改类的实例的状态,会在 函数中添加一个隐式的参数const this函数表的指针以得到函 数的地址,因此调用虚函数需要一个实例。两者相互矛盾。
struct Point3D
{
int x;
int y;
int z;
};
int _tmain (int argc, _TCHAR* argv[])
{
Point3D* pPoint = NULL;
int offset = (int)(&(pPoint)->z);
printf("%d”, offset);
return 0;
}
答案:输出8。由于在pPoint->z的前面加上了取地址 符号,运行到此时的时候,会在pPoint的指针地址上加z 在类型Point3D中的偏移量8。由于pPoint的地址是0,因 此最终offset的值是8o
&(pPoint->z)的语意是求pPoint中变量z的地址 (pPoint的地址0加z的偏移量8),并不需要访问pPoint 指向的内存。只要不访问非法的内存,程序就不会出错。
class A
{
public:
AO
{
Print ();
}
virtual void Print ()
{
printf("A is constructed.\n");
}
};
class B: publie A
public:
B()
Print ();
virtual void Print ()
{
printf(nB is constructed.\n");
}
};
int _tmain (int argc, _TCHAR* argv[])
{
A* pA = new B ();
pA;
return 0;
}
答案:先后打印出两行:A is constructed. B is ,先会调用B的基类及A 的构造函数。然后在A的构造函数里调用Printo由于此时 实例的类型B的部分还没有构造好,本质上它只是A的一个 实例,他的虚函数表指针指向的是类型A的虚函数表。因此 此时调用的Print是A::Print,而不是B: :Printo接着调 用类型B的构造函数,并调用Print。此时已经开始构造B, 因此此时调用的Print是B: :Print。
同样是调用虚拟函数Print,我们发现在类型A的构造 函数中,调用的是A:: Print,在B的构造函数中,调用的是 B::Print。因此虚函数在构造函数中,已经失去了虚函数的 动态绑定特性。
namespace ChangesOnString
{
class Program
{
static void Main (string[] args)
{
String str = "hello”;
0;
(0, " WORLD");
(str);
答案:,String有一个非 常特殊的性质:String的实例的状态不能被改变。如果 String的成员函数会修改实例的状态,将会返回一个新的 String实例。改动只会出现在返回值中,而不会修改原来的 实例。所以本题中输出仍然是原来的字符串值helloo
如果试图改变String的内容,改变之后的值可以通过 返回值拿到。用StringBuilder是更好的选择,特别是要连 续多次修改的时候。如果用String连续多次修改,每一次 修改都会产生一个临时对象,开销太大。
答案:在C++中,如果没有标明函数或者变量是的访问 权限级别,在struct中,是pub lie的;而在class中,是 private 的。
在C#中,如果没有标明函数或者变量的访问权限级别, struct 和 class 中都是 private 的。struct 和 class 的区 别是:struct定义值类型,其实例在栈上分配内存;class 定义引用类型,其实例在堆上分配内存。
题目(十):运行下图中的C#代码,输出是什么?
namespace StaticConstructor
{
class A
{
public A (string text)
{
(text);
class B
static A al = new A(nal");
A a2 = new A (n a2");
static B()
{
al = new A(n a3");
}
public B()
{
a2 = new A (
程序员网络面试题 来自淘豆网m.daumloan.com转载请标明出处.