Навигация
Главная
Поиск
Форум
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
Эмулятор микроп... 65535
Подключение Mic... 65535
Создание потоко... 65535
Приложение «Про... 65535
Оператор выбора... 65535
Создание отчето... 65383
Модуль Forms 65160
Пример работы с... 64247
ТЕХНОЛОГИИ ДОСТ... 61804
Имитационное мо... 57719
Реклама
Сейчас на сайте
Гостей: 10
На сайте нет зарегистрированных пользователей

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

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

Реклама



Подписывайся на 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 Комментариев · 1534 Прочтений · Для печати

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


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



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

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

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

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

Пароль



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

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

Случайные загрузки
THttpScan v4.1
Профессиональное ...
C++ Builder 6 СПР...
Создание меню на ...
Карта сайта
Панель Наша Кнопка
PHP 5. Полное рук...
BDEPack
FilesInfo
Обучение Borland ...
PHP/MySQL для нач...
Strawberry Prolog...
SearchAndReplace
CodeGear RAD Stud...
Domen Name IP
Cooltray
Отключение и вклю...
Конвертирование и...
Прграммирование в...
mp3tag

Топ загрузок
Приложение Клие... 100468
Delphi 7 Enterp... 87024
Converter AMR<-... 20078
GPSS World Stud... 12793
Borland C++Buil... 11819
Borland Delphi ... 8600
Turbo Pascal fo... 7039
Visual Studio 2... 4999
Калькулятор [Ис... 4795
FreeSMS v1.3.1 3542
Случайные статьи
Почему уходит так ...
Вулкан 777
Большинство соврем...
Силовой модуль PW70
Топологические фигуры
Этап идентификации
Глава 22. Роли ...
Приведение типов
Динамические масси...
Методы класса TStr...
Бинарные операторы
Блоки
Система SVR4/MP и ...
Пользовательский п...
Символьный (литерн...
Поиск элемента
Фольклор
Режим “Спорт” и вс...
Variable Identifie...
ЯЧЕЙКИ В GPSS
Хранение записей о...
АНТИПАТТЕРН: ЗАПОЛ...
Организация взаимо...
Модемы стандарта V.90
План книги
Статистика



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


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