Параллельное и распределенное программирование на С++
Шрифт:
// Программа 8.3
1 #include <iostream>
2 #include <fstream>
3 #include «permutation_impl.h»
4 #define MICO_CONF_IMR
5 #include <CORBA-SMALL.h>
6 #include <iostream.h>
7 #include <fstream.h>
8 #include <unistd.h>
9 #include <mico/CosNaming.h> 10
11
12 int main(int argc, char *argv[])
13 {
14 CORBA::ORB_var Orb = CORBA: :ORB_init(argc,argv,«mico-local-orb»);
15 CORBA::Object_var PoaObj =Orb->resolve__initial_references(«RootPOA»);
16 PortableServer::POA_var Poa =PortableServer::POA::_narrow(PoaObj);
17 PortableServer::POAManager_var Mgr =Poa->the_POAManager;
18 inversion Server;
19 PortableServer: :ObjectId_var Oid =Poa->activate_object(&Server);
20 Mgr->activate ;
21 permutation_ptr ObjectReference = Server.__this;
22 CORBA::Object_var NameService =Orb->resolve_initial_references («NameService»);
23 CosNaming: :NamingContext_var NamingContext =CosNaming::NamingContext::_narrow (NameService);
24 CosNaming: :Name name;
25 name.length (1) ;
26 name[0].id = CORBA::string_dup («Inflection»);
27 name[0].kind = CORBA::string_dup ("");
28 NamingContext->bind (name, ObjectReference);
29 Orb->run;
30 Poa->destroy(TRUE,TRUE);
31 return(0) ;
32 } 33 34
§ 8.1.
Семантическал сеть (semantic network) — это одна из са м ых старых и простых схе м представления зна н ий. В ос н ове се м а н тической сети лежит г рафическое изображение иерархических взаи м оот н ошений между объекта м и. На рис. 8.9 показа н а простая семантическая сеть, которая отображает зна н ия о тра н спортных средствах в цело м и о конкретных транспортных средствах в част н ости.
Рис. 8.9. Простая семантическая сеть транспортных средств
Овалы в семантической сети называются узлами, а линии — связями. Связи представляют существующие отношения между узлами. Узлы используются для представления объектов и фактов (или описателей). Некоторые связи являются дефинициональными, а другие могут быть вычислены. Связи можно использовать для отображения наследования или подчиненности. Узлы и связи вместе выражают некоторые порции знаний. Например, изучив семантическую сеть, представленную на рис. 8.9, мы понимаем, что F-15 — это транспортное средство, а также летательный аппарат, который имеет по крайней мере два крыла. Семантические сети используются для представления знаний, необходимых в ПО принятия решений.
Использование службы имен и создание именных контекстов
При выполнении строки 22 серверная про г рамма получает ссылку на службу имен
CORBA::Object_var NameService =Orb->resolve_initial_references(«NameService»);
Помимо получения объектных ссылок на хранилище реализаций (Implementation Repositoiy) и хранилище интерфейсов (Interface Repositoiy), метод ORB-объекта resolve_initial_references используется д л я получени я ссылки на службу имен. Получив нужную ссылку, программа-сервер создает на ее основе именной контекст (см. строку 23):
CosNaming::NamingContext_var NamingContext =
CosNaming::NamingContext::_narrow(NameService);
При таком подходе мы получаем начальный именной контекст, который играет роль контекста, действующего по умолчанию. Обнаружив службу имен и создав начальный именной контекст, серверная программа может добавлять в контекст пары (связывания по имени) «имя/объектнал ссылка». Имена могут представлять
struct NameComponent { //.. .
Istring_var id;
Istring_var kind;
}
В CORBA-реализации MICO структура NameComponent объявляется в файле CosNaming. h. Структура NameComponent содержит два атрибута: id и kind. Первый атрибут используется для хранения текста имени, а второй представляет собой идентификатор, который можно использовать для классификации объекта, например так.
//...
CosNaming::Name ObjectName;
ObjectName.length(1);
ObjectName.id = Corba::string_dup (" train») ;
ObjectName.kind=Corba::string_dup(«land_transportation»);
NamingContext->bind(ObjectName,ObjectReference) ;
//...
Здесь объяв л яется объект типа NameComponent. Атрибут id устанавливается равным значению «train», а атрибут kind— значению land_transportation. Очевидно, атрибут id до л жен быть описате л е м (дескриптором) объекта. Атрибут kind м ожно ис-пользовать для описания контекста или логической группы, к которой принадлежит этот объект. В данном случае он классифицирует поезд (train) как объект land_transportation (назе м ный вид транспорта). Метод bind преобразует и м я объекта ObjectName в объектную ссылку ObjectReference и связывает ее с начальны м именным контексто м. И м я м ожет состоять из нескольких объектов типа NameComponent. Если имя состоит только из одного объекта типа NameComponent, оно называется простым, а если из нескольких — составным. Если имя составное, то атрибут kind можно использовать для описания отношения (этот метод рассматривается в главе 12). В программe 8.3 объект связывается с объектной ссылкой, которая соотносится с именованным контекстом. После связывания с именным контекстом объект клиента может получить доступ к контексту посредством службы имен. В программах 8.1 и 8.2 для связи (посре д ство м строковой IOR-ссылки ) между программами потребителя и изготовителя мы использовали файл. А для связи клиента и сервера (см. программу 8.3) используется служба имен.
Детали инсталляции и функционирования службы и м ен зависят от конкретной реализации. Среда MICO включает программу nsd, которая реализует COS-сов м ести м ую службу имен. Прежде чем служба имен будет доступной для программы-погребителя, необходимо залустить де м он micod и внести соответствующие элементы в хранилище реализаций. Чтобы узнать, как пользоваться програ мм а м и nsd, micod и imr, обратитесь к соответствую щ ей доку м е н тации и руководству по MICO (о н о содержит м ножество примеров использования программ imr, nsd, micod и ird). В листинге 8.5 приведен фрагмент из сценария, используемого для настройки сервера в программе 8.3, позволяющей сделать службу имен доступной для программы-потребителя.