A *p=new B;

https://blog.csdn.net/weixin_40539125/article/details/88675498
A* P=new B; //A是父类,B是子类

虽然P是一个基类的指针。但是new B调用的是派生类B的构造方法,所以构造的是B类对象。先调用A的构造函数,再调用B的构造函数。构造完后会返回B类对象的地址,然后将它赋给一个基类指针P。

B* q=new B;//这里和上面唯一的区别就是,将B类对象的地址赋给了派生类指针q

而需要注意的是:可以将一个派生类对象的地址赋给基类指针和派生类指针,而一个基类对象的地址只能赋给基类指针,不能赋给派生类的指针。因为派生类不但拥有基类的方法属性,还有基类没有的属性方法。

将一个地址赋给一个指针前,通常会将该地址处的对象类型转换为指针所指的类型。

而将一个基类地址赋给一个派生类指针是不允许的,如果可以的话,那么这个指针就可以调用派生类的方法和属性。但指针指向的是一个基类对象,而基类可能并没有这些方法和属性,因为这些方法和属性是派生类新增的,所以,基类地址赋给一个派生类指针是不允许的。
但将一个派生类对象的地址赋给一个基类指针是可以的,因为,基类指针能调用的方法和属性,派生类都有,所以并不会有什么问题。

有无虚函数例子对比:

#include<iostream>
using namespace std;
 
class A {
public:
	~A() {
		cout << 111 << endl;
	}
	virtual void Fun()                      // 《==虚函数
	{
		cout << "A" << endl;
	}
};
 
class B :public A {
public:
	~B() {
		cout << 222 << endl;
	}
	void Fun()
	{
		cout << "B" << endl;
	}
 
};
 
int main() {
	A *a = new B();
	a->Fun();
 
	delete a;
	return 0;
}
![运行截图](https://img-blog.csdnimg.cn/bfdc96507aca43829771f5a5db99c6fb.png#pic_center)



#include<iostream>
using namespace std;
 
 
class A{
    public:
        ~A(){
            cout<<111<<endl;
        }
		 void Fun()
		{
			cout<<"A"<<endl;
		}
};
 
class B:public A{
    public:
        ~B(){
            cout<<222<<endl;
        }
		virtual void Fun()
		{
			cout<<"B"<<endl;
		}
 
};
 
int main(){
    A *a=new B();
	a->Fun();
 
    delete a;
 
 
    return 0;
}
![运行截图](https://img-blog.csdnimg.cn/880ace4064fb4c029423e17475a61f95.png#pic_center)

vs code顺利编译, vs2017报错。

delete a调用析构函数输出111后,出现未加载wntdll.pdb。

符号已损坏或无法下载。首先,转到选项 - >调试 - >常规:选择加载DLL导出(仅限本机)。或者手动从Microsoft Symbol Severs下载所有pdb,选项 - >调试 - >符号 - >符号文件位置:选择Microsoft Symbol Severs并指定路径。另一个可能的解决方法是将调试/调试器类型中的C ++项目设置从“自动”更改为“仅管理”参考:https://stackoverflow.com/questions/40489106/myapp-exe-has-triggered-a-breakpoint-while-debugging-afterwards-slow-symbol

#include<iostream>
using namespace std;
 
class A {
public:
	~A() {
		cout << 111 << endl;
	}
	virtual void Fun()
	{
		cout << "A" << endl;
	}
};
 
class B :public A {
public:
	~B() {
		cout << 222 << endl;
	}
	void Fun()
	{
		cout << "B" << endl;
	}
 
};
 
int main() {
	B *a = new B();
	a->Fun();
 
	delete a;
 
 
	return 0;
}
![在这里插入图片描述](https://img-blog.csdnimg.cn/cd397ea017b64ad280c06fc420d91c97.png#pic_center)




 

参考:https://wenwen.sogou.com/z/q356278527.htm

           https://stackoverflow.com/questions/48203687/wntdll-pdb-not-loaded-cant-see-the-exception


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值