Д. Стефенс - C++. Сборник рецептов

Здесь есть возможность читать онлайн «Д. Стефенс - C++. Сборник рецептов» весь текст электронной книги совершенно бесплатно (целиком полную версию без сокращений). В некоторых случаях можно слушать аудио, скачать через торрент в формате fb2 и присутствует краткое содержание. Город: Москва, Год выпуска: 2007, ISBN: 2007, Издательство: КУДИЦ-ПРЕСС, Жанр: Программирование, на русском языке. Описание произведения, (предисловие) а так же отзывы посетителей доступны на портале библиотеки ЛибКат.

C++. Сборник рецептов: краткое содержание, описание и аннотация

Предлагаем к чтению аннотацию, описание, краткое содержание или предисловие (зависит от того, что написал сам автор книги «C++. Сборник рецептов»). Если вы не нашли необходимую информацию о книге — напишите в комментариях, мы постараемся отыскать её.

Данная книга написана экспертами по C++ и содержит готовые рецепты решения каждодневных задач для программистов на С++. Один из авторов является создателем библиотеки Boost Iostreams и нескольких других библиотек C++ с открытым исходным кодом. В книге затрагивается множество тем, вот лишь некоторые из них: работа с датой и временем; потоковый ввод/вывод; обработка исключений; работа с классами и объектами; сборка приложений; синтаксический анализ XML-документов; программирование математических задач. Читатель сможет использовать готовые решения, а сэкономленное время и усилия направить на решение конкретных задач.

C++. Сборник рецептов — читать онлайн бесплатно полную книгу (весь текст) целиком

Ниже представлен текст книги, разбитый по страницам. Система сохранения места последней прочитанной страницы, позволяет с удобством читать онлайн бесплатно книгу «C++. Сборник рецептов», без необходимости каждый раз заново искать на чём Вы остановились. Поставьте закладку, и сможете в любой момент перейти на страницу, на которой закончили чтение.

Тёмная тема
Сбросить

Интервал:

Закладка:

Сделать

//

// (iii) Делегировать основную работу методу

// startAnimalChild()

if (!parsingAnimalList_) {

// Мы только что встретили корень документа

if (localname == animalList) {

parsingAnimalList_ = true; // Обновить состояние анализа.

} else {

// Неправильная вложенность

throw runtime_error(

string("expected 'animalList', got ") + toNative(localname)

);

}

} else if (!parsingAnimal_) {

// Мы только что встретили новое животное

if (localname == animal) {

parsingAnimal_ = true; // Обновить состояние

// анализа.

animalList_.push_back(Animal()); // Добавить в список объект

// Animal.

} else {

// Неправильная вложенность

throw runtime error(

string("expected 'animal', got ") + toNative(localname)

);

}

} else {

// Вы находимся в середине анализа элемента, описывающего

// животного.

if (parsingAnimalChild_) {

// Неправильная вложенность

throw runtime_error("bad animal element");

}

// Обновить состояние анализа

parsingAnimalChild_ = true;

// Пусть startAnimalChild() выполнит реальную работу

startAnimalChild(uri, localname, qname, attrs);

}

}

void endElement(

const XMLCh *const uri, // uri пространства имен

const XMLCh *const localname, // простое имя тега

const XMLCh *const qname ) // квалифицированное имя тега

{

static XercesString animalList = fromNative("animal-list");

static XercesString animal = fromNative("animal");

// Обновить флаги parsingAnimalList, parsingAnimal_

// и parsingAnimalChild_; делегировать основную работу

// endAnimalChild()

if (localname == animal) {

parsingAnimal_ = false;

} else if (localname == animalList) {

parsingAnimalList_ = false;

} else {

endAnimalChild(uri, localname, qname);

parsingAnimalChild_ = false;

}

}

// Получает уведомления о встрече символьных данных

void characters(const XMLCh* const chars, const unsigned int length) {

// Добавляет символы в конец currentText_ для обработки методом

// endAnimalChild()

currentText.append(chars, length);

}

private:

// Если текущий элемент представляет ветеринара или дрессировщика,

// используйте attrs для конструирования объекта Contact для

// текущего Animal; в противном случае очистите currentText_,

// подготавливая обратный вызов characters()

void startAnimalChild(

const XMLCh *const uri, // uri пространства имен

const XMLCh *const localname, // простое имя тега

const XMLCh *const qname, // квалифицированное имя тега

const Attributes &attrs ) // Набор атрибутов

{

static XercesString vet = fromNative("veterinarian");

static XercesString trainer = fromNative("trainer");

Animal& animal = animalList_.back();

if (localname == vet) {

// Мы встретили элемент "ветеринар".

animal.setVeterinarian(contactFromAttributes(attrs));

} else if (localname == trainer) {

// Мы встретили элемент "дрессировщик".

animal.setTrainer(contactFromAttributes(attrs));

} else {

// Мы встретили элемент "кличка , "вид" или

// "дата рождения". Его содержимое будет передано функцией

// обратного вызова characters().

currentText_.clear();

}

}

// Если текущий элемент представляет кличку, вид или дату рождения,

// используйте текст, находящийся в currentText_, для установки

// соответствующего свойства текущего объекта

Animal. void endAnimalChild(

const XMLCh *const uri, // uri пространства имен

const XMLCh *const localname, // простое имя тега

const XMLCh *const qname) // квалифицированное имя тега

{

static XercesString name = fromNative("name");

static XercesString species = fromNative("species");

static XercesString dob = fromNative("dateOfBirth");

// currentText_ содержит текст элемента, который только что

// закончился. Используйте его для установки свойств текущего

// объекта Animal.

Animal& animal = animalList_.back();

if (localname == name) {

animal.setName(toNative(currentText_));

} else if (localname == species) {

animal.setSpecies(toNative(currentText_));

} else if (localname == dob) {

animal.setDateOfBirth(toNative(currentText_));

}

}

vector& animalList_; // заполняемый список

bool parsingAnimalList_; // состояние анализа

bool parsingAnimal_; // состояние анализа

bool parsingAnimalChild_; // состояние анализа

XercesString currentText_; // символьные данные текущего

// текстового узла

};

Из сравнения примера 14.9 с примером 14.6 видно, насколько сложным может быть проверка структуры документа с помощью функций обратного вызова. Более того, в примере 14.6 не делается столько проверок, как в примере 14.3: здесь, например, не проверяется порядок следования дочерних элементов элемента животного. К счастью, существует гораздо более простой способ проверки структуры документа с использованием SАХ2, как вы это увидите в рецептах 14.5 и 14.6.

Читать дальше
Тёмная тема
Сбросить

Интервал:

Закладка:

Сделать

Похожие книги на «C++. Сборник рецептов»

Представляем Вашему вниманию похожие книги на «C++. Сборник рецептов» списком для выбора. Мы отобрали схожую по названию и смыслу литературу в надежде предоставить читателям больше вариантов отыскать новые, интересные, ещё непрочитанные произведения.


Отзывы о книге «C++. Сборник рецептов»

Обсуждение, отзывы о книге «C++. Сборник рецептов» и просто собственные мнения читателей. Оставьте ваши комментарии, напишите, что Вы думаете о произведении, его смысле или главных героях. Укажите что конкретно понравилось, а что нет, и почему Вы так считаете.