1 00:00:07,185 --> 00:00:09,540 [Powered by Google Translate] CHRIS GERBER: funkce je série kroků, které v rámci 2 00:00:09,540 --> 00:00:12,000 větší program, který je obvykle určen k tzv. 3 00:00:12,000 --> 00:00:14,440 vícekrát a od různých jiných místech v 4 00:00:14,440 --> 00:00:15,720 program. 5 00:00:15,720 --> 00:00:18,480 Při vytváření funkce C, jeden z těchto požadavků je 6 00:00:18,480 --> 00:00:21,050 určovat návratový typ hodnoty. 7 00:00:21,050 --> 00:00:23,490 Nejjednodušší případ je situace, kdy volající 8 00:00:23,490 --> 00:00:26,510 Kód se netýká výsledek funkce. 9 00:00:26,510 --> 00:00:28,530 To může být případ, kdy jsme tisk dat na 10 00:00:28,530 --> 00:00:31,120 uživatele displej, jako u printf. 11 00:00:31,120 --> 00:00:33,140 V tomto případě, můžeme deklarovat hodnotu vrácení 12 00:00:33,140 --> 00:00:35,020 být typu void. 13 00:00:35,020 --> 00:00:37,130 Použití neplatné prostě říká kompilátoru, že ne 14 00:00:37,130 --> 00:00:39,120 hodnota bude vrácena. 15 00:00:39,120 --> 00:00:40,530 Pojďme se podívat, jak to vypadá. 16 00:00:40,530 --> 00:00:42,940 >> Řekněme, že máme funkci nazvanou say_hello, že 17 00:00:42,940 --> 00:00:44,490 přijímá jeden argument. 18 00:00:44,490 --> 00:00:47,050 Budeme předat jméno osoby a zobrazí pozdrav 19 00:00:47,050 --> 00:00:48,380 na obrazovce. 20 00:00:48,380 --> 00:00:50,505 Název bude typu char *. 21 00:00:50,505 --> 00:00:53,080 A budeme specifikovat, že jako argument. 22 00:00:53,080 --> 00:00:55,970 Moje žádost nemusí vědět, co byl vytištěn nebo pokud jej 23 00:00:55,970 --> 00:00:56,970 byl vytištěn. 24 00:00:56,970 --> 00:00:59,680 Takže návratová hodnota bude typu void. 25 00:00:59,680 --> 00:01:02,060 Tato funkce může tisknout na obrazovku s příkazem jako 26 00:01:02,060 --> 00:01:07,620 printf ("Hello,% s \ n 27 00:01:07,620 --> 00:01:12,100 ", Name);. 28 00:01:12,100 --> 00:01:14,690 Pozdrav se zobrazí a kontroly budou předány 29 00:01:14,690 --> 00:01:16,260 zpět do volající kód. 30 00:01:16,260 --> 00:01:19,370 Jedna věc k poznámce je, že když návratová hodnota typu je neplatný, 31 00:01:19,370 --> 00:01:20,790 nemusíte zahrnovat návratnost 32 00:01:20,790 --> 00:01:22,300 Prohlášení ve funkci. 33 00:01:22,300 --> 00:01:25,270 Pokud se rozhodnete do jednoho, že nejsou uvedeny návratovou hodnotu 34 00:01:25,270 --> 00:01:27,420 jako argument. 35 00:01:27,420 --> 00:01:29,380 >> V některých případech, to dává smysl vrátit 36 00:01:29,380 --> 00:01:30,570 hodnota z funkce. 37 00:01:30,570 --> 00:01:33,900 Řekněme, že jsme psali funkci nazvanou add_floats. 38 00:01:33,900 --> 00:01:36,160 Budeme předat dva argumenty, oba plováky, 39 00:01:36,160 --> 00:01:37,510 tzv. první a druhé. 40 00:01:37,510 --> 00:01:40,520 A to nám řekne, co součet těchto plováků je. 41 00:01:40,520 --> 00:01:43,000 Víme, že pokud budeme přidat dva plováky dohromady, výsledek 42 00:01:43,000 --> 00:01:44,120 bude float. 43 00:01:44,120 --> 00:01:47,540 Vzhledem k tomu, že jsme si vybrat návratový typ float. 44 00:01:47,540 --> 00:01:50,040 Tato funkce bude provést tento výpočet a vrátí 45 00:01:50,040 --> 00:01:52,260 hodnoty v prohlášení, jako je návrat 46 00:01:52,260 --> 00:01:54,770 první + druhý;. 47 00:01:54,770 --> 00:01:57,300 Pokud je kontrola předána zpět volající kód, 48 00:01:57,300 --> 00:02:00,030 Výsledná hodnota je nyní k dispozici k tomuto kódu. 49 00:02:00,030 --> 00:02:04,250 Můžeme uložit tuto hodnotu jako tak: float výsledek = 50 00:02:04,250 --> 00:02:09,410 add_floats (3,14, 1,62 51 00:02:09,410 --> 00:02:11,290 );. 52 00:02:11,290 --> 00:02:15,200 Výsledek v tomto případě by nyní obsahuje hodnotu 4,76. 53 00:02:15,200 --> 00:02:18,620 >> Jako připomenutí, plovoucí bodové hodnoty jsou nepřesné. 54 00:02:18,620 --> 00:02:21,250 Takže pokud to finanční kalkulace, pomocí dolarů a 55 00:02:21,250 --> 00:02:24,960 centů, můžeme chtít, aby zvážila přesný typ dat, jako 56 00:02:24,960 --> 00:02:29,120 int a provést výpočet v haléře. 57 00:02:29,120 --> 00:02:31,270 >> Další případ, kdy budeme chtít vrátit hodnotu z 58 00:02:31,270 --> 00:02:33,980 Funkce je, když chceme vědět, jestli funkce byla 59 00:02:33,980 --> 00:02:35,960 úspěšný. 60 00:02:35,960 --> 00:02:39,190 Pokud to nebylo úspěšné, můžeme také chtít vědět, jaký typ 61 00:02:39,190 --> 00:02:41,250 Došlo k chybě. 62 00:02:41,250 --> 00:02:43,647 Řekněme, že se snažíme otevřít soubor na disk počítat 63 00:02:43,647 --> 00:02:45,220 počet znaků v něm. 64 00:02:45,220 --> 00:02:48,635 Pokud soubor nelze otevřít, chceme být schopni zastavit a 65 00:02:48,635 --> 00:02:50,910 sdělit uživateli o tomto problému. 66 00:02:50,910 --> 00:02:54,070 >> Zavoláme naše funkce count_file_chars a bude 67 00:02:54,070 --> 00:02:55,490 se jeden argument. 68 00:02:55,490 --> 00:02:57,420 Budeme procházet v názvu souboru pomocí 69 00:02:57,420 --> 00:02:59,610 char * filename volal. 70 00:02:59,610 --> 00:03:03,050 Tato funkce může vypadat nějak takto. 71 00:03:03,050 --> 00:03:05,450 V tomto příkladu, očekávali bychom, že počet se vrátil k 72 00:03:05,450 --> 00:03:07,130 být 0 nebo více. 73 00:03:07,130 --> 00:03:08,870 To ponechává nám negativní celá čísla 74 00:03:08,870 --> 00:03:10,200 použít jako ověřovací hodnoty. 75 00:03:10,200 --> 00:03:13,320 Sentinel hodnota je prostě zvláštní hodnota, která není 76 00:03:13,320 --> 00:03:16,200 legitimní dat, ale to sdělit informaci. 77 00:03:16,200 --> 00:03:19,480 Tady, když jsem se vrátit -1 do volající kód, jsem 78 00:03:19,480 --> 00:03:21,830 skutečně odeslání zprávy, že došlo k chybě při 79 00:03:21,830 --> 00:03:23,810 pokusu o přístup k souboru. 80 00:03:23,810 --> 00:03:26,060 Mohl bych pak zjistit, že návratovou hodnotu určit, zda moje 81 00:03:26,060 --> 00:03:28,060 Funkce volání bylo úspěšné. 82 00:03:28,060 --> 00:03:30,350 Pokud jich bylo 0 nebo větší, bych já vím, že 83 00:03:30,350 --> 00:03:32,180 počet znaků v souboru. 84 00:03:32,180 --> 00:03:35,310 Je-li však počet byl nižší než 0, mohl prostě 85 00:03:35,310 --> 00:03:37,350 vytisknout, že problém nastal. 86 00:03:37,350 --> 00:03:40,120 Jeden trade-off je, aby zvážila, že rezervaci všechny 87 00:03:40,120 --> 00:03:43,180 Negativní hodnoty jako ověřovací hodnoty, za předpokladu, že se jedná o 88 00:03:43,180 --> 00:03:46,070 32-bit celé číslo, já jsem v podstatě vzali kolem 89 00:03:46,070 --> 00:03:48,970 2000000000 možné návratové hodnoty. 90 00:03:48,970 --> 00:03:51,270 >> Typy návratová hodnota jsou jedním z nejdůležitějších prvků 91 00:03:51,270 --> 00:03:52,460 volání funkce. 92 00:03:52,460 --> 00:03:54,670 Doufejme, že tento krátký přehled vám pomohl myslet 93 00:03:54,670 --> 00:03:59,110 tři klíčové typy: void, výsledné hodnoty a ověřovací hodnoty, 94 00:03:59,110 --> 00:04:00,190 a když každý z těchto tří může být 95 00:04:00,190 --> 00:04:02,010 vhodné v kódu. 96 00:04:02,010 --> 00:04:03,260 Díky za sledování.