Корзина
0
Корзина
0
Добавьте в корзину товаров ещё на 900 гривен, чтобы БЕСПЛАТНО получить товар по Украине до отделения Новой почты.

Ваша корзина пустая

Меню
Чай, кофе, безалкогольные напитки
Купить Технология Corba для профессионалов +CD

Технология Corba для профессионалов +CD

Рассматриваются вопросы, наиболее важные для CORBA-программиста - концепция, назначение, область применения составных частей архитектуры CORBA. Книга предназначена для программистов средней и высокой квалификации, хорошо знакомыми с языками C++ и/или Java и имеющими опыт их применения. Она может быть использована на курсах по изучению основных возможностей CORBA. Прилагаемый компакт-диск содержит как все тексты учебных программ, так и большое количество документов, являющихся частью спецификации CORBA. Кроме того, вы найдете там trial-версии основных продуктов Inprise, ориентированных на создание распределенных систем - C++ Builder 5.0, JBuilder 4, VisiBroker 4.0 for C++/Java, Inprise Application Server 4.1, Inprise Application Center и многое другое.

Краткое содержание

Часть I. Вводная Распределенные системы: задачи и терминология

Задачи, для решения которых используются распределенные системы

Часто используемые термины

Объектно-ориентированное программирование (ООП)

Объект

Метод

Свойство

Состояние

Интерфейс

Реализация

Наследование

Полиморфизм

Сообщение

Компонентная модель

Компонент

Object

Request Broker (ORB)

Стаб Маршалинг

Сервер

Серверный объект

Транзакция

Монитор транзакций (OTM)

Распределенная система

Краткий обзор современных технологий XML CGI/ISAPI/Servlet/JSP CGI ISAPI/NSAPI Servlets JSP Использование CGI/ISAPI/ASP/Servlet в распределенных системах DCOM CORBA RMI JavaBeans/Enterprise JavaBeans JavaBeans (JB) Enterprise JavaBeans (EJB) EJB Server EJB Container

Заключение

CORBA.

Архитектура, состояние и перспективы IDL ORB

Объектные адаптеры

Сервисы CORBA

Сервис имен

Трейдер-сервис

Сервис свойств

Сервис отношений

Сервис цикла жизни

Сервис событий

Сервис долговременного хранения

Сервис внешнего представления

Сервис транзакций

Сервис совместного доступа

Сервис безопасности

Сервис времени

Сервис лицензирования

Сервис контейнеров

Сервис запросов

Реализация INPRISE/Visigenic

Перспективы - CORBA 3.0

Языки программирования и распределенные системы C++ Delphi Java

Часть II. Основы CORBA

Глава 1. Язык определения интерфейсов IDL

1.1. Служебные слова, идентификаторы и комментарии 1.2. Основные типы данных IDL 1.2.1. Базовые типы данных 1.2.2. Сконструированные типы данных 1.2.3. Исключения CORBA 1.2.4. Объектные ссылки и интерфейсы 1.2.5. Типы-значения IDL 1.2.6. Абстрактные интерфейсы 1.2.7. Тип Any и интерфейс TypeCode 1.3. Константы IDL 1.4. Модули и пространства имен 1.4.1. Синтаксис определения модуля 1.4.2. Вложенные пространства имен 1.5. Структура IDL-файла 1.5.1. Модули 1.5.2. Интерфейсы 1.5.3. Типы-значения 1.5.4. Структуры, объединения и исключения 1.6. Псевдо-IDL (PIDL) 1.7. Репозитарные идентификаторы (RepositoryID) 1.7.1. Формат OMG IDL 1.7.2. Формат RMI 1.7.3. Формат DCE UUID 1.7.4. Формат LOCAL 1.8. Препроцессор 1.8.1. Основные директивы препроцессора 1.8.2. Директива #pragma ID 1.8.3. Директива #pragma prefix 1.8.4. Директива #pragma version

Глава 2. Отображение IDL на C++

2.1. Некоторые конструкции C++ 2.1.1. namespace 2.1.2. template-классы 2.1.3. auto_ptr 2.1.4. Некоторые классы STL 2.2. Опции компилятора idl2cpp 2.2.1. Опция -boa 2.2.2. Опция -excep_spec 2.2.3. Опция -namespace 2.2.4. Опция -tie 2.2.5. Опция -type_code_info 2.3. Код, сгенерированный для использования на стороне клиента 2.4. Код, сгенерированный для использования на стороне сервера 2.5. _var, _ptr и _out-типы 2.5.1. Тип _ptr 2.5.2. Тип _var 2.5.3. Тип _out 2.6. Идентификаторы 2.7. Базовые типы данных 2.7.1. Простые базовые типы данных 2.7.2. Типы string и wstring 2.7.3. Функции управления динамической памятью 2.7.4. Класс CORBA::String_var 2.7.5. Типичные ошибки при использовании String_var и char* 2.7.6. Перечисления 2.8. Сконструированные типы данных 2.8.1. Оператор typedef 2.8.2. Массивы 2.8.3. Последовательности 2.8.4. Структуры 2.8.5. Объединения 2.9. Исключения 2.10. Интерфейсы 2.10.1. Общие принципы 2.10.2. Объектные ссылки 2.10.3. Proxy-объект 2.10.4. Преобразования типов 2.10.5. Использование счетчиков ссылок 2.11. Классы на стороне клиента 2.12. Знакомство с объектными адаптерами 2.13. Классы на стороне сервера 2.14. Типы-значения 2.14.1. Обычный valuetype 2.14.2. Абстрактные valuetype 2.14.3. Наследование valuetype 2.14.4. Boxed valuetype 2.14.5. Базовые типы, перечисления и объектные ссылки 2.14.6. Структуры строки struct 2.14.7. Строки string и wstring 2.14.8. Типы union, sequence, fixed и any 2.14.9. Массивы 2.14.10. Valuetype, поддерживающий IDL interface 2.15. Абстрактные интерфейсы 2.16. Тип any и TypeCode 2.16.1. Тип any 2.16.2. Тип any и string/wstring 2.16.3. Cтруктуры, объединения и последовательности и any 2.16.4. Массивы и any 2.16.5. Объектные ссылки и any 2.16.6. TCKind 2.16.7. TypeCode 2.16.8. DynAny 2.16.9. Пример использования 2.17. Константы 2.18. Модули 2.19. Tie-классы 2.20. Схема управления динамической памятью 2.21. Передача аргументов

Глава 3. Отображение IDL на Java

3.1. Опции компилятора idl2java 3.1.1. Опция -[no_]boa 3.1.2. Опция -[no_]comments 3.1.3. Опция -[no_]examples 3.1.4. Опция -tie 3.2. Код, сгенерированный для использования на стороне клиента 3.3. Код, сгенерированный для использования на стороне сервера 3.4. Helper-классы 3.5. Holder-классы 3.6. Интерфейс IDLEntity 3.7. Идентификаторы 3.8. Базовые типы данных 3.8.1. Простые базовые типы данных 3.8.2. Строки 3.8.3. Перечисления 3.9. Сконструированные типы данных 3.9.1. Оператор typedef 3.9.2. Массивы 3.9.3. Последовательности 3.9.4. Структуры 3.9.5. Объединения 3.10. Исключения 3.11. Интерфейсы 3.11.1. Общие принципы 3.11.2. Объектные ссылки 3.12. Классы на стороне клиента 3.12.1. Методы класса Helper 3.12.2. Система обеспечения переносимости кода стабов 3.13. Классы на стороне сервера 3.13.1. Методы класса POA 3.13.2. Система обеспечения переносимости кода скелетов 3.14. Типы-значения 3.14.1. Обычный (stateful) valuetype 3.14.2. Абстрактные valuetype 3.14.3. Наследование valuetype 3.14.4. Boxed valuetype 3.15. Абстрактные интерфейсы 3.16. Тип any и TypeCode 3.16.1. Тип any 3.16.2. IDL-типы данных и any 3.16.3. TCKind 3.16.4. TypeCode 3.16.5. DynAny 3.16.6. Пример использования 3.17. Константы 3.18. Модули 3.19. Tie-классы 3.20. Передача аргументов

Глава 4. Отображение IDL на Delphi

4.1. Delphi и распределенные системы 4.1.1. Состояние, проблемы и перспективы 4.1.2. Delphi 5 и CORBA 4.1.3. Реальная поддержка CORBA в Delphi 4.1.4. Особенности управления памятью в Delphi 5 при работе с CORBA 4.1.5. Производительность 4.2. Опции компилятора idl2pas 4.2.1. Опции -generate_empty_units/-no_generate_empty_units 4.2.2. Опции -comments/-no_comments 4.2.3. Опция -root_dir 4.3. Код, сгенерированный для использования на стороне клиента 4.4. Код, сгенерированный для использования на стороне сервера 4.5. Helper-классы 4.6. Stub-классы 4.7. Идентификаторы 4.8. Базовые типы данных 4.8.1. Простые базовые типы данных 4.8.2. Строки 4.8.3. Перечисления 4.9. Сконструированные типы данных 4.9.1. Оператор typedef 4.9.2. Массивы 4.9.3. Последовательности 4.9.4. Структуры 4.9.5. Объединения 4.10. Исключения 4.11. Интерфейсы 4.12. Тип аny 4.13. Константы 4.14. Модули 4.15. Передача аргументов

Глава 5. ORB 5.1. ORB и их взаимодействие

5.2. Объектная ссылка и IOR 5.3. Инициализация ORB 5.4. Интерфейс ORB 5.4.1. Преобразования между объектными ссылками и строками 5.4.2. Организация динамических и асинхронных вызовов 5.4.3. Информационные методы 5.4.4. Обеспечение доступа к сервисам 5.4.5. Динамическое создание объектов типа TypeCode 5.4.6. Методы управления работой сервера приложений 5.4.7. Создание объектов типа Policy 5.4.8. Управление фабриками для типов-значений

Глава 6. Объекты и объектные ссылки

6.1. Понятие объекта CORBA 6.2. Объекты и интерфейсы 6.3. Объектная ссылка 6.4. Интерфейс CORBA::Object 6.4.1. IDL-объявление 6.4.2. Метод _get_interface() 6.4.3. Метод is_nil() 6.4.4. Метод _duplicate() 6.4.5. Метод _release() 6.4.6. Метод _is_a() 6.4.7. Метод _non_existent() 6.4.8. Метод _is_equivalent() 6.4.9. Метод _hash() 6.4.10. Метод _get_policy() 6.5. Некоторые методы, создаваемые при отображении интерфейса CORBA::Object для VisiBroker 6.5.1. Метод _nil() (только для C++) 6.5.2. Метод CORBA::_release() (только для C++) 6.6. Расширения интерфейса CORBA::Object для VisiBroker 6.6.1. Метод _is_bound() 6.6.2. Метод _is_persistent() 6.6.3. Метод _is_local() 6.6.4. Метод _is_remote() 6.6.5. Метод _object_name() 6.6.6. Метод _repository_id() 6.6.7. Методы работы с Policy (часть QoS) 6.6.8. Метод _ref_count() (только для C++) 6.6.9. Метод _interface_name() (только для C++) 6.6.10. Методы _type_info () и _desc() (только для C++) 6.6.11. Метод _clone () (только для C++) 6.6.12. Метод _orb () (только для Java) 6.7. Методы получения объектных ссылок 6.7.1. Стандартные способы CORBA 6.7.2. Расширения для VisiBroker 6.7.3. Использование smart agent для получения объектных ссылок 6.8. Метод _narrow() 6.9. Утилита PrintIOR

Глава 7. Объекты и объектный адаптер POA

7.1. Серванты 7.2. Объекты CORBA и их серванты 7.3. Объекты на стороне сервера 7.4. Основные обязанности POA 7.5. Структура POA 7.5.1. Active Object Map 7.5.2. Servant Manager 7.6. Иерархия POA 7.6.1. RootPOA 7.6.2. Дочерние POA 7.7. Опции (Policies) POA 7.7.1. Thread Policy 7.7.2. Lifespan Policy 7.7.3. Object Id Uniqueness Policy 7.7.4. Id Assignment Policy 7.7.5. Servant Retention Policy 7.7.6. Request Processing Policy 7.7.7. Implicit Activation Policy 7.7.8. Bind Support Policy (только для VisiBroker) 7.7.9. Server Engine Policy (только для VisiBroker) 7.8. IDL-Интерфейс POA 7.8.1. Операции создания и поиска POA 7.8.2. Операция уничтожения POA 7.8.3. Фабрики объектов типа Policy 7.8.4. Операции регистрации менеджеров сервантов и Default-менеджера 7.8.5. Операции активизации и деактивизации CORBA-объектов 7.8.6. Операции создания CORBA-объектов 7.8.7. Операции преобразования 7.9. ServantActivator 7.10. ServantLocator 7.11. Default Servant 7.12. Интерфейс POAManager 7.13. Интерфейс AdapterActivator 7.14. Интерфейс Current 7.15. "Сборка мусора" в распределенных системах

Глава 8. Многопоточность

8.1. Модели управления потоками VisiBroker 8.1.1. Модель Thread pooling 8.1.2. Модель Thread-per-session 8.2. Управление соединениями 8.3. Средства синхронизации VisiBroker для C++ 8.3.1. Мьютексы 8.3.2. Классы VISRWLock, VISRLock_var и VISWLock_var 8.3.3. Класс VISThread

Глава 9. Репозитарии интерфейсов

9.1. Что такое репозитарий интерфейсов 9.2. Иерархия интерфейсов для IR 9.2.1. Интерфейсы IR 9.2.2. Иерархия содержания 9.2.3. Иерархия наследования 9.3. Создание репозитариев интерфейсов 9.4. Просмотр информации в репозитариях интерфейсов 9.4.1. Пример отображения информации из IR на C++ 9.4.2. Пример отображения информации из IR на Java 9.5. Занесение информации в репозитарии интерфейсов 9.6. Доступ к требуемому репозитарию интерфейсов 9.6.1. Присоединение к репозитарию интерфейсов 9.6.2. Получение информации об интерфейсах по объектной ссылке

Глава 10. Репозитарии реализаций

10.1. Установка связи с серверным объектом по объектной ссылке 10.1.1. Прямая привязка 10.1.2. Косвенная привязка 10.2. Информация в репозитарии реализаций 10.3. Взаимодействие серверов приложений и репозитариев реализаций 10.4. Последовательность действий при установке связи 10.5. VisiBroker OAD 10.6. Утилиты для взаимодействия с OAD 10.6.1. Регистрация объектов в OAD 10.6.2. Отмена регистрации объектов в OAD 10.6.3. Получение информации из OAD 10.7. IDL-объявления для OAD 10.8. Взаимодействие с OAD из программ 10.8.1. Использование C++ 10.8.2. Использование Java

Глава 11. Динамическое взаимодействие клиентов и серверов

11.1. Какая информация необходима для использования DII/DSI 11.2. Некоторые IDL-типы, используемые при работе с DII/DSI 11.2.1. NamedValue 11.2.2. NVList 11.2.3. Environment 11.2.4. Context 11.2.5. Интерфейс ExceptionList 11.3. DII 11.3.1. Объект CORBA::Request 11.3.2. Отображение Request на C++ 11.3.3. Отображение Request на Java 11.3.4. Создание объекта Request 11.3.5. Вызовы удаленных методов 11.4. DSI 11.4.1. Объект ServerRequest 11.4.2. Отображение ServerRequest на C++ 11.4.3. Отображение ServerRequest на Java 11.4.4. Тип серванта 11.4.5. PortableServer::DynamicImplementation 11.4.6. CORBA::DynamicImplementation

Глава 12. Smart аgents

12.1. Что такое smart agent 12.2. Взаимодействие smart agents, серверов и клиентов 12.2.1. Запуск smart agent 12.2.2. Взаимодействие smart agents друг с другом 12.2.3. Smart agents и серверные объекты 12.2.4. Smart agents и клиенты 12.2.5. Домены ORB 12.3. Настройка параметров при использовании smart agents 12.3.1. Параметры, влияющие на поведение smart agents 12.3.2. Способы настройки параметров 12.3.3. Взаимодействие в объединении локальных сетей 12.3.4. Использование multihomed-хостов 12.4. Утилиты osfind и VisiBroker Console 12.5. Распределение нагрузки между серверами 12.6. Обеспечение устойчивости к сбоям 12.7. Location Service 12.7.1. IDL для Location Service 12.7.2. Получение доступа к Location Service 12.7.3. Интерфейс Agent 12.7.4. Триггеры сервиса поиска

Глава 13. Cервисы именования CORBA

13.1. Концепция Naming Service 13.2. Основные понятия 13.2.1. Представление имен 13.2.2. Связанное имя 13.2.3. Контекст имен 13.2.4. Начальный контекст имен 13.2.5. Иерархия контекстов 13.2.6. Разрешение имени 13.3. Интерфейсы Naming Service 13.3.1. Интерфейс NamingContext 13.3.2. Интерфейс BindingIterator 13.4. Создание экземпляра службы именования 13.5. Соединение с экземпляром службы именования 13.6. Федерация служб именования 13.7. Расширения, предлагаемые INS 13.7.1. Представление имен 13.7.2. Кластеры 13.7.3. Сохранение состояния

Глава 14. Callback-вызовы, сервисы событий и уведомлений

14.1. Callback-объекты при использовании CORBA 14.2. Сервис событий CORBA 14.2.1. Недостатки сервиса событий 14.2.2. Основные положения 14.2.3. Канал событий 14.2.4. Модели взаимодействия сервиса событий 14.2.5. Основные этапы создания приложения 14.2.6. Модуль CosEventComm 14.2.7. Модуль CosEventChannelAdmin 14.2.8. Понятие о типизированных событиях 14.3. Сервис уведомлений CORBA 14.4. Сервис сообщений CORBA 14.4.1. AMI 14.4.2. TII 14.5. Заключение

Глава 15. Сервис жизненного цикла

15.1. Модуль CosLifeCycle 15.1.1. "Фабрика" как формальная конструкция 15.1.2. Используемые IDL-типы 15.1.3. Интерфейс GenericFactory 15.1.4. Интерфейс FactoryFinder 15.1.5. Интерфейс LifeCycleObject 15.2. Модуль CosCompoundLifeCycle 15.3. Проблемы использования сервиса 15.4. Уничтожение CORBA-объектов 15.4.1. Основные положения 15.4.2. Уничтожение при явной активизации объектов 15.4.3. Уничтожение при использовании серванта по умолчанию 15.4.4. Уничтожение при использовании менеджера-активатора 15.4.5. Уничтожение при использовании менеджера-локатора 15.5. Заключение Часть III. Создание простых приложений

Глава 16. Создание простейшего клиента и сервера

16.1. Общие замечания 16.2. Использование C++ 16.2.1. Сервер 16.2.2. Клиент 16.3. Использование Java 16.3.1. Сервер 16.3.2. Клиент 16.4. Использование Delphi 16.4.1. Клиент 16.5. Заключение

Глава 17. Работа с POA

17.1. Общие замечания по примерам программ 17.2. Использование C++ 17.2.1. Явная активизация объекта 17.2.2. Явная активизация объекта с использованием счетчика ссылок 17.2.3. Использование менеджера-активатора 17.2.4. Использование менеджера-локатора 17.2.5. Использование серванта по умолчанию 17.2.6. Активизация объектного адаптера 17.2.7. Клиент 17.3. Использование Java 17.3.1. Явная активизация объекта 17.3.2. Использование менеджера-активатора 17.3.3. Использование менеджера-локатора 17.3.4. Использование серванта по умолчанию 17.3.5. Активизация объектного адаптера 17.3.6. Клиент 17.4. Заключение

Глава 18. Взаимодействие с репозитарием интерфейсов

18.1. Использование C++ 18.2. Использование Java 18.3. Результат работы

Глава 19. Использование DII/DSI

19.1. Использование C++ 19.1.1. Статический сервер 19.1.2. Статический клиент 19.1.3. DII-клиент 19.1.4. DSI-сервер 19.2. Использование Java 19.2.1. Статический сервер 19.2.2. Статический клиент 19.2.3. DII-клиент 19.2.4. DSI-сервер 19.3. Заключение

Глава 20. Использование сервиса именования CORBA

20.1. Задача и IDL-объявления серверного объекта 20.2. Запуск Naming Service 20.3. Серверное приложение 20.3.1. С++ 20.3.2. Java 20.3.3. Использование VisiBroker Console для создания графа имен 20.4. Клиентское приложение 20.4.1. С++ 20.4.2. Java 20.5. Заключение

Глава 21. Использование сервиса событий

21.1. Создание канала событий с помощью утилит VisiBroker 21.2. Создание канала событий с использованием интерфейса EventChannelFactory и классов VisiBroker 21.2.1. IDL-объявление интерфейса EventChannelFactory 21.2.2. Отображение интерфейса EventChannelFactory на С++ 21.2.3. Отображение интерфейса EventChannelFactory на Java 21.2.4. Создание объекта типа EventChannelFactory 21.3. Присоединение к каналу событий 21.4. Пример использования push-модели 21.4.1. Применение C++ 21.4.2. Применение Java 21.5. Заключение

Используемая литература

Алфавитный указатель

66
Нет в наличии

Технология Corba для профессионалов +CD

Купить Технология Corba для профессионалов +CD
Артикул : 3706
Издательство : Питер
Автор : Цимбал
Язык : Английский
Страниц : 624
Год издания : 2001
Нет в наличии

Описание
Рассматриваются вопросы, наиболее важные для CORBA-программиста - концепция, назначение, область применения составных частей архитектуры CORBA. Книга предназначена для программистов средней и высокой квалификации, хорошо знакомыми с языками C++ и/или Java и имеющими опыт их применения. Она может быть использована на курсах по изучению основных возможностей CORBA. Прилагаемый компакт-диск содержит как все тексты учебных программ, так и большое количество документов, являющихся частью спецификации CORBA. Кроме того, вы найдете там trial-версии основных продуктов Inprise, ориентированных на создание распределенных систем - C++ Builder 5.0, JBuilder 4, VisiBroker 4.0 for C++/Java, Inprise Application Server 4.1, Inprise Application Center и многое другое.

Краткое содержание

Часть I. Вводная Распределенные системы: задачи и терминология

Задачи, для решения которых используются распределенные системы

Часто используемые термины

Объектно-ориентированное программирование (ООП)

Объект

Метод

Свойство

Состояние

Интерфейс

Реализация

Наследование

Полиморфизм

Сообщение

Компонентная модель

Компонент

Object

Request Broker (ORB)

Стаб Маршалинг

Сервер

Серверный объект

Транзакция

Монитор транзакций (OTM)

Распределенная система

Краткий обзор современных технологий XML CGI/ISAPI/Servlet/JSP CGI ISAPI/NSAPI Servlets JSP Использование CGI/ISAPI/ASP/Servlet в распределенных системах DCOM CORBA RMI JavaBeans/Enterprise JavaBeans JavaBeans (JB) Enterprise JavaBeans (EJB) EJB Server EJB Container

Заключение

CORBA.

Архитектура, состояние и перспективы IDL ORB

Объектные адаптеры

Сервисы CORBA

Сервис имен

Трейдер-сервис

Сервис свойств

Сервис отношений

Сервис цикла жизни

Сервис событий

Сервис долговременного хранения

Сервис внешнего представления

Сервис транзакций

Сервис совместного доступа

Сервис безопасности

Сервис времени

Сервис лицензирования

Сервис контейнеров

Сервис запросов

Реализация INPRISE/Visigenic

Перспективы - CORBA 3.0

Языки программирования и распределенные системы C++ Delphi Java

Часть II. Основы CORBA

Глава 1. Язык определения интерфейсов IDL

1.1. Служебные слова, идентификаторы и комментарии 1.2. Основные типы данных IDL 1.2.1. Базовые типы данных 1.2.2. Сконструированные типы данных 1.2.3. Исключения CORBA 1.2.4. Объектные ссылки и интерфейсы 1.2.5. Типы-значения IDL 1.2.6. Абстрактные интерфейсы 1.2.7. Тип Any и интерфейс TypeCode 1.3. Константы IDL 1.4. Модули и пространства имен 1.4.1. Синтаксис определения модуля 1.4.2. Вложенные пространства имен 1.5. Структура IDL-файла 1.5.1. Модули 1.5.2. Интерфейсы 1.5.3. Типы-значения 1.5.4. Структуры, объединения и исключения 1.6. Псевдо-IDL (PIDL) 1.7. Репозитарные идентификаторы (RepositoryID) 1.7.1. Формат OMG IDL 1.7.2. Формат RMI 1.7.3. Формат DCE UUID 1.7.4. Формат LOCAL 1.8. Препроцессор 1.8.1. Основные директивы препроцессора 1.8.2. Директива #pragma ID 1.8.3. Директива #pragma prefix 1.8.4. Директива #pragma version

Глава 2. Отображение IDL на C++

2.1. Некоторые конструкции C++ 2.1.1. namespace 2.1.2. template-классы 2.1.3. auto_ptr 2.1.4. Некоторые классы STL 2.2. Опции компилятора idl2cpp 2.2.1. Опция -boa 2.2.2. Опция -excep_spec 2.2.3. Опция -namespace 2.2.4. Опция -tie 2.2.5. Опция -type_code_info 2.3. Код, сгенерированный для использования на стороне клиента 2.4. Код, сгенерированный для использования на стороне сервера 2.5. _var, _ptr и _out-типы 2.5.1. Тип _ptr 2.5.2. Тип _var 2.5.3. Тип _out 2.6. Идентификаторы 2.7. Базовые типы данных 2.7.1. Простые базовые типы данных 2.7.2. Типы string и wstring 2.7.3. Функции управления динамической памятью 2.7.4. Класс CORBA::String_var 2.7.5. Типичные ошибки при использовании String_var и char* 2.7.6. Перечисления 2.8. Сконструированные типы данных 2.8.1. Оператор typedef 2.8.2. Массивы 2.8.3. Последовательности 2.8.4. Структуры 2.8.5. Объединения 2.9. Исключения 2.10. Интерфейсы 2.10.1. Общие принципы 2.10.2. Объектные ссылки 2.10.3. Proxy-объект 2.10.4. Преобразования типов 2.10.5. Использование счетчиков ссылок 2.11. Классы на стороне клиента 2.12. Знакомство с объектными адаптерами 2.13. Классы на стороне сервера 2.14. Типы-значения 2.14.1. Обычный valuetype 2.14.2. Абстрактные valuetype 2.14.3. Наследование valuetype 2.14.4. Boxed valuetype 2.14.5. Базовые типы, перечисления и объектные ссылки 2.14.6. Структуры строки struct 2.14.7. Строки string и wstring 2.14.8. Типы union, sequence, fixed и any 2.14.9. Массивы 2.14.10. Valuetype, поддерживающий IDL interface 2.15. Абстрактные интерфейсы 2.16. Тип any и TypeCode 2.16.1. Тип any 2.16.2. Тип any и string/wstring 2.16.3. Cтруктуры, объединения и последовательности и any 2.16.4. Массивы и any 2.16.5. Объектные ссылки и any 2.16.6. TCKind 2.16.7. TypeCode 2.16.8. DynAny 2.16.9. Пример использования 2.17. Константы 2.18. Модули 2.19. Tie-классы 2.20. Схема управления динамической памятью 2.21. Передача аргументов

Глава 3. Отображение IDL на Java

3.1. Опции компилятора idl2java 3.1.1. Опция -[no_]boa 3.1.2. Опция -[no_]comments 3.1.3. Опция -[no_]examples 3.1.4. Опция -tie 3.2. Код, сгенерированный для использования на стороне клиента 3.3. Код, сгенерированный для использования на стороне сервера 3.4. Helper-классы 3.5. Holder-классы 3.6. Интерфейс IDLEntity 3.7. Идентификаторы 3.8. Базовые типы данных 3.8.1. Простые базовые типы данных 3.8.2. Строки 3.8.3. Перечисления 3.9. Сконструированные типы данных 3.9.1. Оператор typedef 3.9.2. Массивы 3.9.3. Последовательности 3.9.4. Структуры 3.9.5. Объединения 3.10. Исключения 3.11. Интерфейсы 3.11.1. Общие принципы 3.11.2. Объектные ссылки 3.12. Классы на стороне клиента 3.12.1. Методы класса Helper 3.12.2. Система обеспечения переносимости кода стабов 3.13. Классы на стороне сервера 3.13.1. Методы класса POA 3.13.2. Система обеспечения переносимости кода скелетов 3.14. Типы-значения 3.14.1. Обычный (stateful) valuetype 3.14.2. Абстрактные valuetype 3.14.3. Наследование valuetype 3.14.4. Boxed valuetype 3.15. Абстрактные интерфейсы 3.16. Тип any и TypeCode 3.16.1. Тип any 3.16.2. IDL-типы данных и any 3.16.3. TCKind 3.16.4. TypeCode 3.16.5. DynAny 3.16.6. Пример использования 3.17. Константы 3.18. Модули 3.19. Tie-классы 3.20. Передача аргументов

Глава 4. Отображение IDL на Delphi

4.1. Delphi и распределенные системы 4.1.1. Состояние, проблемы и перспективы 4.1.2. Delphi 5 и CORBA 4.1.3. Реальная поддержка CORBA в Delphi 4.1.4. Особенности управления памятью в Delphi 5 при работе с CORBA 4.1.5. Производительность 4.2. Опции компилятора idl2pas 4.2.1. Опции -generate_empty_units/-no_generate_empty_units 4.2.2. Опции -comments/-no_comments 4.2.3. Опция -root_dir 4.3. Код, сгенерированный для использования на стороне клиента 4.4. Код, сгенерированный для использования на стороне сервера 4.5. Helper-классы 4.6. Stub-классы 4.7. Идентификаторы 4.8. Базовые типы данных 4.8.1. Простые базовые типы данных 4.8.2. Строки 4.8.3. Перечисления 4.9. Сконструированные типы данных 4.9.1. Оператор typedef 4.9.2. Массивы 4.9.3. Последовательности 4.9.4. Структуры 4.9.5. Объединения 4.10. Исключения 4.11. Интерфейсы 4.12. Тип аny 4.13. Константы 4.14. Модули 4.15. Передача аргументов

Глава 5. ORB 5.1. ORB и их взаимодействие

5.2. Объектная ссылка и IOR 5.3. Инициализация ORB 5.4. Интерфейс ORB 5.4.1. Преобразования между объектными ссылками и строками 5.4.2. Организация динамических и асинхронных вызовов 5.4.3. Информационные методы 5.4.4. Обеспечение доступа к сервисам 5.4.5. Динамическое создание объектов типа TypeCode 5.4.6. Методы управления работой сервера приложений 5.4.7. Создание объектов типа Policy 5.4.8. Управление фабриками для типов-значений

Глава 6. Объекты и объектные ссылки

6.1. Понятие объекта CORBA 6.2. Объекты и интерфейсы 6.3. Объектная ссылка 6.4. Интерфейс CORBA::Object 6.4.1. IDL-объявление 6.4.2. Метод _get_interface() 6.4.3. Метод is_nil() 6.4.4. Метод _duplicate() 6.4.5. Метод _release() 6.4.6. Метод _is_a() 6.4.7. Метод _non_existent() 6.4.8. Метод _is_equivalent() 6.4.9. Метод _hash() 6.4.10. Метод _get_policy() 6.5. Некоторые методы, создаваемые при отображении интерфейса CORBA::Object для VisiBroker 6.5.1. Метод _nil() (только для C++) 6.5.2. Метод CORBA::_release() (только для C++) 6.6. Расширения интерфейса CORBA::Object для VisiBroker 6.6.1. Метод _is_bound() 6.6.2. Метод _is_persistent() 6.6.3. Метод _is_local() 6.6.4. Метод _is_remote() 6.6.5. Метод _object_name() 6.6.6. Метод _repository_id() 6.6.7. Методы работы с Policy (часть QoS) 6.6.8. Метод _ref_count() (только для C++) 6.6.9. Метод _interface_name() (только для C++) 6.6.10. Методы _type_info () и _desc() (только для C++) 6.6.11. Метод _clone () (только для C++) 6.6.12. Метод _orb () (только для Java) 6.7. Методы получения объектных ссылок 6.7.1. Стандартные способы CORBA 6.7.2. Расширения для VisiBroker 6.7.3. Использование smart agent для получения объектных ссылок 6.8. Метод _narrow() 6.9. Утилита PrintIOR

Глава 7. Объекты и объектный адаптер POA

7.1. Серванты 7.2. Объекты CORBA и их серванты 7.3. Объекты на стороне сервера 7.4. Основные обязанности POA 7.5. Структура POA 7.5.1. Active Object Map 7.5.2. Servant Manager 7.6. Иерархия POA 7.6.1. RootPOA 7.6.2. Дочерние POA 7.7. Опции (Policies) POA 7.7.1. Thread Policy 7.7.2. Lifespan Policy 7.7.3. Object Id Uniqueness Policy 7.7.4. Id Assignment Policy 7.7.5. Servant Retention Policy 7.7.6. Request Processing Policy 7.7.7. Implicit Activation Policy 7.7.8. Bind Support Policy (только для VisiBroker) 7.7.9. Server Engine Policy (только для VisiBroker) 7.8. IDL-Интерфейс POA 7.8.1. Операции создания и поиска POA 7.8.2. Операция уничтожения POA 7.8.3. Фабрики объектов типа Policy 7.8.4. Операции регистрации менеджеров сервантов и Default-менеджера 7.8.5. Операции активизации и деактивизации CORBA-объектов 7.8.6. Операции создания CORBA-объектов 7.8.7. Операции преобразования 7.9. ServantActivator 7.10. ServantLocator 7.11. Default Servant 7.12. Интерфейс POAManager 7.13. Интерфейс AdapterActivator 7.14. Интерфейс Current 7.15. "Сборка мусора" в распределенных системах

Глава 8. Многопоточность

8.1. Модели управления потоками VisiBroker 8.1.1. Модель Thread pooling 8.1.2. Модель Thread-per-session 8.2. Управление соединениями 8.3. Средства синхронизации VisiBroker для C++ 8.3.1. Мьютексы 8.3.2. Классы VISRWLock, VISRLock_var и VISWLock_var 8.3.3. Класс VISThread

Глава 9. Репозитарии интерфейсов

9.1. Что такое репозитарий интерфейсов 9.2. Иерархия интерфейсов для IR 9.2.1. Интерфейсы IR 9.2.2. Иерархия содержания 9.2.3. Иерархия наследования 9.3. Создание репозитариев интерфейсов 9.4. Просмотр информации в репозитариях интерфейсов 9.4.1. Пример отображения информации из IR на C++ 9.4.2. Пример отображения информации из IR на Java 9.5. Занесение информации в репозитарии интерфейсов 9.6. Доступ к требуемому репозитарию интерфейсов 9.6.1. Присоединение к репозитарию интерфейсов 9.6.2. Получение информации об интерфейсах по объектной ссылке

Глава 10. Репозитарии реализаций

10.1. Установка связи с серверным объектом по объектной ссылке 10.1.1. Прямая привязка 10.1.2. Косвенная привязка 10.2. Информация в репозитарии реализаций 10.3. Взаимодействие серверов приложений и репозитариев реализаций 10.4. Последовательность действий при установке связи 10.5. VisiBroker OAD 10.6. Утилиты для взаимодействия с OAD 10.6.1. Регистрация объектов в OAD 10.6.2. Отмена регистрации объектов в OAD 10.6.3. Получение информации из OAD 10.7. IDL-объявления для OAD 10.8. Взаимодействие с OAD из программ 10.8.1. Использование C++ 10.8.2. Использование Java

Глава 11. Динамическое взаимодействие клиентов и серверов

11.1. Какая информация необходима для использования DII/DSI 11.2. Некоторые IDL-типы, используемые при работе с DII/DSI 11.2.1. NamedValue 11.2.2. NVList 11.2.3. Environment 11.2.4. Context 11.2.5. Интерфейс ExceptionList 11.3. DII 11.3.1. Объект CORBA::Request 11.3.2. Отображение Request на C++ 11.3.3. Отображение Request на Java 11.3.4. Создание объекта Request 11.3.5. Вызовы удаленных методов 11.4. DSI 11.4.1. Объект ServerRequest 11.4.2. Отображение ServerRequest на C++ 11.4.3. Отображение ServerRequest на Java 11.4.4. Тип серванта 11.4.5. PortableServer::DynamicImplementation 11.4.6. CORBA::DynamicImplementation

Глава 12. Smart аgents

12.1. Что такое smart agent 12.2. Взаимодействие smart agents, серверов и клиентов 12.2.1. Запуск smart agent 12.2.2. Взаимодействие smart agents друг с другом 12.2.3. Smart agents и серверные объекты 12.2.4. Smart agents и клиенты 12.2.5. Домены ORB 12.3. Настройка параметров при использовании smart agents 12.3.1. Параметры, влияющие на поведение smart agents 12.3.2. Способы настройки параметров 12.3.3. Взаимодействие в объединении локальных сетей 12.3.4. Использование multihomed-хостов 12.4. Утилиты osfind и VisiBroker Console 12.5. Распределение нагрузки между серверами 12.6. Обеспечение устойчивости к сбоям 12.7. Location Service 12.7.1. IDL для Location Service 12.7.2. Получение доступа к Location Service 12.7.3. Интерфейс Agent 12.7.4. Триггеры сервиса поиска

Глава 13. Cервисы именования CORBA

13.1. Концепция Naming Service 13.2. Основные понятия 13.2.1. Представление имен 13.2.2. Связанное имя 13.2.3. Контекст имен 13.2.4. Начальный контекст имен 13.2.5. Иерархия контекстов 13.2.6. Разрешение имени 13.3. Интерфейсы Naming Service 13.3.1. Интерфейс NamingContext 13.3.2. Интерфейс BindingIterator 13.4. Создание экземпляра службы именования 13.5. Соединение с экземпляром службы именования 13.6. Федерация служб именования 13.7. Расширения, предлагаемые INS 13.7.1. Представление имен 13.7.2. Кластеры 13.7.3. Сохранение состояния

Глава 14. Callback-вызовы, сервисы событий и уведомлений

14.1. Callback-объекты при использовании CORBA 14.2. Сервис событий CORBA 14.2.1. Недостатки сервиса событий 14.2.2. Основные положения 14.2.3. Канал событий 14.2.4. Модели взаимодействия сервиса событий 14.2.5. Основные этапы создания приложения 14.2.6. Модуль CosEventComm 14.2.7. Модуль CosEventChannelAdmin 14.2.8. Понятие о типизированных событиях 14.3. Сервис уведомлений CORBA 14.4. Сервис сообщений CORBA 14.4.1. AMI 14.4.2. TII 14.5. Заключение

Глава 15. Сервис жизненного цикла

15.1. Модуль CosLifeCycle 15.1.1. "Фабрика" как формальная конструкция 15.1.2. Используемые IDL-типы 15.1.3. Интерфейс GenericFactory 15.1.4. Интерфейс FactoryFinder 15.1.5. Интерфейс LifeCycleObject 15.2. Модуль CosCompoundLifeCycle 15.3. Проблемы использования сервиса 15.4. Уничтожение CORBA-объектов 15.4.1. Основные положения 15.4.2. Уничтожение при явной активизации объектов 15.4.3. Уничтожение при использовании серванта по умолчанию 15.4.4. Уничтожение при использовании менеджера-активатора 15.4.5. Уничтожение при использовании менеджера-локатора 15.5. Заключение Часть III. Создание простых приложений

Глава 16. Создание простейшего клиента и сервера

16.1. Общие замечания 16.2. Использование C++ 16.2.1. Сервер 16.2.2. Клиент 16.3. Использование Java 16.3.1. Сервер 16.3.2. Клиент 16.4. Использование Delphi 16.4.1. Клиент 16.5. Заключение

Глава 17. Работа с POA

17.1. Общие замечания по примерам программ 17.2. Использование C++ 17.2.1. Явная активизация объекта 17.2.2. Явная активизация объекта с использованием счетчика ссылок 17.2.3. Использование менеджера-активатора 17.2.4. Использование менеджера-локатора 17.2.5. Использование серванта по умолчанию 17.2.6. Активизация объектного адаптера 17.2.7. Клиент 17.3. Использование Java 17.3.1. Явная активизация объекта 17.3.2. Использование менеджера-активатора 17.3.3. Использование менеджера-локатора 17.3.4. Использование серванта по умолчанию 17.3.5. Активизация объектного адаптера 17.3.6. Клиент 17.4. Заключение

Глава 18. Взаимодействие с репозитарием интерфейсов

18.1. Использование C++ 18.2. Использование Java 18.3. Результат работы

Глава 19. Использование DII/DSI

19.1. Использование C++ 19.1.1. Статический сервер 19.1.2. Статический клиент 19.1.3. DII-клиент 19.1.4. DSI-сервер 19.2. Использование Java 19.2.1. Статический сервер 19.2.2. Статический клиент 19.2.3. DII-клиент 19.2.4. DSI-сервер 19.3. Заключение

Глава 20. Использование сервиса именования CORBA

20.1. Задача и IDL-объявления серверного объекта 20.2. Запуск Naming Service 20.3. Серверное приложение 20.3.1. С++ 20.3.2. Java 20.3.3. Использование VisiBroker Console для создания графа имен 20.4. Клиентское приложение 20.4.1. С++ 20.4.2. Java 20.5. Заключение

Глава 21. Использование сервиса событий

21.1. Создание канала событий с помощью утилит VisiBroker 21.2. Создание канала событий с использованием интерфейса EventChannelFactory и классов VisiBroker 21.2.1. IDL-объявление интерфейса EventChannelFactory 21.2.2. Отображение интерфейса EventChannelFactory на С++ 21.2.3. Отображение интерфейса EventChannelFactory на Java 21.2.4. Создание объекта типа EventChannelFactory 21.3. Присоединение к каналу событий 21.4. Пример использования push-модели 21.4.1. Применение C++ 21.4.2. Применение Java 21.5. Заключение

Используемая литература

Алфавитный указатель

Рекомендуемые книги

Купить I am not Russia

I am not Russia

Антін Мухарський

345 грн
Купить Не верьте цифрам! Размышления о заблуждениях инвесторов, капитализме, «взаимных» фондах, индексном инвестировании, предпринимательстве, идеализме и ге

Не верьте цифрам! Размышления о заблуждениях инвесторов, капитализме, «взаимных» фондах, индексном инвестировании, предпринимательстве, идеализме и ге

Джон С. Богл

606 грн
Купить Після третього дзвінка вхід до зали забороняється

Після третього дзвінка вхід до зали забороняється

Оксана Забужко

195 грн
Купить Тафти жрица. Гуляние живьем в кинокартине

Тафти жрица. Гуляние живьем в кинокартине

Вадим Зеланд

450 грн
Купить Индия: 5000 лет истории

Индия: 5000 лет истории

Джон Кей

562 грн
Купить Это кто?

Это кто?

Полина Дзюба

19 грн
Купить Практическое пособие Ч.1 по высшей математике

Практическое пособие Ч.1 по высшей математике

Полозюк О.Е.

5 грн
Купить Выход из кризиса: Новая парадигма управления людьми, системами и процессами

Выход из кризиса: Новая парадигма управления людьми, системами и процессами

Эдвардс Деминг

475 грн
Купить Как заработать на YouTube для чайников

Как заработать на YouTube для чайников

Роб Чиампа, Тереза Мур, Джон Каруччи

450 грн
Купить Ноутбук без страха для начинающих. Самый наглядный самоучитель

Ноутбук без страха для начинающих. Самый наглядный самоучитель

Миронов Дмитрий

191 грн
Купить Любит - Не любит: выбираю счастье

Любит - Не любит: выбираю счастье

Елена Рыхальская

180 грн
Купить Финансовая отчетность для руководителей и начинающих специалистов

Финансовая отчетность для руководителей и начинающих специалистов

Алексей Герасименко

530 грн
Купить Прямой и интерактивный маркетинг

Прямой и интерактивный маркетинг

Мерлин Стоун, Элисон Бонд

32 грн
Купить Прикладное машинное обучение с помощью Scikit-Learn и TensorFlow: концепции, инструменты и техники для создания интеллектуальных систем

Прикладное машинное обучение с помощью Scikit-Learn и TensorFlow: концепции, инструменты и техники для создания интеллектуальных систем

Орельен Жерон

990 грн
Купить Пірати Котячого моря. Спіймати легенду

Пірати Котячого моря. Спіймати легенду

Аня Амасова, Виктор Запаренко

190 грн
Купить Солом’яний  бичок. Серія Оченята

Солом’яний бичок. Серія Оченята

45 грн
Купить Дмитро Дубілет. Бізнес на здоровому глузді

Дмитро Дубілет. Бізнес на здоровому глузді

Тимур Ворона

265 грн
Купить Як стати успішним ілюстратором

Як стати успішним ілюстратором

Дерек Бразелл, Джо Девіс

500 грн
Купить Барви твого життя. Розмальовка для медитації (цитати Ошо, малюнки)

Барви твого життя. Розмальовка для медитації (цитати Ошо, малюнки)

Ошо Багван Шри Раджниш

130 грн
Купить Коробка-сумочка, бордовая, большая 27х20х9 см (подарочная)

Коробка-сумочка, бордовая, большая 27х20х9 см (подарочная)

108 грн
Купить Основы маркетинга

Основы маркетинга

Филип Котлер, Гари Армстронг, Вероника Вонг, Джон Сондерс

900 грн
Купить Людина, яка хакнула ринок. Як Джим Саймонс розпочав квантову революцію

Людина, яка хакнула ринок. Як Джим Саймонс розпочав квантову революцію

Ґреґорі Зукерман

285 грн
Купить Врятуй мене

Врятуй мене

Мона Кастен

220 грн
Купить Microsoft Windows 8.1. Справочник администратора

Microsoft Windows 8.1. Справочник администратора

Уильям Р. Станек

181 грн
Купить Тайна моего мужа

Тайна моего мужа

Лиана Мориарти

170 грн
Купить Брехуни на кушетці

Брехуни на кушетці

Ирвин Ялом

160 грн
Купить Прикосновение

Прикосновение

Дэниел Киз

250 грн
Купить Я — дневник

Я — дневник

Ира Негован

270 грн
Купить Полиция. Серия об инспекторе полиции Харри Холе. Книга 10

Полиция. Серия об инспекторе полиции Харри Холе. Книга 10

Ю Несбё

88 грн
Купить Сверхчувствительные люди. От трудностей к преимуществам

Сверхчувствительные люди. От трудностей к преимуществам

Тед Зефф

385 грн
Купить Граматика англійської мови

Граматика англійської мови

Валерій Федоров

52 грн
Купить Добрые феи. Супернаклейки

Добрые феи. Супернаклейки

155 грн
Купить #В постели с твоим мужем. Записки любовницы. Женам читать обязательно!

#В постели с твоим мужем. Записки любовницы. Женам читать обязательно!

Ника Набокова

179 грн
Купить Мужской клуб без соплей. Книга, которую мудрые жены дарят мужьям

Мужской клуб без соплей. Книга, которую мудрые жены дарят мужьям

Сатья Дас

240 грн
Купить The Catсher in the Rye / Над пропастью во ржи.  Адаптированная книга для чтения на англ. языке. Pre-Intermediate

The Catсher in the Rye / Над пропастью во ржи. Адаптированная книга для чтения на англ. языке. Pre-Intermediate

Jerome Salinger

115 грн
Купить Як подолати кризу управління

Як подолати кризу управління

Іцхак Адізес

260 грн
Купить На запах м’яса

На запах м’яса

Люко Дашвар

120 грн
Купить Англійська граматика в таблицях

Англійська граматика в таблицях

Оксана Кузнєцова

36 грн
Купить Вчимося розмовляти

Вчимося розмовляти

Вікторія Юрченко

19 грн
Купить Цветы. Естественная история

Цветы. Естественная история

Бруно П. Кремер

450 грн

Книги из категории "Кулинария"

Купить Маркировка алкогольной продукции (Вып.4)

Маркировка алкогольной продукции (Вып.4)

54 грн
27 грн
Купить Чистый виски. Настольный путеводитель

Чистый виски. Настольный путеводитель

Сирил Маль, Александр Вентье

570 грн
Купить Пісні страви української кухні

Пісні страви української кухні

Леся Кравецька

150 грн
Купить Зваблення їжею: 70 рецептів, які захочеться готувати

Зваблення їжею: 70 рецептів, які захочеться готувати

Євген Клопотенко

345 грн
Купить Красное и белое. Неутолимая жажда вина

Красное и белое. Неутолимая жажда вина

Оз Кларк

610 грн
Купить Еда как есть

Еда как есть

Виктория Мельник

440 грн
Купить Wine Folly. Вино. Практический путеводитель

Wine Folly. Вино. Практический путеводитель

Мадлен Пакетт, Джастин Хэммек

295 грн
Купить Зі Сходу — до столу!

Зі Сходу — до столу!

Зарема Хаджієва

400 грн
Купить Книга о хлебе №1. Основы и рецепты правильного домашнего хлеба

Книга о хлебе №1. Основы и рецепты правильного домашнего хлеба

Лутц Гайслер

700 грн
Купить Паста как искусство. Рецепты радужной лапши для настоящих ценителей

Паста как искусство. Рецепты радужной лапши для настоящих ценителей

Линда Миллер Николсон

480 грн
Купить Готовим в мультиварке. 150 простых и полезных рецептов

Готовим в мультиварке. 150 простых и полезных рецептов

Ирина Горчакова

100 грн
Купить История вина в 100 бутылках. От Бахуса до Бордо и дальше

История вина в 100 бутылках. От Бахуса до Бордо и дальше

Оз Кларк

520 грн
Купить Чизкейк внутри. Книга вторая

Чизкейк внутри. Книга вторая

Виктория Мельник

305 грн
Купить Истории про еду с рисунками и рецептами автора

Истории про еду с рисунками и рецептами автора

Андрей Бильжо

330 грн
165 грн
Купить Курс идеальной еды. Рецепты для активной жизни

Курс идеальной еды. Рецепты для активной жизни

Гордон Рамзи

570 грн
Купить Кулинарная книга моей бабушки

Кулинарная книга моей бабушки

Оксана Путан

300 грн
Купить Итальянская кухня

Итальянская кухня

130 грн
Купить Мечта гурмана. Париж. Гастрономические искушения города любви

Мечта гурмана. Париж. Гастрономические искушения города любви

Клотильда Дюсулье

500 грн
Купить Легко и вкусно. Необычное сочетание обычных продуктов

Легко и вкусно. Необычное сочетание обычных продуктов

Елена Ермоленко

350 грн
Купить Бургеры, а еще хот-доги и бейглы (хюгге-формат)

Бургеры, а еще хот-доги и бейглы (хюгге-формат)

Валери Друэ, Пьер-Луи Вьель

170 грн

Цитаты пользователей

Всего цитат
0

Только зарегистрированные пользователи могут оставлять комментарии. Войдите, пожалуйста.

Отзывы

Отзывы
0 рецензий

Только зарегистрированные пользователи могут оставлять комментарии. Войдите, пожалуйста.
Все права защищены © 2003-2021 Bookzone.com.ua              Условия использования | Политика конфиденциальности
Интеграция сайта с 1С: ©SUPC