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

VB - 27. lekceVB - 27. lekce

 

VB - 27. lekce

Google       Google       8. 9. 2005       12 354×

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 NEWTON Media prohledá 200  milionů mediálních zpráv během sekund díky Cisco UCS

NEWTON Media prohledá 200 milionů mediálních zpráv během sekund díky Cisco UCS

Česká společnost NEWTON Media provozuje největší archiv mediálních zpráv ve střední a východní Evropě. Mezi její zákazníky patří například ministerstva, evropské instituce nebo komerční firmy z nejrůznějších oborů. NEWTON Media rozesílá svým zákazníkům každý den monitoring médií podle nastavených klíčových slov a nabízí online službu, kde lze vyhledat mediální výstupy v plném znění od roku 1996.

Reklama
Reklama
Obrázek ke článku Delphi 10.1.2 (Berlin Update 2) – na co se můžeme těšit

Delphi 10.1.2 (Berlin Update 2) – na co se můžeme těšit

Touto roční dobou, kdy je zem pokrytá barevným listím a prsty křehnou v mrazivých ránech, se obvykle těšíme na zbrusu novou verzi RAD Studia. Letos si však ale budeme muset počkat na Godzillu a Linux až do jara. Vezměme tedy za vděk alespoň updatem 2 a jelikož dle vyjádření pánů z Embarcadero se budou nové věci objevovat průběžně, pojďme se na to tedy podívat.

Obrázek ke článku Konference: Moderní datová centra pro byznys dneška se koná už 24. 11.

Konference: Moderní datová centra pro byznys dneška se koná už 24. 11.

Stále rostoucí zájem o cloudové služby i maximální důraz na pružnost, spolehlivost a bezpečnost IT vedou k výrazným inovacím v datových centrech. V infrastruktuře datových center hraje stále významnější roli software a stále častěji se lze setkat s hybridními přístupy k jejich budování i provozu.

Obrázek ke článku Konference: Mobilní technologie mají velký potenciál pro byznys

Konference: Mobilní technologie mají velký potenciál pro byznys

Firmy by se podle analytiků společnosti Gartner měly  rychle přizpůsobit skutečnosti, že mobilní technologie už zdaleka nejsou horkou novinkou, ale standardní součástí byznysu. I přesto - nebo možná právě proto - tu nabízejí velký potenciál. Kde tedy jsou ty největší příležitosti? I tomu se bude věnovat již čtvrtý ročník úspěšné konference Mobilní řešení pro business.

loadingtransparent (function() { var po = document.createElement('script'); po.type = 'text/javascript'; po.async = true; po.src = 'https://apis.google.com/js/plusone.js'; var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(po, s); })();
Hostujeme u Českého hostingu       ISSN 1801-1586       ⇡ Nahoru Webtea.cz logo © 20032016 Programujte.com
Zasadilo a pěstuje Webtea.cz, šéfredaktor Lukáš Churý