Навигация
Главная
Поиск
Форум
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
21 ошибка прогр... 65535
HACK F.A.Q 65535
Бип из системно... 65535
Гостевая книга ... 65535
Invision Power ... 65535
Пример работы с... 65535
Содержание сайт... 65535
ТЕХНОЛОГИИ ДОСТ... 65535
Организация зап... 65535
Вызов хранимых ... 65535
Создание отчето... 65535
Имитационное мо... 65535
Программируемая... 65535
Эмулятор микроп... 65535
Подключение Mic... 65535
Создание потоко... 65535
Приложение «Про... 65535
Оператор выбора... 65535
Реклама
Сейчас на сайте
Гостей: 10
На сайте нет зарегистрированных пользователей

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

Моделирование круглосуточного интернет кафе на GPSS + Отчет
Движение шарика в эллиптическои параболоиде на Delphi [OpenGL] + Блок схемы
Моделирование ЭВМ на GPSS (три класса заданий) + Пояснительная записка

Язык С и С ++: функции
Функция (function) — это именованный фрагмент кода, получающий (возможно, пустой) набор аргументов и (необязательно) возвращающий значение. Функция объявляется с помощью указания типа возвращаемого значения, за которым следует ее имя и список параметров.
char f(string, int);

Также вам может показаться, что такая тема как

http://www.schungit.ru/auxpage_3
никак не связана и даже не тематична с программированием. Хотя, может быть и связана.
В любом случае все-таки зайдите на сайт schungit.ru
Тема шунгит купить в Москве там представлена весьма широко.


Итак, f — это функция, принимающая объекты типа string и int и возвращающая объект типа char. Если функция должна быть просто объявлена, но не определена, то ее объявление завершается точкой с запятой. Если функция должна быть определена, то за объявлением аргументов следует тело функции.
char f(string s, int i) { return s[i]; }
Телом функции должен быть блок или блок try. Функция, в объявлении которой указано, что она возвращает какое-то значение, должна его возвращать (используя оператор return).
char f(string s, int i) { char c = s[i]; } // ошибка: ничего
// не возвращается


Функция main() представляет собой странное исключение из этого правила. За исключением функции main(), если не хотите возвращать значение, то поставьте перед именем функции ключевое слово void. Другими словами, используйте слово void как тип возвращаемого значения.
void increment(int& x) { ++x; } // OK: возвращать значение
// не требуется


Функция вызывается с помощью оператора вызова () с соответствующим списком аргументов.
char x1 = f(1,2); // ошибка: первый аргумент функции f() должен // быть строкой string s = "Battle of Hastings";
char x2 = f(s); // ошибка: функция f() требует двух аргументов
char x3 = f(s,2); // OK
Разрешение перегрузки
Разрешение перегрузки (overload resolution) — это процесс выбора функции
для вызова на основе набора аргументов. Рассмотрим пример.
void print(int);
void print(double);
void print(const std::string&);
print(123); // вызывается print(int)
print(1.23); // вызывается print(double)
print("123"); // вызывается print(const string&)
Компилятор, руководствуясь правилами языка, может самостоятельно выбрать правильную функцию. К сожалению, эти правила довольно сложные, поскольку они пытаются учесть максимально сложные примеры. Здесь мы приведем их упрощенный вариант.
Выбор правильного варианта перегруженной функции осуществляется на основе поиска наилучшего соответствия между типами аргументов функции и типами ее параметров (формальных аргументов).
Для конкретизации нашего представления о выборе наилучшего соответствия сформулируем несколько критериев.
1. Точное совпадение, т. е. совпадение при полном отсутствии преобразований типов или при наличии только самых простых преобразований (например, преобразование имени массива в указатель, имени функции — в указатель на функцию и типа T — в тип const T).
2. Совпадение после продвижения, т.е. целочисленные продвижения (bool — в int, char — в int, short — в int и их аналоги без знака;, а также преобразование типа float в double.
3. Совпадение после стандартных преобразований, например, int — в double, double — в int, double — в long double, Derived* — в Base*, T* — в void*, int — в unsigned int.
4. Совпадение после преобразований, определенных пользователем.
5. Совпадение на основе эллипсиса ... в объявлении функции.
Если найдено два совпадения, то вызов отменяется как неоднозначный. Правила
разрешения перегрузки ориентированы в основном на встроенные числовые типы.
Для разрешения перегрузки на основе нескольких аргументов мы сначала должны найти наилучшее совпадение для каждого аргумента. Выбирается та из функций, которая по каждому аргументу подходит так же хорошо, как и остальные функции, но лучше всех остальных соответствует вызову по одному из аргументов; в противном случае вызов считается неоднозначным. Рассмотрим пример.
void f(int, const string&, double); void f(int, const char*, int);
f(1,"helloM,1); // OK: call f(int, const char*, int)
f(1,string(Mhello"),1.0); // OK: call f(int, const string&, double) f(1, "hello",1.0); // ошибка: неоднозначность
В последнем вызове строка "hello" соответствует типу const char* без преобразования, а типу const string& — только после преобразования. С другой стороны, число 1.0 соответствует типу double без преобразования, а число типа int — только после преобразования, поэтому ни один из вариантов функции f() не соответствует правилам лучше других.
Если эти упрощенные правила не соответствуют правилам вашего компилятора и вашим представлениям, в первую очередь следует предположить, что ваша программа сложнее, чем требуется. Постарайтесь упростить код, в противном случае проконсультируйтесь с экспертами.
Аргументы по умолчанию
Иногда функции имеют больше аргументов, чем это требуется в наиболее часто встречающихся распространенных ситуациях. Для того чтобы учесть это обстоятельство, программист может предусмотреть аргументы по умолчанию, которые будут использоваться, если при вызове соответствующие аргументы не будут заданы. Рассмотрим пример.
void f(int, int=0, int=0); f(1,2,3);
f(1,2); // вызовы f(1,2,0) f(1); // вызовы f(1,0,0)
Задавать по умолчанию можно только замыкающие аргументы. Рассмотрим пример.

A.9. ФУНКЦИИ

1113
void g(int, int =7, int); // ошибка: по умолчанию задан
// не замыкающий аргумент f(1,,1); // ошибка: пропущен второй аргумент
Альтернативой аргументам, заданным по умолчанию, может быть перегрузка (и наоборот).
Опубликовал katy May 01 2015 12:24:17 · 0 Комментариев · 2913 Прочтений · Для печати

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


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



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

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

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

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

Пароль



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

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

Случайные загрузки
База данных фильм...
3d Tank [Исходник...
OnlineIP
Реализация ЭЦП по...
API (Применение A...
IIIDTrans
C++ Стандартная б...
Таймер и секундомер
С# для профессион...
DiskInfo
Crypt32
AddPage [Исходник...
БД студентов
Создание лабиринт...
FilesInfo
Отключение и вклю...
Сапёр
Error mod
Создание Web-сайт...
Трассировка прово...

Топ загрузок
Приложение Клие... 100793
Delphi 7 Enterp... 98016
Converter AMR<-... 20298
GPSS World Stud... 17059
Borland C++Buil... 14238
Borland Delphi ... 10373
Turbo Pascal fo... 7390
Калькулятор [Ис... 6080
Visual Studio 2... 5228
Microsoft SQL S... 3674
Случайные статьи
Создание веб-анима...
ЛюбойЛюбой2
Приэтом проверяетс...
Решение: интерфейс...
Маршрутизатор обра...
Алгоритм расширени...
Списковая форма за...
Конечная область п...
Описание архива с ...
Генерация программ...
Желонка для скважины
Компиляция модулей
Способы вывода сре...
Почему протокол OS...
Заполнить квадрат NxN
Что напоминает тре...
Другие команды
Пицца Подольск
Операции записи да...
10.1. Краткое вве...
• Публикация CRL, ...
Первое контрольно...
машина Поста на C#...
Ребята из Microsoft
Целостность информ...
Статистика



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


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