Programmeringssprog og if-sætningninger - "negative" eller "positive"

froksen
Antal: 412
Tilmeldt:
25-04-2005
User is offline
Programmeringssprog og if-sætningninger - "negative" eller "positive"

Hej alle jer gode mennesker

Jeg har et spørgsmål, som egentlig ikke har specifikt noget at gøre med GNU/Linux. Men i diverse programmeringssprog, nu særlig fokus på C++/Qt, hvad er så "best practice" når man anvender if-sætninger. Er det at anvende den "positive" eller "negative" tilgang.

Altså hvis dette sker, så gør dette - eller at hvis dette ikke sker, da afslut (return). Herunder to simple kodeeksempler (kunne f.eks. være i en metode)

"Positive"

if(a==0)
{
//Gør dette
}

"Negative"

if(a != 0)
{
return;
}

//Gør dette, hvis er nul.

Jeg er bevidst om, at der kan være grunde til at anvende det ene eller det andet. Men er der nogen fordele eller ulemper ved den ene frem for den anden? Nu tænker jeg særligt på memory, og læsbarhed.

På forhånd tak.


denmagisketangopirat
Antal: 136
Tilmeldt:
25-02-2008
User is offline
Jeg mener at have læst et

Jeg mener at have læst et sted at den menneskelige hjerne har nemmest ved at forstå den "positive" logik.

F.eks. manden er høj er bedre end manden er ikke lav.


denmagisketangopirat
Antal: 136
Tilmeldt:
25-02-2008
User is offline
Nu nærlæste jeg lige dit

Nu nærlæste jeg lige dit spørgsmål igen og i dit eksempel handler nok ikke så meget om positiv og negativ logik, men mere om flere "return" i en funktion.

Se derfor denne:
http://softwareengineering.stackexchange.com/quest...


johnnyec
Antal: 44
Tilmeldt:
20-01-2008
User is offline
re: Jeg mener at have læst et

Noget er der nok om det. Jeg skulle på et tidspunkt besvare en spørgeskemaundersøgelse fra kræftens bekæmpelse. Der skulle jeg på en liste med 20 ting vælge de 10 jeg syntes var _mindst_ vigtige.

Det kortsluttede min hjerne så meget at jeg efter et par forsøg helt opgav at besvare undersøgelsen :-o


froksen
froksen's picture
Antal: 412
Tilmeldt:
25-04-2005
User is offline
@denmagisketangopirat, det

@denmagisketangopirat, det giver vel egentlig OK mening, at den positive tilgang er lettere læselig egentlig. Kan være, at man skal anvende det lidt mere :)
Men ja, mit eksempel er nok (kan jeg se) ret meget som i det link du har henvist til. Så det kigger jeg lige lidt nærmere på. :)


Kristho
Kristho's picture
Antal: 1270
Tilmeldt:
21-02-2008
User is offline
Det er et lidt svært

Det er et lidt svært spørgsmål, fordi det ikke som sådan handler om hvorvidt man bruger den positive eller den negative tilgang.

Min holdning er at man skal vurdere det i hvert enkelt tilfælde. Det kommer an på om man er tilhænger af at returnere hurtigt eller returnere én gang.

f.eks.:

public int CalculateSomething(int x, int y) {
    if (x == 0) {
        return 0;
    }
    if (y == 0) {
        return 0;
    }

    return x + y;
}

Her har jeg lavet "guard-clauses", så vi hurtigst muligt får returneret fra funktionen, hvis parametrene ikke overholder vores pre-conditions (at x og y ikke må være 0). Det gør det også lettere at forstå når man læser koden, fordi man kan tage tingene ét statement ad gangen i stedet for at skulle jonglere med ANDs og ORs.

Men når det så er sagt, så tror jeg det er rigtigt, at den positive tilgang er nemmere at forstå - for mig er det bare det mindste af problemerne :D

(Bemærk: Jeg er normalt C# udvikler, så min kode er ikke C++ - men tror du fanger pointen alligevel ;) )


thorbjørntux
thorbjørntux's picture
Antal: 698
Tilmeldt:
30-04-2007
User is offline
Early returns

Kristho har en pointe her, for det er et 'filosofi'-spørgsmål. Dog vil jeg gerne reklamere for early returns (i C++)

Jeg synes at

if (a) {
  calcb(a);
  if (!b) {
    for (something) {

    }
  }
}

er rodet i forhold til f.eks

if (!a)
  return;
calcb(a);
if (b)
  return;
for (something) {

}

Min påstand er at det med early returns er lettere at matche braces og læse koden ...

PS: C++ og Qt .... fantastisk valg ;)