易截截图软件、单文件、免安装、纯绿色、仅160KB

C/C++ 指向子类对象的基类指针

有如下程序:
//-----------------
class A
{
public:
A()
{
printf( "base A\r\n" );
}
virtual ~A()
{
printf( "base ~A\r\n" );
}
public:
virtual void VirtualFunc()
{
printf( "base VirtualFunc\r\n" );
};
void Func()
{
printf( "base Func\r\n" );
}
void F1()
{
printf( "base F1\r\n" );
}
protected:
private:
};
class B : public A
{
public:
B()
{
printf( "derive B\r\n" );
}
~B()
{
printf( "derive ~B\r\n" );
}
public:
virtual void VirtualFunc()
{
printf( "derive VirtualFunc\r\n" );
};
void Func()
{
printf( "derive Func\r\n" );
}
void G1()
{
printf( "derive G1\r\n" );
}
protected:
private:
};
在这两个类中,子类B 重写了 基类的 两个函数,一个是虚函数,一个不是虚函数。
1. 如果main函数如下:
int main(int argc, int* argv[])
{
A* pA = new B;  //基类指针指向子类对象
pA->VirtualFunc();
pA->Func();
//pA->G1(); //出错:'G1' : is not a member of 'A'
delete( pA );
system("pause");
return 0;
}
运行结果如下:
base A
derive B
derive VirtualFunc
base Func
derive ~B
base ~A
也就是说,如果子类重写了基类的虚函数,那么该指针(基类指针,但指向派生类对象)将调用子类的函数;
即使子类重写了子类的非虚函数,该指针也不会调用子类的函数。
2.
如果main 函数如下:
int main(int argc, int* argv[])
{
B *pB = new B; //子类指针指向子类对象
pB->VirtualFunc();
pB->Func();
//pB->F1(); //正确,输出:base F1。请注意:B类是公有继承A类。具体参见:C++的三种继承方式
delete( pB );
system("pause");
return 0;
}
则运行结果如下:
base A
derive B
derive VirtualFunc
derive Func
derive ~B
base ~A
即如果用子类指针指向子类对象,则都调用子类的函数。


相关文档:

C盘下各个文件夹简介

├—WINDOWS
│ ├—system32(存放Windows的系统文件和硬件驱动程序)
│ │ ├—config(用户配置信息和密码信息)
│ │ │ └—systemprofile(系统配置信息,用于恢复系统)
│ │ ├—drivers(用来存放硬件驱动文件,不建议删除)
│ │ ├—spool(用来存放系统打印文件。 ......

c标准库函数

本文包括大部分C标准库函数,但没有列出一些用途有限的函数以及某些可以简单的从其他函数合成的函数,也没有包含多字节和本地化函数。
标准库中的各个函数、类型以及宏分别在以下标准头文件中说明:
<assert.h> <float.h> <math.h> <stdarg.h> <stdlib.h>
<ctype.h> <limits.h& ......

c头文件最后要加一个空行,知道为什么嘛?

 以前学生时代的时候就有遇到过这个问题,不过没去深究;
现在也是老问题,其实很简单,就是为了防止#include两个头文件的时候,把第一个头文件的最后一行和 第二个头文件的第一行拼接成一行;呵呵,其实很多问题都很简单,而且很隐蔽,只是我们很多时候没去注意! ......

c经典链表程序

#include "stdio.h"
#include "malloc.h"
typedef int elemtype;
struct node
{
elemtype data;
struct node *next;
};
typedef struct node NODE;
NODE * creat(NODE *head)
{
NODE *p,*q;
elemtype i;
head=(NODE*)malloc(sizeof(NODE));
scanf("%d",&(head->data));
p=head;
......

关于delete C/C++ 指针

栈:函数调用的时候,在栈中保存局部变量和函数参数等。当函数返回时,自动清除栈。
自由存储区:也称为堆(heap),可以看作大量的内存段。通过 new 操作符分配的内存在堆中。程序结束之前不自动清除自由存储区。需要由程序来负责释放(delete)。
1.
对指向栈上内存的指针调用delete会导致程序Crash。
2. 
new 进 ......
© 2009 ej38.com All Rights Reserved. 关于E健网联系我们 | 站点地图 | 赣ICP备09004571号