VB - 27. lekce
 x   TIP: Přetáhni ikonu na hlavní panel pro připnutí webu
Reklama
Reklama

VB - 27. lekceVB - 27. lekce

 
Hledat
Moderní platforma pro vytvoření vašeho nového webu – Wix.com.
Nyní už můžete mít web zdarma.
Vybavení pro Laser Game
Spuštěn Filmový magazín
Laser Game Brno

VB - 27. lekce

Google       Google       8. 9. 2005       13 881×

27.1 Členění do podprogramů
27.2 Předávání parametrů pomocí ByRef a ByVal
27.3 Nepovinné parametry
27.4 Volání nepovinných parametrů pomocí názvů
27.5 Funkce IsMissing pro nepovinné parametry
27.6 Předdefinovaná hodnota nepovinného parametru
27.7 Pole parametrů ParamArray
27.8 Domácí úkol
27.9 V další lekci

Reklama
Reklama

27.1 Členění do podprogramů

Proč vlastně soft členit do podprogramů? No především je to úspora práce. Také to způsobuje přehlednější kód. Urychluje to práci a to je také důležité. Dnes, kdy se vývoj žene kupředu až neuvěřitelnou rychlostí, je potřeba rychlost, ale nesmí to být na úkor kvality. Ne všichni se ale řídí tím, že by rychlost vývoje neměla být na úkor kvality. Podprogramy se většinou vytváří jako funkce nebo procedury. A ty potřebují (ne vždy, ale většinou) parametry a my je poskytujeme za názvem funkce či procedury. V parametrech se přenášejí údaje o tom, jak se má ona funkce vykonat nebo s jakými hodnotami se funkce bude zpracovávat. Tak si o oněch parametrech řekneme něco víc.

27.2 Předávání parametrů pomocí ByRef a ByVal

Parametr můžeme funkci předat dvojím způsobem, a to pomocí reference nebo pomocí hodnoty. Rozdíl v nich si ukážeme na následujícím zdrojovém kódu:


Dim a As Long
Dim b As Long

Private Sub Form_Click()
  a = 4
  b = 5
  Call N (a, b)
  Print a
  Print b
End Sub

Private Function N(ByVal x As Long, ByRef y As Long)
  x = 3
  y = 3
End Function

Proměnnou a v parametru x předáváme jako hodnotu, a i když se ve funkci změní, její hodnota v programu bude taková, jaká se vložila do funkce. Na rozdíl od proměnné b v parametru y, která je předaná pomocí reference. Pokud se tedy parametr y v těle funkce změní, změní se i hodnota proměnné b.

27.3 Nepovinné parametry

Převážná většina funkci používá parametr(y). Může ale existovat funkce, kde některý z parametrů někdy nebude používán, jindy ano. Proto musejí být ve funkci definovány všechny parametry, i když nemusí být při volání funkce zadány všechny. V kódu nepovinný parametr vypadá takto:


Private Function Info(Optional ByVal Meno As String _
                      Optional ByVal Primeni As String _
                      Optional ByVal cislo As Long)
  'tělo funkce
End Function

Značí se slovíčkem optional. Pokud funkce obsahuje povinné i nepovinné parametry, musí být uvedeny první ty povinné a až pak mohou následovat nepovinné parametry.


Nepovinné parametry se používají spíše výjimečně a musí se při práci s nimi dávat pozor a funkce musí být řádně ošetřená. Nešikovným použitím způsobíte pád programů.

27.4 Volání nepovinných parametrů pomocí názvů

Pokud chceme zadat některý z několik nepovinných parametrů, máme několik možností. První je standardně se dostat na místo pomocí čárek. A pak to druhé je zadání jména parametru.


Private Sub Form_Click()
  Info ,strPrimeni
  'nebo
  Info Primeni: strPrimeni
End Sub

Nic v tom není, jen se obávám, že to u vás nenajde mnoho použití. Ani já toho nevyužívám, ale je dobré vědět, že ta možnost tu je.

27.5 Funkce IsMissing pro nepovinné parametry

Je tu také funkce, která vám zjistí, zda byl parametr zadán nebo zda zůstal prázdný. Zdrojový kód pak může vypadat třeba takto:


Private Function x(a As Long, b As Long, Optional c As Variant)
  If IsMissing(c) Then
    Print a, b
  Else
    Print a, b, c
  End If
End Function

Někdy se to může hodit, ale výhodnější je použití následující možnosti…

27.6 Předefinovaná hodnota nepovinného parametru

Spíše než funkce IsMissing se používá definování defaultní hodnoty parametru, pokud není zadán, je tedy do parametru uložena tato hodnota.


Private Function x(a As Long, b As Long, Optional c As Long = 3)
  'Tělo funkce
End Function

Pokud tedy hodnotu vy nezadáte, je nahrazena hodnotou zadanou.

Tato možnost je mírně elegantnější, a když vezmu v potaz Visual Basic.NET, tak tam funkce IsMissing vůbec není. Tam se musí defaultní hodnota parametru definovat vždy.

27.7 Pole parametrů ParamArray

Za nejvhodnější příklad, jak použít pole parametrů, bych viděl asi funkci SUMA. Sečte nám prakticky libovolný počet čísel.


Private Sub Form_Click()
  Print Suma(4, 4, 5, 9, 3, 11, 569, 1, 2, 2)
End Sub

Private Function Suma(ParamArray Cisla() As Variant)
  For Each Var In Cisla
    Sum = Sum + Var
  Next Var
  Suma = Sum
End Function

Využíváme zde klíčového slova ParamArray. A potom pro práci s polem parametrů používáme cyklus ForEach. Ve kterém to vše sečteme.

27.8 Domácí úkol

Co třeba vytvořit si trochu lepší kalkulačku? Ne? Ale jo. Grafické zpracování by taky nebylo na škodu. A pokud znáte trochu lepší kalkulačky, mají třeba tlačítko shift nebo 2ndF. Případně když si troufnete na jednoduchou dvouřádkovou kalkulačku, tak by to nebylo špatné.

27.9 V další lekci

Příště si budeme povídat něco o proměnných.

×Odeslání článku na tvůj Kindle

Zadej svůj Kindle e-mail a my ti pošleme článek na tvůj Kindle.
Musíš mít povolený příjem obsahu do svého Kindle z naší e-mailové adresy kindle@programujte.com.

E-mailová adresa (např. novak@kindle.com):

TIP: Pokud chceš dostávat naše články každé ráno do svého Kindle, koukni do sekce Články do Kindle.

Hlasování bylo ukončeno    
0 hlasů
Google
(fotka) Jiří ChytilAutor programuje ve VB, zajímá se o elektrotechniku, studuje na SOŠ Elektrotechnické - obor číslicová technika.
Web    

Nové články

Obrázek ke článku Virtuální zrcadla změní způsob nakupování v e-shopech

Virtuální zrcadla změní způsob nakupování v e-shopech

Díky pluginu Virtooal.com získávají zákazníci e-shopů možnost si vyzkoušet produkty ve virtuálním světě. E-shopy, které si plugin nainstalují, výrazně snižují množství vráceného zboží, dělají nákupy zábavnějšími, a tím budují lepší vztahy se svými zákazníky. V současnosti lze Virtooal.com využít zejména pro kosmetiku, brýle a šperky, do budoucna půjde také o módu.

Reklama
Reklama
Obrázek ke článku Kariérní postup & vyšší plat: Titul MBA ve sféře IT

Kariérní postup & vyšší plat: Titul MBA ve sféře IT

Působíte jako specialista v oblasti IT a aspirujete na povýšení, příp. řídící pozici? Pak se jistě potýkáte nejen s vysokými nároky (potenciálních) zaměstnavatelů, ale i se silnou konkurencí ze strany ostatních uchazečů. Pokud chcete zvýšit své šance na kariérní posun a lepší plat, měli byste vedle technických dovedností ovládat i ty manažerské. Pomoci vám v tomto ohledu může studium MBA se specializací na management IT.

Obrázek ke článku Tisková konference Hackers Congress Paralelni Polis 2018

Tisková konference Hackers Congress Paralelni Polis 2018

Již pátý ročník akce globálního významu Hackers Congress Paralelni Polis 2018 se letos odehraje 5. – 7. října, a to znovu v prostorech Paralelní Polis a přilehlého divadla La Fabrika na Praze 7. Na kongres se opět sjedou světoví odborníci, kteří svým zaměřením kopírují čtyři základní pilíře akce. Jsou jimi Svoboda a kryptoanarchie, Decentralizovaná ekonomika a kryptoměny, Politické umění a hacking a také Věda a technologie

Hostujeme u Českého hostingu       ISSN 1801-1586       ⇡ Nahoru Webtea.cz logo © 20032018 Programujte.com
Zasadilo a pěstuje Webtea.cz, šéfredaktor Lukáš Churý