Diskuze: vyskočím přes return z funkce?
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.
Člen
Zobrazeno 11 zpráv z 11.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.
Použil jsme return ale funkce pokračuje dál,
hoď kód, return ukončuje VŽDY současnou funkci, takže pravděpodobně děláš něco špatně, nebo něco špatně chápeš.
Konkrétní kód nemůžu ale zkusím to trochu obecně jak to mám:
<?php
$vysledek = priklad($parametry);
if(!$vysledek){
$log->error('Bla Bla Bla');
}
// FUNKCE ----------------
function priklad($parametry)
{
$kontakty = $spravceKontaktu->vratIdkontaktuPodleLicencnihoKlice('AAAAA');
if(!$kontakty) {
return false;
}
$deaktivace = $spravceKontaktu->deaktivujKontakt($kontakty['id']);
if(!$deaktivace) {
return false;
}
return true;
}
když první funkce ve funkci priklad vrati false tak se mi stejně spusti druha funkce a ta pochopitelně háže chybu, protože nezná parametr $kontakt['id']. TA by se podle mě ale už vůbec neměla provést a funkce priklad by měla vrátit false. Ale neděje se tak. Ještě může být chyba někde v těch knihovnách že nevrací false když ten kontakt nenajde ale na první podle to vypadá že by to mělo fungovat.
A co vrací "$spravceKontaktu->vratIdkontaktuPodleLicencnihoKlice('AAAAA');" ?
To vrátí IDKontaktuPodleLicencnihoKlice NeumisCist?
Jinak ano... já samozřejmě vím, že PHP je dynamický SHIT a tudíž můžeš dělat různé věci... ale vratIdkontaktuPodleLicencnihoKlice by mi taky evokovalo, ze to treba bude vracet nejaky GUID, nebo Integer?
tudíž mi přijde poměrně nebezpečný dávat toto do podmínky a využít jakéhokoliv implicitního přetypování na boolean.. ale já nejsem PHPkář...
Vrací buď id kontaktu nebo FALSE v případě že nenajde. A to false právě odchytávám a když nenajde potřebuju aby to skočilo ven
Udělej si var_dump() vrácené hodnoty z $kontakty. Podle tvého modelového
příkladu nedostáváš ID, ale pole...
V podmínce použij ===, čili porovnání hodnoty a datového typu Comparison Operators
souhlasim s tim co napsal Findthee
pridej si tam var_dump:
$kontakty = $spravceKontaktu->vratIdkontaktuPodleLicencnihoKlice('AAAAA');
var_dump($kontakty);
if(!$kontakty) {
return false;
}
a pokud ti to skutecne vypise "bool(false)" a pritom funkce neskonci hned v tomto prvnim IFu, tak jsi objevil bug v PHP
pokud ti to vypise neco jineho, s cim nebudes vedet co a jak, tak to sem hod a popereme se s tim
To je predovsetkym zly pristup. Funkcia ma mat jediny vystupny bod, okrem ineho aj preto, aby si sa nestratil, ako sa ti to prave stalo. Prinajmensom to vsak bude prehladnejsie.
function priklad ($parametry) {
$vysledok = false
$kontakty = $spravceKontaktu->vratIdkontaktuPodleLicencnihoKlice('AAAAA');
$deaktivace = $spravceKontaktu->deaktivujKontakt($kontakty['id']);
if ($kontakty || $deaktivace) { //Ak to ide, testuj na true, nie false. A OR je vhodnejsie, lebo ma skratene vyhodnocovanie
$vysledok = true;
}
return $vysledok;
}
Tak to určitě ne. V rozumné míře můžeme použít
kolik returnů chceme. V PHP platí pouze obecné pravidlo, nepoužívat break,
else, elseif pokud předtím použiji return v if nebo case.
Např. místo.:
if (true) {
return 1;
} else {
return 0;
}
použít:
if (true) {
return 1;
}
return 0;
Navíc tvůj příklad může skončit chybou hned na 4 řádku (opominu chybějící středník na druhém), pokud $spravceKontaktu->vratIdkontaktuPodleLicencnihoKlice('AAAAA') vrátí false.
Zobrazeno 11 zpráv z 11.