Навигация
Главная
Поиск
Форум
FAQ's
Ссылки
Карта сайта
Чат программистов

Статьи
-Delphi
-C/C++
-Turbo Pascal
-Assembler
-Java/JS
-PHP
-Perl
-DHTML
-Prolog
-GPSS
-Сайтостроительство
-CMS: PHP Fusion
-Инвестирование

Файлы
-Для программистов
-Компонеты для Delphi
-Исходники на Delphi
-Исходники на C/C++
-Книги по Delphi
-Книги по С/С++
-Книги по JAVA/JS
-Книги по Basic/VB/.NET
-Книги по PHP/MySQL
-Книги по Assembler
-PHP Fusion MOD'ы
-by Kest
Professional Download System
Реклама
Услуги

Автоматическое добавление статей на сайты на Wordpress, Joomla, DLE
Заказать продвижение сайта
Программа для рисования блок-схем
Инженерный калькулятор онлайн
Таблица сложения онлайн
Популярные статьи
OpenGL и Delphi... 65535
Форум на вашем ... 65535
HACK F.A.Q 65535
Бип из системно... 65535
Гостевая книга ... 65535
Invision Power ... 65535
Содержание сайт... 65535
Вызов хранимых ... 65535
Программируемая... 65535
Эмулятор микроп... 65535
Подключение Mic... 65535
Приложение «Про... 65535
Оператор выбора... 65535
Организация зап... 64600
Создание потоко... 61592
Модуль Forms 61229
Создание отчето... 61174
ТЕХНОЛОГИИ ДОСТ... 57621
Пример работы с... 55124
Имитационное мо... 53014
Реклама
Сейчас на сайте
Гостей: 8
На сайте нет зарегистрированных пользователей

Пользователей: 13,067
новичок: senata7
Новости
Реклама
Выполняем курсовые и лабораторные по разным языкам программирования
Подробнее - курсовые и лабораторные на заказ
Delphi, Turbo Pascal, Assembler, C, C++, C#, Visual Basic, Java, GPSS, Prolog, 3D MAX, Компас 3D
Заказать программу для Windows Mobile, Symbian

Расчет обратной матрицы на Delphi + Пояснительная записка
Метод половинного деления для нахождения корня уровнения на Turbo Pascal...
Моделирование интернет кафе на GPSS + Отчет

Реклама



Подписывайся на YouTube канал о программировании, что бы не пропустить новые видео!

ПОДПИСЫВАЙСЯ на канал о программировании
Добавление квалификаторов: работа с указателем
Теперь мы работаем с указателями, поэтому должны предусмотреть проверку нулевого показателя. Для того чтобы гарантировать, что функция better2() не модифицирует наш массив и векторы находятся под защитой контейнера Array_ref, мы добавили несколько квалификаторов const.


Также вам может показаться, что такая тема как http://www.alexanderpolyakov.ru/upravlenie-partnerskoj-programmoj/ никак не связана и даже не тематична с программированием. Хотя, может быть и связана.
В любом случае все-таки зайдите на сайт alexanderpolyakov.ru
Тема создание партнерской программы там представлена весьма широко. На том сайте можно узнать много интересного на тему создание партнерской программы
Что означает вообще тема создание партнерской программы, где найти тему создание партнерской программы - про это написано на сайте alexanderpolyakov.ru
Это очень важная для многих людей тема - посуда Спасибо сайту alexanderpolyakov.ru за информацию на тему создание партнерской программы

Первый квалификатор const гарантирует, что мы не применим к объекту класса Array_ref модифицирующие операции, такие как assign() и reset(). Второй квалификатор const размещен после звездочки (*). Это значит, что мы хотим иметь константный указатель (а не указатель на константы); иначе говоря, мы не хотим модифицировать указатели на элементы, даже если у нас есть операции, позволяющие это сделать.
Далее, мы должны устранить главную проблему: как выразить идею, что объект класса Array_ref можно конвертировать
• в нечто подобное объекту класса Array_ref (который можно использовать в функции better2());
• но только если объект класса Array_ref является неизменяемым. Это можно сделать, добавив в класс Array_ref оператор преобразования.
template class Array_ref { public:
// как прежде
template
operator const Array_ref()
{
// проверка неявного преобразования элементов: static_cast(*static_cast(0));
// приведение класса Array_ref:
return Array_ref(reinterpret_cast(p),sz);
}
// как прежде
};
Это похоже на головоломку, но все же перечислим ее основные моменты.
• Оператор приводит каждый тип Q к типу Array_ref, при условии, что мы можем преобразовать каждый элемент контейнера Array_ref в элемент контейнера Array_ref (мы не используем результат этого приведения, а только проверяем, что такое приведение возможно).


• Мы создаем новый объект класса Array_ref, используя метод решения “в лоб” (оператор reinterpret_cast), чтобы получить указатель на элемент желательного типа. Решения, полученные “в лоб”, часто слишком затратные; в данном случае никогда не следует использовать преобразование в класс Array_ref, используя множественное наследование.
• Обратите внимание на квалификатор const в выражении Array_ref : именно он гарантирует, что мы не можем копировать объект класса Array_ref в старый, допускающий изменения объект класса Array_ref.
Мы предупредили вас о том, что зашли на территорию экспертов и столкнулись с головоломкой. Однако эту версию класса Array_ref легко использовать (единственная сложность таится в его определении и реализации).
void f(Shape* q, vector& s0)
{
Polygon* s1[10];
Shape* s2[20];
// инициализация
Shape* p1 = new Rectangle(Point(0,0),10); better2(make_ref(s0)); // OK: преобразование
// в Array_ref better2(make_ref(s1)); // OK: преобразование
// в Array_ref better2(make_ref(s2)); // OK (преобразование не требуется)
better2(make_ref(p1,1)); // ошибка
better2(make_ref(q,max)); // ошибка
}
Опубликовал katy April 26 2015 11:46:10 · 0 Комментариев · 1267 Прочтений · Для печати

• Не нашли ответ на свой вопрос? Тогда задайте вопрос в комментариях или на форуме! •


Комментарии
Нет комментариев.
Добавить комментарий
Имя:



smiley smiley smiley smiley smiley smiley smiley smiley smiley
Запретить смайлики в комментариях

Введите проверочный код:* =
Рейтинги
Рейтинг доступен только для пользователей.

Пожалуйста, залогиньтесь или зарегистрируйтесь для голосования.

Нет данных для оценки.
Гость
Имя

Пароль



Вы не зарегистрированны?
Нажмите здесь для регистрации.

Забыли пароль?
Запросите новый здесь.
Поделиться ссылкой
Фолловь меня в Твиттере! • Смотрите канал о путешествияхКак приготовить мидии в тайланде?
Загрузки
Новые загрузки
iChat v.7.0 Final...
iComm v.6.1 - выв...
Visual Studio 200...
CodeGear RAD Stud...
Шаблон для новост...

Случайные загрузки
EditNew
Шейдеры в Delphi
Delphi Russian Kn...
Strawberry Prolog...
Ильдар Хабибуллин...
Turbo Pascal for ...
PHP/MySQL для нач...
Пишем программы и...
Архив программ
Упорядоченный дин...
Progressbar
Blib [Исходник на...
Панель поиска
Pass [Исходник на...
Простой пример ка...
Как программирова...
Мониторинг сервер...
Игра змейка
ProLIB18
С. Г. Горнаков - ...

Топ загрузок
Приложение Клие... 100384
Delphi 7 Enterp... 83515
Converter AMR<-... 20051
GPSS World Stud... 11297
Borland C++Buil... 11233
Borland Delphi ... 8175
Turbo Pascal fo... 6987
Visual Studio 2... 4970
Калькулятор [Ис... 4416
FreeSMS v1.3.1 3516
Случайные статьи
Игра в интернете -...
Методы класса
Множественное насл...
Форматирование объ...
ir.f /overwriteВне...
Гостевая книга на ...
Интернет-казино Ву...
Лотерея - доступны...
Совершенная красот...
Формирование запро...
В задаче строим сл...
Домашний театр на ...
Разработка инфогра...
Параметр DEFAULT (...
Оптимизация расход...
Простейшая среда
Да! При проектиров...
ВКонтакте, Однокла...
Сигналы в SVR4
Бесплатный «межгород»
Перевод между сист...
Таблица, свойства ...
Элемент ввода chec...
Обучение английско...
Локальные сети с ш...
Статистика



Друзья сайта
Программы, игры


Полезно
В какую объединенную сеть входит классовая сеть? Суммирование маршрутов Занимают ли таблицы память маршрутизатора?