Главная страница Случайная страница Разделы сайта АвтомобилиАстрономияБиологияГеографияДом и садДругие языкиДругоеИнформатикаИсторияКультураЛитератураЛогикаМатематикаМедицинаМеталлургияМеханикаОбразованиеОхрана трудаПедагогикаПолитикаПравоПсихологияРелигияРиторикаСоциологияСпортСтроительствоТехнологияТуризмФизикаФилософияФинансыХимияЧерчениеЭкологияЭкономикаЭлектроника |
💸 Как сделать бизнес проще, а карман толще?
Тот, кто работает в сфере услуг, знает — без ведения записи клиентов никуда. Мало того, что нужно видеть свое раписание, но и напоминать клиентам о визитах тоже.
Проблема в том, что средняя цена по рынку за такой сервис — 800 руб/мес или почти 15 000 руб за год. И это минимальный функционал.
Нашли самый бюджетный и оптимальный вариант: сервис VisitTime.⚡️ Для новых пользователей первый месяц бесплатно. А далее 290 руб/мес, это в 3 раза дешевле аналогов. За эту цену доступен весь функционал: напоминание о визитах, чаевые, предоплаты, общение с клиентами, переносы записей и так далее. ✅ Уйма гибких настроек, которые помогут вам зарабатывать больше и забыть про чувство «что-то мне нужно было сделать». Сомневаетесь? нажмите на текст, запустите чат-бота и убедитесь во всем сами! Массивы указателей на функции
Аналогично объявлению массива указателей целых чисел можно объявить массив указателей на функции с определенной сигнатурой, возвращающих значения определенного типа. Листинг 14.7 является еще одним вариантом программы из листинга 14.5, в которой все указатели на функции собраны в массив. Листинг 14.7. Использование массива указателей на функции 1: // Листинг 14.7. Пример использования массива указателей на функции 2: 3: #include < iostream.h> 4: 5: void Square (int&, int&); 6: void Cube (int&, int&); 7: void Swap (int&, int &); 8: void GetVals(int&, int&); 9: void PrintVals(int, int); 10: 11: int main() 12: { 13: int valOne=1, valTwo=2; 14: int choice, i; 15: const MaxArray = 5; 16: void (*pFuncArray[MaxArray])(int&, int&); 17: 18: for (i=0; i< MaxArray; i++) 19: { 20: cout < < " (1)Change Values (2)Square (3)Cube (4)Swap: "; 21: cin > > choice; 22: switch (choice) 23: { 24: case 1: pFuncArray[i] = GetVals; break; 25: case 2: pFuncArray[i] = Square; break; 26: case 3: pFuncArray[i] = Cube; break; 27: case 4: pFuncArray[i] = Swap; break; 28: default: pFuncArray[i] = 0; 29: } 30: } 31: 32: for (i=0; i< MaxArray; i++) 33: { 34: if (pFuncArray[i] == 0) 35: continue; 36: pFuncArray[i](valOne, valTwo); 37: PrintVals(valOne, valTwo); 38: } 39: return 0; 40: } 41: 42: void PrintVals(int x, int у) 43: { 44: cout < < " x: " < < x < < " у: " < < у < < endl; 45: } 46: 47: void Square (int & rX, int & rY) 48: { 49: rX *= rX; 50: rY *= rY; 51: } 52: 53: void Cube (int & rX, int & rY) 54: { 55: int tmp; 56: 57: tmp = rX; 58: rX *= rX; 59: rX = rX * tmp; 60: 61: tmp = rY; 62: rY *= rY; 63: rY = rY * tmp; 64: } 65: 66: void Swap(int & rX, int & rY) 67: { 68: int temp; 69: temp = rX; 70: rX = rY; 71: rY = temp; 72: } 73: 74: void GetVals (int & rValOne, int & rValTwo) 75: { 76: cout < < " New value for ValOne: "; 77: cin > > rValOne; 78: cout < < " New value for ValTwo: "; 79: cin > > rValTwo; 80: }
Результат: (1)Change Values (2)Square (3)Cube (4)Swap: 1 (1)Change Values (2)Square (3)Cube (4)Swap: 2 (1)Change Values (2)Square (3)Cube (4)Swap: 3 (1)Change Values (2)Square (3)Cube (4)Swap: 4 (1)Change Values (2)Square (3)Cube (4)Swap: 2 New Value for ValOne: 2 New Value for ValTwo: 3 x: 2 y: 3 x: 4 y: 9 x: 64 y: 729 x: 729 y: 64 x: 531441 y: 4096
Анализ: Как и в предыдущем листинге, для экономии места не были показаны выполнения объявленных функций, поскольку сами функции остались теми же, что и в листинге 14.5. В строке 16 объявляется массив pFuncArray, содержащий пять указателей на функции, которые возвращают void и принимают две ссылки на значения типа int. В строках 18-30 пользователю предлагается установить последовательность вызова функций. Каждый член массива связывается с соответствующей функцией. Последовательный вызов функции осуществляется в строках 32-38, причем после каждого вызова на экран сразу выводится результат.
|