КАТЕГОРИИ: Архитектура-(3434)Астрономия-(809)Биология-(7483)Биотехнологии-(1457)Военное дело-(14632)Высокие технологии-(1363)География-(913)Геология-(1438)Государство-(451)Демография-(1065)Дом-(47672)Журналистика и СМИ-(912)Изобретательство-(14524)Иностранные языки-(4268)Информатика-(17799)Искусство-(1338)История-(13644)Компьютеры-(11121)Косметика-(55)Кулинария-(373)Культура-(8427)Лингвистика-(374)Литература-(1642)Маркетинг-(23702)Математика-(16968)Машиностроение-(1700)Медицина-(12668)Менеджмент-(24684)Механика-(15423)Науковедение-(506)Образование-(11852)Охрана труда-(3308)Педагогика-(5571)Полиграфия-(1312)Политика-(7869)Право-(5454)Приборостроение-(1369)Программирование-(2801)Производство-(97182)Промышленность-(8706)Психология-(18388)Религия-(3217)Связь-(10668)Сельское хозяйство-(299)Социология-(6455)Спорт-(42831)Строительство-(4793)Торговля-(5050)Транспорт-(2929)Туризм-(1568)Физика-(3942)Философия-(17015)Финансы-(26596)Химия-(22929)Экология-(12095)Экономика-(9961)Электроника-(8441)Электротехника-(4623)Энергетика-(12629)Юриспруденция-(1492)Ядерная техника-(1748) |
Перевантаження конструкторів
Перевантаження функцій-членів класу Функції-члени класу можна перевантажувати так само, як і будь-які інші функції в C++, тобто в класі допускається існування декількох функцій з однаковим ім'ям. Правильний варіант функції автоматично вибирається компілятором залежно від кількості і типів аргументів, заданих в прототипі функції. У наступній програмі створюється переобтяжена функція number() класу absolute_value, яка повертає абсолютне значення як цілочисельних аргументів, так і аргументів з плаваючою комою. У першому випадку для цього використовується бібліотечна функція abs(), що приймає аргумент типу int, в другому - fabs (), що приймає аргумент типу double. // // // absolute. cpp // // Ця програма на мові C++ демонструє використання переобтяжених // // функцій-членів класу. Програма обчислює абсолютне значення чисел // // типу int і double. ##include <iostream.h> ##include <math.h> // містить прототипи функцій abs() і fabs() class absolute value { public: int number (int); double number (double); int absolute_value::number(int test_data) return(abs(test_data)); double absolute_value::number(double test_data) return(fabs(test_data)); } main() absolute_value neg_number; cout<< "Абсолютне значення числа - 583 рівне << neg_number.number(- 583) << endl; cout<< "Абсолютне значення числа - 583.1749 рівно " << neg_number. number (- 583.1749)<< endl; return (0);) Ось якими будуть результати роботи програми: Абсолютне значення числа - 583 рівне 583 Абсолютне значення числа - 583.1749 рівно 583.175 У програмі, що приводиться далі, у функцію trig_calc() передається значення кута в одному з двох форматів: числовому або строковому. Програма обчислює синус, косинус і тангенс кута. // // // overload. срр // // Ця програма на мові C++ містить приклад переобтяженої функції // // що набуває значення кута як в числовому виді, так і у форматі // // градуси/хвилини/секунди. // ##include <iostream.h> ##include <math.h> ##include <string.h> const double DEG_TO_RAD = 0.0174532925; class trigonometric { double angle; public: void trig_calc(double); void trig_calc(char *); }; void trigonometric::trig_calc(double degrees)! angle = degrees; cout << "\nДля кута " << angle << " градусів:" << endl; cout << "синус рівний " << sin (angle * DEG TO_RAD) << endl; cout << "косинус рівний " << cos(angle * DEG_TO_RAD) << endl; cout << "тангенс рівний " << tan(angle * DEG_TO_RAD) << endl; } void trigonometric::trig_calc(char *dat)( char *deg, *min, *sec; deg = strtok(dat, "d"); min = strtok(0, "m"); sec = strtok(0","s); angle = atof(deg) + atof(min)/60.0 + atof (sec)/360.0; cout<< "\nДля кута". << angle << " градусів:" << endl; cout << "синус рівний ' " << sin(angle * DEG_TO_RAD) << endl; cout << "косинус рівний " << cos(angle * DEG_TO_RAD) << endl; cout << "тангенс рівний " << tan (angle * DEG_TO_RAD) << endl; } main () ((trigonometric data; data.trig_calc(75.0); char str1[] = "35 d 75m 20s"; data.trig_calc(str1); data.trig_calc(145.72); char str2[l= "65 d45m 30s"; data.trig_calc (str2); return(0); } У програмі використовується бібліотечна функція strtok(), прототип якої знаходиться у файлі STRING.H. Ця функція сканує рядок, розбиваючи її на лексеми, ознакою кінця яких служить один з символів, перерахованих в другому аргументі. Довжина кожної лексеми може бути довільною. Функція повертає покажчик на першу виявлену лексему. Лексеми можна читати одну за іншою шляхом послідовного виклику функції strtok(). Річ у тому, що після кожної лексеми вона вставляє в рядок символ \0 замість символу-роздільника. Якщо при наступному виклику як перший аргумент вказати 0, функція продовжить читання рядка з цього місця. Коли в рядку більше немає лексем, повертається нульовий покажчик. Розглянута програма дозволяє задавати значення кута у вигляді рядка з вказівкою градусів, хвилин і секунд. Ознакою кінця першої лексеми, що містить кількість градусів, служить буква d, другої лексеми - т, третьою, - s. Кожна витягнута лексема перетвориться в число за допомогою стандартної бібліотечної функції atof() з файлу МАТН.Н. Нижче представлені результати роботи програми: Для кута 75 градусів: синус дорівнює 0.965926 косинус дорівнює 0.258819 тангенс дорівнює 3.73205 Для кута 36.3056 градусів: синус дорівнює 0.592091 косинус дорівнює 0.805871 тангенс дорівнює 0.734722 Для кута 145.72 градусів: синус дорівнює 0.563238 косинус рівний - 0.826295 тангенс рівний - 0.681642 Для кута 65.8333 градусів: синус дорівнює 0.912358 косинус дорівнює 0.409392 тангенс дорівнює 2.22857
Дата добавления: 2013-12-14; Просмотров: 789; Нарушение авторских прав?; Мы поможем в написании вашей работы! Нам важно ваше мнение! Был ли полезен опубликованный материал? Да | Нет |