Навигация
Главная
Поиск
Форум
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
Создание отчето... 65461
Модуль Forms 65220
Пример работы с... 64726
ТЕХНОЛОГИИ ДОСТ... 61914
Имитационное мо... 57793
Реклама
Сейчас на сайте
Гостей: 5
На сайте нет зарегистрированных пользователей

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

Моделирование процесса поступления заявок в систему, состоящую из трёх Э...
Моделирование интернет магазина (Apache, Php, Html) на GPSS + Блок схема
Сравнение двух бинарных деревьев на Turbo Pascal + отчет

Реклама



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

ПОДПИСЫВАЙСЯ на канал о программировании
Язык С и С ++: доступ к членам класса
Открытый член класса доступен для пользователей; закрытый член класса доступен только членам класса.
class Date { public:
// . . . int next_day(); private:
int y, m, d;
};
void Date::next_day() { return d+1; } // OK void f(Date d)
{
int nd = d.d+1; // ошибка: Date::d — закрытый член класса // . . .
}
Структура — это класс, члены которого по умолчанию являются открытыми. struct S {
// члены (открытые, если явно не объявлены закрытыми)
};


К членам объекта можно обращаться с помощью оператора . (точка), примененного к его имени, или оператора -> (стрелка), примененного к указателю на него. struct Date {
int d, m, y;
int day() const { return d; } // определенный в классе int month() const; // просто объявленный; определен
Также вам может показаться, что такая тема как

http://ashaindia.ru/indiyskie-specii/specii-i-travy-razvesnye/muskatnyy-oreh-molotyy-100g
никак не связана и даже не тематична с темой этого сайта. Хотя, может быть и связана.
В любом случае все-таки зайдите на сайт ashaindia.ru
Тема мускатный орех купить там представлена весьма широко.


// в другом месте int year() const; // просто объявленный; определен
// в другом месте
};
Date x;
x.d = 15; // доступ через переменную
int y = x.day(); // вызов через переменную
Date* p = &x;
p->m = 7; // доступ через указатель
int z = p->month(); // вызов через указатель
На члены класса можно ссылаться с помощью оператора :: (разрешение области видимости).
int Date::year() const { return y; } // определение за пределами
// класса
В функциях-членах класса можно ссылаться на другие члены класса, не указывая имя класса.
struct Date {
int d, m, y;
int day() const { return d; }
// . . .
};
Такие имена относятся к объекту, из которого вызвана функция: void f(Date d1, Date d2)
{
d1.day(); // обращается к члену d1.d d2.day(); // обращается к члену d2.d // . . .
}
Указатель this
Если хотите явно сослаться на объект, из которого вызвана функция-член, то можете использовать зарезервированный указатель this.
A. 12. КЛАССЫ
1117
struct Date {
int d, m, y;
int month() const { return this->m; }
// . . .
};
Функция-член, объявленная с помощью спецификатора const (константная функция-член), не может изменять значение члена объекта, из которого она вызвана.
struct Date {
int d, m, y;
int month() const { ++m; } // ошибка: month() — константная
// функция
// . . .
};
Друзья
Функция, не являющаяся членом класса, может получить доступ ко всем членам- класса, если ее объявить с помощью ключевого слова friend. Рассмотрим пример.
// требует доступа к членам классов Matrix и Vector members:
Vector operator*(const Matrix&, const Vector&);
class Vector { friend
Vector operator*(const Matrix&, const Vector&); // есть доступ // . . .
};
class Matrix { friend
Vector operator*(const Matrix&, const Vector&); // есть доступ // . . .
};
Как показано выше, обычно это относится к функциям, которым нужен доступ к двум классам. Другое предназначение ключевого слова friend — обеспечивать функцию доступа, которую нельзя вызывать как функцию-член.
class Iter { public:
int distance_to(const iter& a) const;
friend int difference(const Iter& a, const Iter& b);
// . . .
};
void f(Iter& p, Iter& q)
{
int x = p.distance_to(q); // вызов функции-члена
1118
ПРИЛОЖЕНИЕ A • КРАТКИЙ ОБЗОР ЯЗЫКА
int y = difference(p,q); // вызов с помощью математического
// синтаксиса
// . . .
}
Отметим, что функцию, объявленную с помощью ключевого слова friend, нельзя объявлять виртуальной.
A.12.2. Определения членов класса
Члены класса, являющиеся целочисленными константами, функциями или типами, могут быть определены как в классе, так и вне его. struct S {
static const int c = 1; static const int c2;
void f() { } void f2();
struct SS { int a; }; struct SS2;
};
Члены, которые не были определены в классе, должны быть определены “где-то”.
const int S::c2 = 7; void S::f2() { } struct S::SS2 { int m; };
Статические константные целочисленные члены класса (static const int) представляют собой особый случай. Они просто определяют символические целочисленные константы и не находятся в памяти, занимаемой объектом. Нестатические данные-члены не требуют отдельного определения, не могут быть определены отдельно и инициализироваться в классе.
struct X { int x;
int y = 7; // ошибка: нестатические данные-члены
// не могут инициализироваться внутри класса static int z = 7; // ошибка: данные-члены, не являющиеся
// константами, не могут инициализироваться // внутри класса static const string ae = "7"; // ошибка: нецелочисленный тип
// нельзя инициализировать // внутри класса static const int oe = 7; // OK: статический константный
// целочисленный тип
};
int X::x = 7; // ошибка: нестатические члены класса нельзя // определять вне класса
Если вам необходимо инициализировать не статические и не константные данные-члены, используйте конструкторы.
Функции-члены не занимают память, выделенную для объекта.
struct S { int m; void f();
};

Здесь sizeof(S)==sizeof(int). На самом деле стандартом это условие не регламентировано, но во всех известных реализациях языка оно выполняется. Следует подчеркнуть, что класс с виртуальной функцией имеет один скрытый член, обеспечивающий виртуальные вызовы.
Опубликовал katy May 03 2015 15:01:37 · 0 Комментариев · 1448 Прочтений · Для печати

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


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



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

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

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

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

Пароль



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

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

Случайные загрузки
Proeffectimage
Просмотр коммент...
Программирование ...
Создание лабиринт...
SysInfo [Исходник...
Delphi Russian Kn...
Tank [Исходник на...
Sztransppanel
Система баннеро...
OnlineIP
Cooltray
DCAVI
BSButton
DirHTMLReportBuil...
Pass [Исходник на...
Illusion
Программа для рис...
Самоучитель PHP 5...
Удаление своего EXE
Импорт новостей ...

Топ загрузок
Приложение Клие... 100470
Delphi 7 Enterp... 87103
Converter AMR<-... 20078
GPSS World Stud... 12859
Borland C++Buil... 11848
Borland Delphi ... 8604
Turbo Pascal fo... 7039
Visual Studio 2... 4999
Калькулятор [Ис... 4804
FreeSMS v1.3.1 3542
Случайные статьи
Необходимые компле...
Казино Вулкан приг...
Пошаговое выполнен...
Разделение списка
Батуты в СПб попры...
Тянем-потянем за с...
Первое знакомство
Линейное рехеширов...
Исходные положения...
Поле CIST INTERNAL...
Где купить укрывно...
Множественное насл...
— порядок применен...
ПРИЛОЖЕНИЕ 2. Осно...
Инвертирование мас...
13.2. Линейные стр...
Структура интерфей...
Завершение установ...
Выделение трех объ...
Implementation exp...
Обеспечение обратн...
Освоение приложени...
Вскрытие корпуса
5. КОС отсылает эт...
Состояния потока
Статистика



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


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