С++ - язык, который изучается постепенно.ГЛАВА 15. Алгоритм Бейкера: уход и кормление в C++

Недорогой но высококачественный сайт. Такое может быть? Да. У нас может быть всё. Достойное качество по доступной цене.
С точки зрения нашей студии создание сайта недорого значит, прежде всего, отменно, технологично и потом уже - недорого.
Удаленная форма работы с клиентами оптимизирует наши расходы и мы можем делать сайты по всему миру. Вам совсем не нужно приезжать к нам. Мы сэкономим Ваше время и средства.

В столь непростое время глобального финансового кризиса, когда отмирают старые схемы бизнеса, появляются новые. Самое лучше время для начала своей деятельности. Вы начинаете свой бизнес, а я помогу создать вам свой сайт очень недорого, для вас.
Огромной популярностью пользуются так называемые сайты-визитки.
Создание сайта-визитки - это совсем недорого, и будет по карману даже начинающему предпринимателю. При разработке подобного сайта достаточно небольшого бюджета.


По последним данным, на рынке продается по крайней мере 2 768 942 книги о С++, не говоря уже о всевозможных курсах, обучающих программах, журналах и семинарах с коктейлями. И все же в этом изобилии наблюдается удручающее однообразие. Просматривать полку книг о С++ в книжном магазине ничуть не интереснее, чем литературу по бухгалтерии. В сущности, все книги пересказывают одно и то же и отличаются разве что по весу и количеству цветов в диаграммах и таблицах.На сегодняшний день язык Си и языки основанные на синтаксисе Си (например, C++, Java, C#) наиболее популярны в практическом программировании. Язык Си имеет массу достоинств, он прост в изучении и лаконичен. Элементы языка Си (массивы, функции, указатели) максимально приближены к архитектуре компьютеров. Студия Web-дизайна, создание, раскрутка сайта

                    



Материалы книги получены с http://www.itlibitum.ru/

Алгоритм Бейкера: уход и кормление в C++

Практическое использование описанных выше алгоритмов требует нескольких жестких ограничений. Алгоритм Бейкера для объектов С++ напоминает котенка, которого ваш ребенок приносит в дом и клянется «всегда-всегда» кормить и заботиться. Другими словами, все совершенно искренне клянутся соблюдать правила, а вам лучше надевать передник и идти за тряпкой.

Очереди операций и указатель this

Если на момент вызова Copy1() существует указатель this, то объект, на который он ссылается, может переместиться из одной половины в другую. При этом this будет радостно ссылаться на старую копию. Мы позаботились обо всех остальных стековых переменных и превратили их в дескрипторы. Теперь, чтобы получить доступ к объекту, им приходится разворачиваться на 180. и действовать через ведущий указатель. Возможно, силовое решение, которое работает, хотя и ненамного лучше - потребовать, чтобы функция Copy1() всегда вызывалась в самом конце функций класса:

class Foo {

public:

void Fn()

{

// Код, который делает нечто осмысленное

VoidPtr::pool->Copy1();

}

};

Разумеется, все будет нормально лишь в том случае, если объект вызывавший Fn(), ну будет

использовать свой указатель this после возвращения из Fn(). Не знаю, как вы, а лично я предпочитаю спать спокойно и не думать о том, как один из 2435 программистов, работающих с моей библиотекой классов, придумает способ все испортить.

Более достойное решение - сделать так, чтобы функция Copy1() вызывалась из некоторого цикла событий верхнего уровня. На самом деле нежелательно, чтобы в момент вызова Copy1() функции исчезающих объектов находились в стеке. В результате получается архитектура, которую я называю опосредованной (inside-out), - функция класса не выполняет работу сама, а создает объект-операцию (operational object) и направляет его в некоторую главную очередь. Это распространенное решение встречается во многих библиотеках классов.

class Operation {

friend void MainLoop();

private:

static Queue<Operation> OperationQ;

public:

virtual void DoSomething() = 0;

void Post() { OperationQ.Push(this); }

};

void MainLoop()

{

Operation* op;

while ((op = Operation::OperationQ.Pop()) != NULL)

{

op->DoSomething();

object_space->Copy1();

}

}

Если теперь объект захочет выполнить какое-нибудь действие, он не выполняет его сам, а создает класс, производный от Operation, и заносит его в очередь. Если обработка связана с итерациями, объект Operation продолжает направлять себя в очередь в конце каждого вызова DoSomething() до завершения итераций. Приведу краткий набросок традиционного подхода и опосредованной архитектуры:

// Традиционный способ сделать что-то

void Foo::SomeOperation()

{

for (...)

OnePass();

}

Если операция занимает много времени, перед вами возникают два неудобных варианта: не выполнять сборку мусора и уплотнение до завершения Foo::SomeOperation(), а следовательно, утратить многие преимущества от управления памятью; или косвенно вызвать Copy1() во время вызова Foo::SomeOperation(), а это небезопасно. Очередь операций предоставляет другое решение проблемы:

// Опосредованная архитектура с очередями операций

class FooSomeOperation : public Operation }

public:

virtual void DoSomething();

{

// Выполнить один проход

if (еще не готово)

this->Post(); // Послать заново для следующего захода

delete this;

}

};

void Foo::SomeOperation()

{

Operation* op = new FooSomeOperation(args);

op->Post();

// op->DoSomething выполняет работу

}

Теперь функция Copy1() заведомо не будет вызвана в момент нахождения в стеке FooSomeOperation::DoSomething(). Подобные очереди операций так часто приносят пользу, что

являются едва ли не стандартной возможностью объектно-ориентированных библиотек классов. Сколько библиотек - столько и вариаций (скажем, назначение приоритетов операций или возможность блокирования одних операций до завершения других), но во всех разновидностях встречается одна общая черта - максимальное освобождение стека на время периодического выполнения вспомогательных операций.

Адреса переменных класса

Аналогичная проблема возникает и при получении адреса переменной класса, даже если это

происходит в функциях класса, которым мы управляем. Именно по этой причине мы и потребовали, чтобы везде применялись дескрипторы. Благодаря опосредованной методике проблем не возникает - при условии, что вы получаете адрес переменной класса,  используете и забываете про него в течение одного цикла. Впрочем, от хлопот, связанных с опосредованной архитектурой, можно и отказаться.

Если вы абсолютно уверены, что адрес не сохранится до следующего вызова функции Copy1(), то можете избирательно снимать требование обязательного применения дескрипторов.

Множественное наследование

Множественное наследование безопасно при условии соблюдения всех приведенных выше

рекомендаций по уходу и кормлению указателя this. То обстоятельство, что this пляшет в памяти при вызове функций второго и третьего базового класса, не вызовет новых проблем - это все та же проблема с this, только замаскированная. Конечно, вы никогда не должны возвращать адрес объекта, преобразованного к базовому классу, но передача this тоже небезопасна.

Неустойчивые объекты

Объекты, адреса которых (в отличие от адресов их ведущих указателей) передаются за пределы вашей зоны контроля - скажем, при вызове системной функции - необходимо сначала вывести из очищаемого пространства. Самое простое решение - создать объект-операцию, которая перемещает свой объект и вызывает системную функцию, когда оказывается в новом безопасном месте.


Назад    Содержание    Далее    

   Почти всегда целью создания сайта является получение прибыли, которая в свою очередь, зависит от его внешнего вида. Статистика говорит, что около 94% людей, при выборе товара, сначала обращают внимание на упаковку, а потом уже на её содержимое. И если эта упаковка не привлекательная и безвкусная, мало кто обратит на нее внимание, и, соответственно, товар не будет пользоваться спросом.
   В случае с интернет, “упаковкой” выступает ваш сайт, а “товаром” - его контент. Если сайт выглядит непривлекательно, то каким бы ценным и нужным не было его содержимое, люди будут обходить его стороной. Наша задача - сделать ваш сайт привлекательным и удобным, чтобы люди чувствовали себя уютно и комфортно, чтоб они возвращались к вам еще и еще. Соответствие между ценой и качеством вас, несомненно, порадуют.
.
   Мы делаем сайты для бизнеса, а не красочную картинку, которая увешена тяжеловесными флэшами и огромными фотографиями.
   Пользователя, когда он попадает на абсолютно любой сайт, прежде всего интересует информация, затем, как реализовать на этом сайте полученную информацию, чтобы было удобно и просто (юзабилити), подбор цветовой гаммы, расположение блоков на странице и многое другое.

   Перед тем, как заказывать создание сайта, рекомендуем прочесть статью А зачем мне (нам) сайт? или Что нужно знать заказчику сайта
Да и вообще, обратите внимание на раздел Статьи о продвижении сайта и бизнеса там вы найдёте ответы на многие вопросы.