#include <stdlib.h>
#include <stdio.h>
#include <string.h>
class Session
{
public:
Session(){num =0;}
void setNum(int nindex){ num = nindex;}
virtual void ThreadStep(){printf("hello world\n");}
public:
int num;
};
class MySession : public Session
{
void ThreadStep();
};
void MySession::ThreadStep()
{
printf("%d\n",num);
}
int main()
{
Session session;
session.ThreadStep();
// MySession mysession;
// Session *session =&mysession;
// session->ThreadStep();
return 0;
}
/*
在类Session中有一个虚函数:
virtual void ThreadStep() { }
我在MySession 中把它实现:
class MySession : public Session
{
protected:
void ThreadStep();
调用的部分是这样的:
Session &session;
session.ThreadStep();
但是函数调用还是调用Session中的那个,而不是MySession 中的那个,为什么啊?
MySession instance;
Session *p = &instance;
p->ThreadStep();
上面的方式应该调用子类的函数了\*/
#include <stdio.h>
#include <string.h>
class Session
{
public:
Session(){num =0;}
void setNum(int nindex){ num = nindex;}
virtual void ThreadStep(){printf("hello world\n");}
public:
int num;
};
class MySession : public Session
{
void ThreadStep();
};
void MySession::ThreadStep()
{
printf("%d\n",num);
}
int main()
{
Session session;
session.ThreadStep();
// MySession mysession;
// Session *session =&mysession;
// session->ThreadStep();
return 0;
}
/*
在类Session中有一个虚函数:
virtual void ThreadStep() { }
我在MySession 中把它实现:
class MySession : public Session
{
protected:
void ThreadStep();
调用的部分是这样的:
Session &session;
session.ThreadStep();
但是函数调用还是调用Session中的那个,而不是MySession 中的那个,为什么啊?
MySession instance;
Session *p = &instance;
p->ThreadStep();
上面的方式应该调用子类的函数了\*/
本文探讨了C++中虚函数的使用方法及其在继承类中的覆盖问题。通过具体的代码示例,解释了如何正确地实现和调用派生类中的虚函数,解决了在特定上下文中基类函数被误调用的问题。
9164

被折叠的 条评论
为什么被折叠?



