免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 4883 | 回复: 5
打印 上一主题 下一主题

C++中动态调用类,如何实现。 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-06-13 22:56 |只看该作者 |倒序浏览
想在c++代码中实现这么个功能。

主类动态的new一个动态库的类,然后执行动态库的某个函数。

在c中就是用dlopen,然后找到函数地址,然后执行。对应c++如何实现。


也就是说,我主程序通过参数来判断调用那个。so的那个类。

例子如下,c++不大会写,希望不会引起误会。


--主文件
CLASS AA:ABC(CHAR *A)
{
  HHH(类名)=dlopen(.so)---不知道如何写
 DEF =  NEW HHH();
   DEF.A();
}


--主文件编译时不知道此文件。
CLASS BB
{
int A();
}
--另一个so
CLASS CC
{
int A();
}

论坛徽章:
0
2 [报告]
发表于 2008-06-13 23:29 |只看该作者

论坛徽章:
24
狮子座
日期:2013-12-31 10:48:0015-16赛季CBA联赛之吉林
日期:2016-04-18 14:43:1015-16赛季CBA联赛之北控
日期:2016-05-18 15:01:4415-16赛季CBA联赛之上海
日期:2016-06-22 18:00:1315-16赛季CBA联赛之八一
日期:2016-06-25 11:02:2215-16赛季CBA联赛之佛山
日期:2016-08-17 22:48:2615-16赛季CBA联赛之福建
日期:2016-12-27 22:39:272016科比退役纪念章
日期:2017-02-08 23:49:4315-16赛季CBA联赛之八一
日期:2017-02-16 01:05:3415-16赛季CBA联赛之山东
日期:2017-02-22 15:34:5615-16赛季CBA联赛之上海
日期:2017-11-25 16:17:5015-16赛季CBA联赛之四川
日期:2016-01-17 18:38:37
3 [报告]
发表于 2008-06-13 23:43 |只看该作者
原帖由 foxpro7 于 2008-6-13 22:56 发表
想在c++代码中实现这么个功能。

主类动态的new一个动态库的类,然后执行动态库的某个函数。

在c中就是用dlopen,然后找到函数地址,然后执行。对应c++如何实现。


也就是说,我主程序 ...


用 Factory Method 像这样:

"myso01.h"
class Base
{
  public:
    virtual ~Base() {}

    virtual void show() = 0;
};

typedef Base* create_obj();
typedef void  destroy_obj(Base*);

"myso01.cc"
#include "myso01.h"
#include <iostream>

class ABC : public Base
{
  public:
    void show();
};

void ABC::show()
{
    std::cout << "ABC" << std::endl;
}

extern "C" Base* create()
{
    return new ABC;
}

extern "C" void destroy(Base* p)
{
    delete p;
}

"main.cc"
#include "myso01.h"
#include <iostream>
#include <dlfcn.h>

int main()
{
    void* p_lib = dlopen("./myso01.so", RTLD_LAZY);
        if (!p_lib)
    {
            std::cout << dlerror() << std::endl;
            return 1;
        }

   
        create_obj* create_abc = (create_obj*)dlsym(p_lib, "create");

         char* dlsym_error = dlerror();
       if (dlsym_error)
    {
            std::cout << dlsym_error << std::endl;
                return 1;
        }
   
        destroy_obj* destroy_abc = (destroy_obj*)dlsym(p_lib, "destroy");
        dlsym_error = dlerror();
        if (dlsym_error)
    {
            std::cout << dlsym_error << std::endl;
            return 1;
        }

        Base* p_abc = create_abc();

        p_abc->show();

        destroy_abc(p_abc);

        dlclose(p_lib);

    return 0;
}

论坛徽章:
0
4 [报告]
发表于 2008-06-14 20:17 |只看该作者
其实还是用了c的方法。

我曾经想过用这个办法,不过感觉还是笨笨的。c++就没有更好的实现?

不过还是感谢。

论坛徽章:
0
5 [报告]
发表于 2008-06-14 20:21 |只看该作者
windows COM

论坛徽章:
0
6 [报告]
发表于 2008-06-14 22:58 |只看该作者
原帖由 jigloo 于 2008-6-14 20:21 发表
windows COM



可惜,不混win行业,win的东西实在是强大。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP