dicht timmeren?

Overzicht Reageren

Sponsored by: Vacatures door Monsterboard

Medior Java developer

Wat je gaat doen: Of beter nog, wat wil jij doen? Binnen DPA GEOS zijn we dan ook op zoek naar enthousiaste Java developers om ons development team te versterken. Als Java developer werk je in Agile/Scrum teams bij onze klanten en daarbij kun je eventueel ook andere ontwikkelaars begeleiden in het softwareontwikkelproces. Verder draag je positief bij aan de teamgeest binnen een projectteam en je kijkt verder dan je eigen rol. Je gaat software maken voor verschillende opdrachtgevers in jouw regio. Je bent een professional die het IT-vak serieus neemt en kwaliteit levert. Je leert snel vanwege je diepgaande

Bekijk vacature »

PHP Software Developer

Functie omschrijving Op zoek naar een nieuwe uitdaging binnen PHP? Lees dan snel verder! Wij zoeken een ervaren PHP developer die binnen een organisatie gaat functioneren als verlengstuk van de klant. Wij zoeken voor deze iemand die technisch complexe zaken met enthousiasme en plezier aanvliegt. Verder moet je instaat zijn om je tijd goed te managen omdat je aan meerdere projecten tegelijkertijd werkt. Je werkt met de nieuwste technieken en tijdens deze uitdaging werk je veel samen met de front-end developers van deze organisatie. Wij zoeken iemand die zichzelf graag uitdaagt en altijd de beste wilt zijn. Bedrijfsprofiel Waar ga

Bekijk vacature »

Lead developer

Functie Als Lead developer wordt jij onderdeel van een multidisciplinair team van circa 23 software engineers. Als team werken jullie agile en zijn termen als Continuous Integration en Continuous Delivery dagelijkse koek. Jullie werken aan uitdagende en afwisselende projecten met als doel klanten een totaal oplossing aan te kunnen bieden. Jij wordt verantwoordelijk voor complete projecten waarbij jij als verantwoordelijke zorgt dat het project op de juiste manier blijft draaien. Zo haal jij ook de requirements op bij de klant en kijk jij samen met het team en met de salesafdeling hoeveel uren hiervoor nodig zijn. Daarnaast stuur jij jouw

Bekijk vacature »

C# developer

Functie Als C# ontwikkelaar ben jij de spin in het web bij deze organisatie. Jij begeleidt en traint de field engineers die bij de klanten machines leveren en installeren. Daarnaast ondersteun jij de field engineers als zij bij de klant vastlopen bij het installeren van de machine m.b.t. software matige vragen. Jouw doel is dan ook om de technische kennis van de field engineers door middel van training zoveel mogelijk uit te breiden. Dit om ervoor te zorgen dat zij zelfstandiger software matige problemen kunnen oplossen. Ook ben jij verantwoordelijk voor het bedenken van software oplossingen voor klanten en dit

Bekijk vacature »

.NET Developer gezocht!

Functie omschrijving Wij zijn op zoek naar een .NET Developer! Wil jij werken voor een internationaal bedrijf waar je legio mogelijkheden krijgt als Software Ontwikkelaar? Grijp nu je kans en kijk snel of jouw vaardigheden aansluiten bij onderstaand profiel! Je kunt een uitdagende rol gaan vervullen als .NET Developer binnen een internationaal bedrijf dat gevestigd is in omgeving Bergen. Dit bedrijf is zeer vooruitstrevend en verricht betekenisvol werk. Binnen dit bedrijf wordt gewerkt aan de productie en ontwikkeling van medische middelen. Als .NET Developer ga jij je bezig houden met het volgende: Je wordt betrokken bij alle fasen van software

Bekijk vacature »

Back-end Developer

Functieomschrijving Heb jij kort geleden jouw HBO ICT diploma in ontvangst mogen nemen? Of ben je toe aan een nieuwe uitdaging? Voor een gewaardeerde werkgever in regio Oosterhout zijn wij op zoek naar een back-end developer. Kennis of ervaring met C# & SQL is een must! Je bent verantwoordelijk voor de beheer en ontwikkeling van de software; Je draagt bij aan de implementatie van aanpassingen, verbeteringen en aanvullingen in de C# based applicaties; Je test de software en ontwikkelt deze door; Je houdt je bezig met het ontwikkelen van nieuwe functionaliteiten; Je brengt de aanpassingssuggesties van klanten in kaart, om

Bekijk vacature »

Junior PHP Developer

Je maakt een vliegende start van je carrière, door meteen mee te bouwen aan de digitale aspecten van Coolblue. Wat doe je als Junior PHP Developer bij Coolblue? Als Junior PHP Developer ben je meteen vanaf de start onderdeel van een development team. Je kijkt veel mee met collega’s en volgt trainingen om te groeien als Junior Developer. Op dat moment komt je wil om steeds te blijven leren naar boven. Daarnaast pak je in de sprints ook je eigen stories op om Coolblue iedere dag een beetje beter te kunnen maken. Je sterk analytisch vermogen komt dan ook goed

Bekijk vacature »

Front End Ontwikkelaar (React)

In het kort Als front end developer ga je aan de slag met maatwerkprojecten voor onze klanten. Denk bijvoorbeeld aan het toevoegen van een machine aan een database of het corrigeren van formulieren voor ingestuurde orders. Voorbeeld van zo’n project is Smart Link. De projecten waar je op ingezet kunt worden liggen binnen het technische domein waar jij als front end developer een grote rol speelt om samen met je back end collega’s de juiste oplossingen te leveren. please note that this particular role requires fluent Dutch language skills. Dit vind je leuk om te doen Het omzetten van designs

Bekijk vacature »

Back-end programmeur

Functieomschrijving Heb jij kort geleden je MBO of HBO ICT in ontvangst mogen nemen? Of ben je klaar voor een nieuw hoofdstuk in jouw carrière? Voor een uitdagende werkgever in de regio van Tilburg zijn wij op zoek naar een ambitieuze back-end programmeur met affiniteit met MS Acess. Samen met een enthousiast team ben je verantwoordelijk voor het bouwen van maatwerk software voor hun klanten. Je hebt kennis of ervaring van SQL, Maar affiniteit met MS Acess is nog belangrijker. Je bent sociaal naar klanten en flexibel ingesteld. Je denkt altijd in kansen en gaat graag de uitdaging aan. Verder

Bekijk vacature »

Ervaren Magento developer gezocht!

Functie Je komt te werken in een zelfsturend team waarin vertrouwen voorop staat en inbreng en ideeën worden gewaardeerd. Ook staat innovatie centraal. Ze bieden jou de mogelijkheid om jezelf door te ontwikkelen. Denk hierbij aan cursussen en een persoonlijk ontwikkelplan. Je komt terecht in het team van momenteel 4 (ervaren) collega’s en zal meewerken aan de doorontwikkeling en nieuwbouw van de Magento platformen van meerdere opdrachtgevers volgens Agile/Scrum. Denk hierbij aan nieuwe functionaliteiten, UX en koppelingen met verschillende back-end systemen. Als ervaren developer zul je hiernaast ook andere developers assisteren en waar nodig de leiding nemen in het project.

Bekijk vacature »

Junior .NET Developer

Dit ga je doen Als junior .NET Developer lever je met jouw oplossingen direct een bijdrage aan de bedrijfsprocessen van de klanten. Werkzaamheden waar jij je zoal mee bezig houdt zijn; Het ontwikkelen, onderhouden en optimaliseren van de draaiende platforms van de klanten; Softwareontwikkeling middels C#, .NET; Klantcontact om de wensen te bespreken en uit te werken; Optimaliseren van de (huidige) bedrijfsprocessen; De IT-afdeling bestaat uit 30 personen verdeeld over 3 teams. Het team waar je in terecht komt bestaat uit ongeveer tien man. Het is een team wat bestaat uit betrokken collega’s, waar iedereen bereidt is om elkaar te

Bekijk vacature »

Senior Front end developer

Functie Wij zijn op zoek naar een ambitieuze, zelfsturende Front-end Expert die ons (internationale) team komt versterken. Onze huidige software development afdeling bestaat uit 7 developers en designers. Wij zijn een écht softwarehuis, dus ervaring in software development is wel echt een must. Er wordt tegelijkertijd aan meerdere projecten gewerkt, voor mooie toonaangevende klanten. Je hebt dus regelmatig te maken met deadlines en opleveringen. Een deel van onze omgeving is in Angular.JS. Dit deel wordt langzamerhand omgebouwd naar de nieuwste versie van Angular. Jouw werkzaamheden zullen bestaan uit: Het aansturen en begeleiden van jouw collega’s Het implementeren van visuele elementen

Bekijk vacature »

Back End Developer .NET

Dit ga je doen Ontwikkelen in C# .NET en werken aan nieuwbouw, uitbouw en onderhoud van de software (die communiceren met 68.000 sensoren, waardoor er meerdere miljoenen berichten per uur verwerkt worden); Samenwerken in Scrum Teams; Meewerken aan verschillende, uitdagende projecten; Werken met nieuwe technologieën en vrijheid krijgen om jezelf te ontwikkelen en door te groeien. Hier ga je werken Je komt als Developer te werken bij een organisatie die gespecialiseerd is in software die real-time wordt gebruikt. De software constateert waar werk moet worden uitgevoerd en de chauffeurs worden met een andere applicatie hierop geattendeerd. Ook wordt er direct

Bekijk vacature »

Oracle Apex Developer

Dit ga je doen Jouw taken bestaan uit: Het bouwen maatwerk Oracle applicaties voor Europese business units; Het implementeren van de nieuwste technieken om te blijven innoveren; Actief meedenken en aandragen van verbetervoorstellen. Hier ga je werken Deze organisatie in de regio Veenendaal is een van wereld grootste retailers met ruim 16.000 winkels in 27 markten en jaarlijks ruim 5,3 miljard klanten die winkelen bij een van hun welbekende retailmerken. Binnen de organisatie is er een IT Group actief die dient als IT Service Provider voor de hele organisatie en waar dagelijks IT'ers werken aan state-of-the-art IT oplossingen. Dit doen

Bekijk vacature »

Medior/senior PHP ontwikkelaar E-commerce

Functie Het software development team bestaat momenteel 5 scrum teams . Ieder team heeft een eigen SCRUM Master en eigen tester. Zij werken voornamelijk in PHP en met hun eigen geschreven framework wat Symfony based is . Jij bent samen met je collega’s verantwoordelijk voor het interne softwaresysteem en alle projecten die daar omheen lopen. Alles wat jij ontwikkelt, wordt direct toegepast en uitgerold (wereldwijd). Dit maakt jouw werk tastbaar en uitdagend! Een greep uit jouw werkzaamheden: Toevoegen en ontwikkelen van nieuwe functionaliteiten Logistieke software ontwikkelen voor intern gebruik Tientallen gigabytes aan data inzichtelijk maken Altijd op zoek gaan naar

Bekijk vacature »

Pagina: « vorige 1 2 3 4 5 volgende »

Ozzie PHP

Ozzie PHP

20/03/2012 21:14:32
Quote Anchor link
Inmiddels weer even verder en wat wijzer. Ik heb besloten om als ik een key ophaal NIET te controleren of die key bestaat, maar direct de value terug te geven. Als de key niet bestaat.. dan heeft de programmeur een fout gemaakt. Weet je niet of een key bestaat, dan gebruik je de exists functie. Zo voorkom ik dus allerlei dubbele controles.

Enige twijfelpuntje is of ik i nm'n exists functie de combinatie van isset en array_key_exists moet gebruiken. Dit doe ik nu wel. Dit levert voordeel op als de key via isset wordt gevonden (deze functie is zeer snel), maar een nadeel als de key niet geset is... iemand advies daarin?
 
PHP hulp

PHP hulp

21/11/2024 17:07:47
 
Niels K

Niels K

22/03/2012 09:52:46
Quote Anchor link
Hoi Ozzie,

Dit is dus één van de situaties waar je het juist wel moet doen.

Oplossing: Maak een functie, exists en controleer in de get / set functie of een key daadwerkelijk bestaat.

Je kan je register ArrayObject laten extenden. Dan kan je met offsetExists controleren of hij daadwerkelijk bestaat.

Snap je?

Niels
 
Ozzie PHP

Ozzie PHP

22/03/2012 09:59:33
Quote Anchor link
Hoi Niels,

Nee, dat snap ik niet.

Ik heb het nu als volgt... waarbij ik meld dat deze situatie niet alleen voorkomt bij de registry maar ook bij m'n session class en configuration class.

Ik heb dus een functie get, die geeft direct de waarde terug (zonder te controleren of die bestaat). Het is dus de verantwoordelijkheid van de programmeur om ervoor te zorgen dat wanneer hij iets "get" hij zeker weet dat het eerder al ge"set" is. Als hij dat niet zeker weet, dan zet hij om de get een exists functie, als volgt:

Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
<?php
if (Registry::exists('geenideeofditgesetis')) {
  $data = Registry::get('geenideeofditgesetis');
}

?>


Ik vind dit eigenlijk wel een mooie manier. Zo kan er niks mis gaan.
 
Niels K

Niels K

22/03/2012 10:07:20
Quote Anchor link
Hoi Ozzie,

Ik vind dit geen mooie manier. Als je iets niet zeker weet kost het altijd drie regels code. Of je moet de ternary operator methode gebruiken.

Ik zou het als volgt doen: (als je ArrayObject extends)

Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
8
9
10
11
12
13
<?php

public static function get($index) {
    $instance = self::getInstance();

    if (false === $instance->offsetExists($index)) {
        throw new Registry_Exception('No entry is registered fory key ...'); // blablabla
    }

    return $instance->offsetGet($index);
}


?>


Niels
Gewijzigd op 22/03/2012 10:07:30 door Niels K
 
Ozzie PHP

Ozzie PHP

22/03/2012 10:31:57
Quote Anchor link
Hoi Niels,

Dat zou op zich wel kunnen, en zo had ik het eerst ook.

ECHTER... nu komt het :)

Ik heb er eens goed over nagedacht. Op jouw (en voorheen ook mijn) manier voer je ten eerste meer controles uit dan wanneer je het resultaat direct teruggeeft.

Ten tweede, stel een user moet inloggen en bij een geslaagde inlogpoging wordt het userobject in de registry geplaatst. Nu haal ik op een andere pagina de user op, maar deze is niet aanwezig in de registry omdat de inlogpoging niet geslaagd is. BOEM, er wordt een exception gegooid! Niet handig, want ik wil in dit geval gewoon een nette melding tonen dat de gebruiker eerst moet inloggen! Hoe lossen we dat op? Toch maar een exists functie eromheen bouwen en pas daarna de user ophalen. Nog meer controles!

Ik leg dus de verantwoordelijkheid nu bij de programmeur neer. Dat is iets minder gebruiksvriendelijk voor de programmeur, maar wel beter voor de performance.

Maar allemaal leuk en aardig dat geneuzel over wat goed en niet goed is. Laat ik het eens vergelijken met een real-life voorbeeld.

Ik ga iedere ochtend douchen, ontbijten en dan met de auto naar m'n werk. Ik ga er iedere ochtend vanuit dat ik brood en beleg heb (dat heb ik immers gekocht) en dat mijn auto aanwezig is op de plek waar ik 'm de avond van tevoren heb neergezet. Mijn proces ziet er in code als volgt uit:

Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
<?php
$ik
->douchen();
$brood_beleg = Registry::get('brood_beleg');
$ik->eten($brood_beleg);
$auto = Registry::get('auto');
$ik->vroem($auto);
?>


Op jouw manier ziet het proces er als volgt uit, waarbij ik de controle in de get functie even heb vertaald in een boolean controle. Dit is even met een hele dikke knipoog en het gaat niet om de exacte invulling. Het gaat vooral om de algemene gedachte erachter. Mijn manier is, vind ik, efficiënter en meer to the point. Jouw manier kent een betere foutafhandeling, maar weegt dat zwaarder op tegen de extra controles... in ieder geval leuk om daar je gedachten eens over te laten gaan. Jouw manier:

Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
<?php
$niels
->douchen();
$boolean = isErBroodBeleg();
if ($boolean) {
  $brood_beleg = Registry::get('brood_beleg');
}
else {
  die('Whhaaaahhh... mn brood is op!!');
}

if ($brood_beleg) {
  $niels->eten($brood_beleg);
}

$boolean = staatMnAutoOpDeJuistePlek();
if ($boolean) {
  $auto = Registry::get('auto');
}
else {
  die('Helluuuup mn auto is gejat!!');
}

if ($auto) {
  $niels->vroem($auto);
}

?>
Gewijzigd op 22/03/2012 10:34:26 door Ozzie PHP
 
Niels K

Niels K

22/03/2012 16:00:36
Quote Anchor link
Hoi Ozzie,

Zoals beloofd een reactie ;-)

Quote:
Ik heb er eens goed over nagedacht. Op jouw (en voorheen ook mijn) manier voer je ten eerste meer controles uit dan wanneer je het resultaat direct teruggeeft.


Dat maakt in mijn ogen in dit geval niet uit. Dit is gewoon noodzakelijk.

Quote:
Ten tweede, stel een user moet inloggen en bij een geslaagde inlogpoging wordt het userobject in de registry geplaatst. Nu haal ik op een andere pagina de user op, maar deze is niet aanwezig in de registry omdat de inlogpoging niet geslaagd is. BOEM, er wordt een exception gegooid! Niet handig, want ik wil in dit geval gewoon een nette melding tonen dat de gebruiker eerst moet inloggen! Hoe lossen we dat op? Toch maar een exists functie eromheen bouwen en pas daarna de user ophalen. Nog meer controles!


Dat is een foute denkwijze best Ozzie. Ik ben van mening dat je een user niet in het register moet stoppen. Die moet het sessie object onthouden.

Per functie moet je controleren of een user daadwerkelijk ingelogd is. Niet of hij in de storage zit.

Bijv:

Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
<?php

if (Auth::getInstance()->hasIdentity()) {
    // Er is dus iemand ingelogd.
}

?>


Snap je? Je moet leren de verantwoordelijkheden te abstraheren. Een Register heeft niets te maken met het feit of een gebruiker daadwerkelijk ingelogd is nietwaar? Een register moet zich druk maken om het feit dat hij / zij dingen moet opslaan en weer moet retourneren. Wat hij precies opslaat, retourneert? Tzal hem een worst zijn!

;-)
 
Ozzie PHP

Ozzie PHP

22/03/2012 16:05:48
Quote Anchor link
Niels, thanks voor je reactie ;)

Dat van die user was een voorbeeld. Ik zal m'n voorbeeld aanpassen.

Stel ik wil een user opslaan in de registry, maar dit doe ik pas als die user is ingelogd...

Ergens anders wil ik die user weer uit de registry halen. Ik controleer of de user is ingelogd. Ik weet dat als hij is ingelogd er een user object in de registry aanwezig is, dus dan haal ik dat direct uit de registry. Ik hoef dan niet eerst nog te controleren of het aanwezig is.

Snap je? Mijn stelling is dus dat op het moment dat ik iets uit de registry ophaal ik ervan overtuigd moet zijn dat datgene ook in de registry aanwezig is. Indien ik dat niet zeker weet, dan pas gebruik ik de exists functie.
 
Niels K

Niels K

22/03/2012 16:08:10
Quote Anchor link
Hoi Ozzie,

Geef mij eens een situatie waarin dit soort dingen voorkomen? Ik kan zo snel geen (goede) situatie bedenken.

Ik heb het bovenstaande nog niet meegemaakt eigenlijk. Terwijl ik toch de manier gebruik die ik hierboven heb omschreven.

Niels
 
Ozzie PHP

Ozzie PHP

22/03/2012 16:12:59
Quote Anchor link
Voorbeeld: in mijn "bootstrap" (of hoe je dat ook noemt) plaats in een configuratie-object met instellingen in de registry.

Als ik nu iets nodig heb uit de configuratie doe ik simpelweg:
$value = Registry::get('config')->my_value;

Dit is puur even een voorbeeldje he. Aangezien ik weet dat de config altijd aanweig is in de registry is het niet nodig om eerst een controle uit te voeren. Dat is eigenlijk wat ik bedoel te zeggen.

Pas op het moment dat ik niet zeker ben of een waarde aanwezig is in de registry pas dan bouw ik een extra controle in:

Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
<?php
if (Registry::exists('misschienbestaatdit')) {
  $value = Registry::get('misschienbestaatdit');
}

?>


Snap je?
 
Niels K

Niels K

22/03/2012 16:16:48
Quote Anchor link
Ja in snap volkomen wat jij bedoeld.

Jij retourneert nu het configuratie object en aan het configuratie object vraag je nu die 'my_value'. Het register hoeft hier dus niets van af te weten. In de __get van het configuratie object moet je afvangen of die value daadwerkelijk bestaat. (ik neem overigens aan dat je de key bedoeld ;-))

Zoals ik al zei kan ik geen situatie bedenken waarin ik niet weet of een object daadwerkelijk in het register zit.

Snap je ? ;-)

Niels
 
Ozzie PHP

Ozzie PHP

22/03/2012 16:20:29
Quote Anchor link
"Jij retourneert nu het configuratie object en aan het configuratie object vraag je nu die 'my_value'. Het register hoeft hier dus niets van af te weten."

CORRECT

"In de __get van het configuratie object moet je afvangen of die value daadwerkelijk bestaat. (ik neem overigens aan dat je de key bedoeld ;-))"

Maar dat afvangen doe ik dus niet omdat ik weet dat de waarde die ok opvraag bestaat.

"Zoals ik al zei kan ik geen situatie bedenken waarin ik niet weet of een object daadwerkelijk in het register zit."

CORRECT, in de praktijk zal dit ook niet vaak voorkomen, dus.... daarom heb ik geen controle in de get functie :)))))

Snap je?
 
Niels K

Niels K

22/03/2012 16:36:23
Quote Anchor link
Quote:
Maar dat afvangen doe ik dus niet omdat ik weet dat de waarde die ok opvraag bestaat.

In het configuratie object zou ik daar iets voorzichtiger mee zijn. Dit omdat je in de loop van het project ook nog configuratie kan aanmaken. (of je moet er voor zorgen dat dit niet kan)

In het register is dat dan inderdaad niet nodig, your right ;-) Ik heb even naar Zend Framework gekeken, maar daar zie ik wel dat het register mijn bovenstaande manier toepast. (iets anders, maar komt op hetzelfde neer)

This en blijft een persoonlijke keuze ;-)
 
Ozzie PHP

Ozzie PHP

22/03/2012 16:39:38
Quote Anchor link
Hehe, oke... de praktijk zal leren of het de juiste keuze is. Nadeel is dat ik goed moet opletten. Voordeel is dat het me heel veel onoodige controles scheelt :)
 
Ozzie PHP

Ozzie PHP

29/03/2012 16:55:03
Quote Anchor link
Hallo mensen, in navolging van een opmerking van Pim (klik) vraag ik me af in hoeverre je classes moet "dicht timmeren".

Ik heb een paar classes (bijv. de Application / bootstrap class en een Autoloader class) waarin ik een statische variabele set nadat ze 1x geconstruct zijn. Als je ze daarna nog een keer probeert te constructen wordt er een exception gegooid. Ik heb dit gedaan om te voorkomen dat iemand zo'n class ooit per ongeluk zal gaan gebruiken... want zoals je wel zult begrijpen gebruik je een bootstrap class in je project maar 1x en kun je een bootstrap niet meerdere keren gebruiken. Echter, het "dicht timmeren" van zo'n class zodat je deze niet dubbel kan gebruiken zorgt voor extra code en de code wordt er ook niet echt niet netter op. Maar goed, het voorkomt dus wel dat iemand een class dubbel gebruikt als dat niet mag.

Wat vinden jullie hiervan? Goed of niet?

(Aub geen opmerkingen over singletons, want daar gaat mijn vraag niet over. Het gaat mij er puur om of je een programmeur of jezelf moet beschermen tegen het mogelijk dubbel gebruiken van een class die daar niet voor bedoeld is.)
 
Ozzie PHP

Ozzie PHP

30/03/2012 17:58:42
Quote Anchor link
Is er iemand die mijn bovenstaande vraag durft te beantwoorden? Ik heb hier een klein voorbeeldje (van de construct functie) dat aangeeft hoe ik er voor zorg dat de Application class slechts eenmaal gebruikt kan worden:

Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
8
9
<?php
public function __construct() {
  if (self::$_application_started) {
    // gooi een Exception, toon een melding dat de Application class
    // slechts eenmaal gebruikt kan worden

  }
  self::$_application_started = true;
}

?>
 
Mark PHP

Mark PHP

30/03/2012 18:17:51
Quote Anchor link
__construct en __clone private maken, en via een statische methode getInstance o.i.d. toegang verlenen.

Toch even een opmerking, voor als iemand dit topic ooit eens doorleest:
Ik meen me te herinneren dat al eens gezegd is dat je eigenlijk nooit een klasse hebt die maar één keer gebruikt *mag* worden. Probeer dit soort programmeertrucjes dan ook te vermijden.
Gewijzigd op 30/03/2012 18:19:13 door Mark PHP
 
Ozzie PHP

Ozzie PHP

30/03/2012 19:29:53
Quote Anchor link
Mark, dankjewel voor je reactie. In dit geval gaat het om een class waarvan ik niet wil dat ie meerdere keren gebruikt wordt. De application class is een bootstrap die een aantal functies doorloopt en aan het eind van de rit wordt dan de pagina getoond. Natuurlijk kan ik de getInstance methode gebruiken, maar ik wil dus uberhaupt niet dat na de eerte keer functies in die class worden uitgevoerd. Met getInstance kun je die functies nog steeds gewoon gebruiken.

Maar de vraag is dus of via trucjes ervoor moet gaan zorgen dat die class maar 1x gebruikt kan worden... of moet je dat aan een programmeur overlaten en hopen dat die snugger genoeg is om die class niet nog een keer te gebruiken?
 
Mark PHP

Mark PHP

30/03/2012 20:23:36
Quote Anchor link
Wat dan nog? Probeer niet jouw denkwijze op te dringen aan andere programmeurs. Dus: als de programmeur per-se twee klassen wil maken, moet 'ie dat lekker doen. Zolang je documentatie goed is, is er niets aan de hand. En werk je in een team, dan heb je zoiets als een Software Design Specification, waarin precies staat hoe er gewerkt workt.

Tot slot: gebruik NOOIT trucjes als je programeert.
 
Ozzie PHP

Ozzie PHP

30/03/2012 20:28:24
Quote Anchor link
"Probeer niet jouw denkwijze op te dringen aan andere programmeurs."

Dit is dus min of meer mijn vraag... in hoeverre moet je middels code voorkomen dat een programmeur verkeerde dingen doet?

Liever gooi ik ook al die controles eruit, want dat vind ik een stuk netter staan, maar het gaat mij vooral om de gedachte erachter:

"Moet ik als ik aan het programmeren ben dingen doen om te voorkomen dat een andere programmeur (of ikzelf) in de toekomst bepaalde dingen fout kan doen?"

Of moet je daar gewoon helemaal niet over nadenken en die verantwoordelijkheid volledig aan de programmeur laten?

Toevoeging op 30/03/2012 20:30:59:

Ander voorbeeld:

Stel een programmeur moet ergens als parameter een url prefix invullen, maar ik wil niet dat die prefix begint of eindigt met een slash.

Nu kan ik dit bij de functieomschrijving aangeven, maar in sommige gevallen controleer ik dus ook of de invoer correct is en gooi ik een exception als dit niet het geval is.

Ik doe dit vooral met dingen die makkelijk fout kunnen gaan, maar is zoiets nu wel of niet goed om te doen... ik vind het lastig...
 
Ozzie PHP

Ozzie PHP

05/04/2012 20:18:47
Quote Anchor link
Ola allemaal. Ik zit te denken om mijn extra controles er toch maar uit te slopen en duidelijke instructies in het commentaar bij een functie te geven.

Stel een pad mag niet eindigen op een slash, dan staat dit in het commentaar bij de functie-omschrijving. Echter, ik controleer het vervolgens ook nog eens via regex. Ik zit er nu dus aan te denken om die regex controle achterwege te laten.

Goed idee?
 

Pagina: « vorige 1 2 3 4 5 volgende »



Overzicht Reageren

 
 

Om de gebruiksvriendelijkheid van onze website en diensten te optimaliseren maken wij gebruik van cookies. Deze cookies gebruiken wij voor functionaliteiten, analytische gegevens en marketing doeleinden. U vindt meer informatie in onze privacy statement.