c++虚函数, 接口, 抽象类
2013-12-11 23:55
447 查看
c++的抽象类可以作为接口,实现事件回调等机制.
接口实现文件IDemoImpl.cpp
[cpp] view
plaincopy
#include <stdio.h>
#include "IDemo.h"
IDemo::IDemo(){}
IDemo::~IDemo(){}
class CDemoImpl : public IDemo
{
public:
CDemoImpl(){};
~CDemoImpl(){};
public:
virtual int Add(int a, int b)
{
return (a+b);
}
virtual int Sub(int a, int b)
{
return (a-b);
}
};
IDemo * GetInstance(void)
{
return new CDemoImpl();
}
接口文件IDemo.h
[cpp] view
plaincopy
#ifndef _IDEMO_H_
#define _IDEMO_H_
class IDemo
{
public:
IDemo();
virtual ~IDemo();
public:
virtual int Add(int, int) = 0;
virtual int Sub(int, int) = 0;
};
IDemo * GetInstance(void);
#endif
对象的客户端可以这样调用
[cpp] view
plaincopy
#include "IDemo.h"
int main(void)
{
IDemo * pDemo = GetInstance();
printf("%d\n", pDemo->Add(1,2));
}
如果把IDemoImpl.cpp编译到dll或者so里面,然后只发布接口文件IDemo.h和二进制的实现,就有了一点com的雏形了。
这个GetInstance()还是太简单了,如果可以改成更具某个id去指定获取不同的对象,
比如GetInstance(const char * uuid), 那么这个函数就有了一些ms的IUnkown接口的QueryInterface()的意思了。
[cpp] view
plaincopy
HRESULT QueryInterface(
[in] REFIID riid,
[out] void **ppvObject
);
参考QueryInterface的样子,实现一个GetInstance()
[cpp] view
plaincopy
void * GetInstance(const char * uuid)
{
if (!strcmp(uuid, "uuid_add")
return new CDemoAddImpl();
if (!strcmp(uuid, "uuid_sub")
return new CDemoSubImpl();
return (void *) 0;
}
修改一个新的IDemo.h
[cpp] view
plaincopy
#ifndef _IDEMO_H_
#define _IDEMO_H_
#ifdef __cplusplus
extern "C"
{
#endif
void * GetInstance(const char * uuid);
#ifdef __cplusplus
};
#endif
#endif
分开不同功能的接口定义
IDemoAdd.h
[cpp] view
plaincopy
#ifndef _IDEMO_ADD_H_
#define _IDEMO_ADD_H_
class IDemoAdd
{
public:
IDemoAdd();
virtual ~IDemoAdd();
public:
virtual int Add(int, int) = 0;
}
#endif
IDemoSub.h
[cpp] view
plaincopy
#ifndef _IDEMO_SUB_H_
#define _IDEMO_SUB_H_
class IDemoSub
{
public:
IDemoSub();
virtual ~IDemoSub();
public:
virtual int Sub(int, int) = 0;
}
#endif
分别在2个cpp文件里面用CDemoAddImpl类和CDemoSubImpl类, 来实现Add()和Sub()方法(略)
然后把实现的cpp编译成二进制的dll或者so文件,连同3个头文件(IDemo.h IDemoAdd.h IDemoSub.h)一起发布给客户端。
客户端调用可以这样:
[cpp] view
plaincopy
#include <stdio.h>
#include "IDemo.h"
#include "IDemoAdd.h"
#include "IDemoSub.h"
int main(void)
{
IDemoAdd * pAdd = GetInstance("uuid_add");
if (pAdd)
pAdd->Add(1,2);
IDemoSub * pSub = GetInstance("uuid_sub");
pSub->Sub(1,2);
return 0;
}
总结一下:
com的基本思想就是公开对象接口(头文件),但是隐藏对象接口实现的细节(二进制库)。通过这些接口定义,客户端可以在二进制的层面像搭积木一样mashup出来新的软件,进而达到软件复用的目的
接口实现文件IDemoImpl.cpp
[cpp] view
plaincopy
#include <stdio.h>
#include "IDemo.h"
IDemo::IDemo(){}
IDemo::~IDemo(){}
class CDemoImpl : public IDemo
{
public:
CDemoImpl(){};
~CDemoImpl(){};
public:
virtual int Add(int a, int b)
{
return (a+b);
}
virtual int Sub(int a, int b)
{
return (a-b);
}
};
IDemo * GetInstance(void)
{
return new CDemoImpl();
}
接口文件IDemo.h
[cpp] view
plaincopy
#ifndef _IDEMO_H_
#define _IDEMO_H_
class IDemo
{
public:
IDemo();
virtual ~IDemo();
public:
virtual int Add(int, int) = 0;
virtual int Sub(int, int) = 0;
};
IDemo * GetInstance(void);
#endif
对象的客户端可以这样调用
[cpp] view
plaincopy
#include "IDemo.h"
int main(void)
{
IDemo * pDemo = GetInstance();
printf("%d\n", pDemo->Add(1,2));
}
如果把IDemoImpl.cpp编译到dll或者so里面,然后只发布接口文件IDemo.h和二进制的实现,就有了一点com的雏形了。
这个GetInstance()还是太简单了,如果可以改成更具某个id去指定获取不同的对象,
比如GetInstance(const char * uuid), 那么这个函数就有了一些ms的IUnkown接口的QueryInterface()的意思了。
[cpp] view
plaincopy
HRESULT QueryInterface(
[in] REFIID riid,
[out] void **ppvObject
);
参考QueryInterface的样子,实现一个GetInstance()
[cpp] view
plaincopy
void * GetInstance(const char * uuid)
{
if (!strcmp(uuid, "uuid_add")
return new CDemoAddImpl();
if (!strcmp(uuid, "uuid_sub")
return new CDemoSubImpl();
return (void *) 0;
}
修改一个新的IDemo.h
[cpp] view
plaincopy
#ifndef _IDEMO_H_
#define _IDEMO_H_
#ifdef __cplusplus
extern "C"
{
#endif
void * GetInstance(const char * uuid);
#ifdef __cplusplus
};
#endif
#endif
分开不同功能的接口定义
IDemoAdd.h
[cpp] view
plaincopy
#ifndef _IDEMO_ADD_H_
#define _IDEMO_ADD_H_
class IDemoAdd
{
public:
IDemoAdd();
virtual ~IDemoAdd();
public:
virtual int Add(int, int) = 0;
}
#endif
IDemoSub.h
[cpp] view
plaincopy
#ifndef _IDEMO_SUB_H_
#define _IDEMO_SUB_H_
class IDemoSub
{
public:
IDemoSub();
virtual ~IDemoSub();
public:
virtual int Sub(int, int) = 0;
}
#endif
分别在2个cpp文件里面用CDemoAddImpl类和CDemoSubImpl类, 来实现Add()和Sub()方法(略)
然后把实现的cpp编译成二进制的dll或者so文件,连同3个头文件(IDemo.h IDemoAdd.h IDemoSub.h)一起发布给客户端。
客户端调用可以这样:
[cpp] view
plaincopy
#include <stdio.h>
#include "IDemo.h"
#include "IDemoAdd.h"
#include "IDemoSub.h"
int main(void)
{
IDemoAdd * pAdd = GetInstance("uuid_add");
if (pAdd)
pAdd->Add(1,2);
IDemoSub * pSub = GetInstance("uuid_sub");
pSub->Sub(1,2);
return 0;
}
总结一下:
com的基本思想就是公开对象接口(头文件),但是隐藏对象接口实现的细节(二进制库)。通过这些接口定义,客户端可以在二进制的层面像搭积木一样mashup出来新的软件,进而达到软件复用的目的
相关文章推荐
- C++ 与 Java 之中的虚函数、抽象函数、抽象类、接口 比较
- C++中如何实现像Java中接口功能--C++抽象类(纯虚函数,虚函数)
- JAVA与C++对比 --– 虚函数、抽象函数、抽象类、接口
- C++ 虚函数、纯虚函数、抽象类、接口、虚基类
- C++的抽象类、虚函数、虚基类和java的抽象类和接口
- JAVA – 虚函数、抽象函数、抽象类、接口_对比C++
- C++虚函数与JAVA中抽象函数比较 接口与抽象类比较
- 抽象类 接口 虚函数(C++模拟,个人见解)
- Java C++ 比较 – 虚函数、抽象函数、抽象类、接口
- C++虚函数virtual,纯虚函数pure virtual和Java抽象函数abstract,接口interface与抽象类abstract class的比较
- 转:C++和Java 虚函数、抽象函数、抽象类、接口
- C++中的抽象类(接口和协议)
- c++中抽象类、虚函数和纯虚函数的学习以及和Java的对比
- C++中接口与抽象类
- C# 虚函数 、抽象类和抽象函、接口的简单说明
- C++接口(抽象类)
- C++第十三周【任务1】开车学习虚函数、多态性和抽象类的应用
- c++标准的 接口和抽象类
- C++ 接口(抽象类)
- C++ 虚基类、虚函数、纯虚函数、抽象类