- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
BorlandVisiBrokerforC开发实例
Borland VisiBroker for C++ 开发实例Tony Tian本文说明使用 Borland VisiBroker 开发CORBA 应用的过程。供 Visibroker 入门使用者参考。例程可以在 VisiBroker 安装目录下的examples\basic\bank_agent 下找到,VisiBroker 下载地址是:/visibroker/download/ 。开发过程遵循以下几个步骤:1. 为 CORBA 应用中的每个对象定义IDL接口。在本例中定义两个IDL接口,一个名为 Account,内含方法:balance()。一个名为AccountManager,内含方法 open()。2. 编译 IDL 文件。使用 VisiBroker IDL Compiler - idl2cpp 编译 IDL文件,生成客户端的 stub代码和服务器端的 POA servant 代码。3. 编写客户端程序代码。初始化ORB,绑定 Account 对象和 AccountManager 对象,并调用相关方法。4. 编写服务器端程序代码。初始化ORB,提供相关接口方法的实现。5. 用 C++ 编译器编译客户端程序和服务器端程序。6. 运行服务器程序。7. 运行客户端程序。下面我们分别讨论各个步骤所作的工作。一. 定义IDL接口IDL语言用于描述一个 CORBA 对象所提供的服务,以及如何调用这些服务。本例定义名为 bank.idl 的 IDL 接口文件。内容如下所示:module Bank{interface Account {float balance()}interface AccountManage {Account open(in tring name)}二. 编译 IDL文件我们使用下列方式编译bank.idl文件:promptidl2cpp bank.idl编译后,生成了如下文件:Bank_c.hh : 包含 Account 和 AccountManager 类的定义。Bank_c.cpp : 包含供客户端使用的stub 接口程序。Bank_s.hh :包含 AccountPOA 和 AccountManagerPOA servant 类的定义。Bank_s.cpp : 包含供服务器端使用的接口程序。三. 编写客户端程序代码客户端代码(Client.c)完成ORB初始化,绑定 Account 和 AccountManager 对象,并调用相关方法。程序如下:#include Bank_c.hhint main(int argc, char* const* argv) {try {// Initialize the ORB.CORBA::ORB_var orb = CORBA::ORB_init(argc, argv);// Get the manager IdPortableServer::ObjectId_var managerId = PortableServer::string_to_ObjectId(BankManager);// Locate an account manager. Give the full POA name and the servant ID.Bank::AccountManager_var manager = Bank::AccountManager::_bind(/bank_agent_poa, managerId);// use argv[1] as the account name, or a default.const char* name = argc 1 ? argv[1] : Jack B. Quick;// Request the account manager to open a named account.Bank::Account_var account = manager-open(name);// Get the balance of the account.CORBA::Float balance = account-balance();// Print out the balance.cout The balance in name s account is $ balance endl;}catch(const CORBA::Exception e) {cerr e endl;return 1;}return 0;}四. 编写服务器端程序代码服务器端代码(S
原创力文档


文档评论(0)