Kezdőoldal » Számítástechnika » Programozás » Melyik feltételvizsgálat fut...

Melyik feltételvizsgálat fut le gyorsabban?

Figyelt kérdés

Tegyük fel, hogy van egy konkrét eset, ahol ha az "x" változó értéke nagyobb mint 5, akkor minden esetben pontosan 6 lesz. Ebből következik, hogy a végeredmény szempontjából az alábbiak közül mindkettő jó megoldás:

if (x > 5)

if (x == 6)

A kérdésem az, hogy a relációnak vagy az egyenlőségnek egyszerűbb a kiértékelése (és így fut le gyorsabban)?


Tisztában vagyok vele, hogy a legtöbb esetben ez teljesen lényegtelen, de most szeretném a lehető leghatékonyabb kódot írni, és előre kérlek titeket, hogy a kérdéssel foglalkozzatok, és ne azzal, hogy van-e bármi értelme. Köszi!:)


2017. ápr. 3. 16:08
1 2
 1/17 anonim ***** válasza:
26%

Meghívod ezt az ellenőrzést a programodban másodpercenként egymilliószor?

Ha nem, akkor teljesen mindegy, nem így kell optimalizálni.

2017. ápr. 3. 16:16
Hasznos számodra ez a válasz?
 2/17 anonim ***** válasza:

Az hogy mi történik pontosan a háttérben az nyilván nyelvfüggő.


Pythonban pl. ha a két feltételt megvizsgálod a timeit-tal, akkor azt kapod, hogy mindkettő nagyjából 110 ns alatt fut le.


C-ben, ha belenézel az assembly-be, akkor az látod, hogy az egyik egy cmp+jle, a másik egy cmp+jne utasításpárosra képződik le, melyek nem különböznek lényegesen egymástól.


"Programmers waste enormous amounts of time thinking about, or worrying about, the speed of noncritical parts of their programs, and these attempts at efficiency actually have a strong negative impact when debugging and maintenance are considered. We should forget about small efficiencies, say about 97% of the time: premature optimization is the root of all evil. Yet we should not pass up our opportunities in that critical 3%." ~ Donald Knuth

2017. ápr. 3. 16:55
Hasznos számodra ez a válasz?
 3/17 anonim ***** válasza:
55%
Az egyenlőség vizsgálat egyértelműen gyorsabb.
2017. ápr. 3. 17:13
Hasznos számodra ez a válasz?
 4/17 A kérdező kommentje:
Az első válaszolónak minden bizonnyal szövegértési problémái vannak, a többieknek viszont köszönöm szépen!
2017. ápr. 3. 18:06
 5/17 A kérdező kommentje:
engem csak az elmélet érdekelt, szó sincs arról, hogy ettől várom, hogy gyors legyen egy program
2017. ápr. 3. 18:08
 6/17 SimkoL ***** válasza:

500 for ciklus 0-tól 268435455-ig, - if i = 268435454 vagy if i = 268435455, eredmény, ezredmásodpercekben, egy lassú gépen, Win7, Delphi 7:

Egyenlo: 155003

Nagyobb: 150778

2017. ápr. 3. 18:17
Hasznos számodra ez a válasz?
 7/17 SimkoL ***** válasza:
* if i > 268435454 vagy if i = 268435455,
2017. ápr. 3. 18:19
Hasznos számodra ez a válasz?
 8/17 anonim ***** válasza:

@Simkol: Ezt nem így szokás számolni, pláne windows alatt. :)))

Ezzel csak kinevetteted magad.

2017. ápr. 3. 18:50
Hasznos számodra ez a válasz?
 9/17 SimkoL ***** válasza:

Ezt mindenki tudja reprodukálni, bármilyen nyelven és tud következtetést levonni. Ez nem szakmai fórum, de ha gondolod essél neki és magyarázd el, hogy hogyan kellene, olyan embereknek, akiknek még egy ciklus is gondot okoz.

Egy párszor már elmondtam itt is, hogy a kérdés szintjéhez kell a választ igazítani.

Ha gondolod menjünk át a Prog.hu-ra és vitassuk meg ott is.

2017. ápr. 3. 19:14
Hasznos számodra ez a válasz?
 10/17 anonim ***** válasza:

"Egy párszor már elmondtam itt is, hogy a kérdés szintjéhez kell a választ igazítani."


Ez a te vélerményed. Az enyém meg ettől eltér.

Ha egy 10 éves megkérdezi tőlem, hogy mennyi 320-szor 192, akkor sem azt válaszolom neki, hogy sok.


Ez a kérdező pedig kifejezetten normális volt, abszolút nem mutatta az itt oly gyakran megnyilvánuló "debilitás" jeleit.

2017. ápr. 3. 19:29
Hasznos számodra ez a válasz?
1 2

Kapcsolódó kérdések:




Minden jog fenntartva © 2025, www.gyakorikerdesek.hu
GYIK | Szabályzat | Jogi nyilatkozat | Adatvédelem | Cookie beállítások | WebMinute Kft. | Facebook | Kapcsolat: info(kukac)gyakorikerdesek.hu

A weboldalon megjelenő anyagok nem minősülnek szerkesztői tartalomnak, előzetes ellenőrzésen nem esnek át, az üzemeltető véleményét nem tükrözik.
Ha kifogással szeretne élni valamely tartalommal kapcsolatban, kérjük jelezze e-mailes elérhetőségünkön!