Heftig udvikler-debat: Performer C++ virkelig bedst?

En intern Google-test af programmeringssprogs performance skaber stor udvikler-debat. C++ har markant bedre performance end Java, er konklusionen. Men er det rigtigt?

Artikel top billede

Hvilket programmeringssprog er "det bedste"?
Det er en diskussion, som udviklere kan bruge lang tid på.

Ligesom diskussionen om hvilket programmeringssprog, der er det mest populære (der er ikke nødvendigvis en sammenhæng mellem bedst og mest populær).

Men hvordan vurderes hvilket programmeringssprog, der er "bedst"?

Hvilket sprog er bedst til at implementere en algoritme?

En Google-ansat, Robert Hundt, gjorde et forsøg ved at prøve at måle hvilket programmeringssprog, der giver den bedste performance ved implementering af en veldefineret algoritme.

I rapporten "Loop Recognition in C++/Java/Go/Scala" (pdf) sammenlignes performance for implementeringen af en Loop Recognition-algoritme i de fire programmeringssprog C++, Java, Go og Scala.

Den oprindelige test byggede på implementering af algoritmen uden speciel optimering af koden.
 
Efter rapportens forfatter, Robert Hundt, publicerede resultaterne fra testen internt i Google, gik udviklere hos Google i gang med at optimere implementeringen i de enkelte sprog.

C++ er langt det bedste

Efter optimeringen af programmerne i de fire programmeringssprog, er der ingen tvivl i Google-rapportens forfatters sind:

C++ vinder performance-mæssigt.
 
"Med hensyn til performance, så vinder C++ med en stor margin. Det krævede dog også den mest intensive tuning-indsats, hvoraf mange blev udført på et sofistikeringsniveau, som ikke ville være tilgængelige for den gennemsnitlige programmør," hedder det i rapporten.

Java-program ikke optimeret i samme grad som C++

Rapporten blev lagt ud på nettet, og nørd-sitet Slashdot fik øje på den, hvorefter en heftig debat blandt Slashdot-læsere udfoldede sig.

Var C++ virkelig så meget bedre end Java?
 
Formentlig ikke.

Der var nemlig forskel på hvor meget optimering, der blev foretaget af algoritmeimplementeringen i de enkelte sprog.
 
Google-udvikleren Jeremy Manson stod for Java-optimeringen, og på sin blog tager han afstand fra rapportens konklusion.
 
Jeremy Manson påpeger, at han kun gjorde nogle enkelte ting ved Java-koden og ikke optimerede den helt.
 
Afhænger af programmørens kendskab til sproget
Samtidig var den oprindelige implementering i Java skrevet af Robert Hundt, der er nybegynder i Java, mens han har godt kendskab til C++.

Derfor var der fra starten stor forskel på kvaliteten og dermed performance af algoritme-implementeringen i de to sprog.
 
Det ses blandt andet af valg af datastruktur, der har stor indflydelse på, om en algoritme-implementering performer godt eller dårligt. Den slags valg afhænger af udviklerens kendskab og erfaring med programmeringssproget og ikke mindst de tilhørende libraries.

"Ud over de collections-relaterede fixes jeg lavede (som beskrevet i rapporten), benyttede testen sig også af en HashMap(Type, Integer), hvor det blot skulle have gemt en primitiv int som Type; den benyttede også en LinkedList, hvor det burde have været en ArrayDeque," skriver Jeremy Manson blandt andet.

Jeremy Manson mener, at testens konklusion ikke bør være, at "Java er langsomt, men at man kan skrive dårlig kode i ethvert sprog (med undskyldninger til Robert, som er en af de smarteste fyre, men han er ikke Java-programmør)."

Skaden er sket

Den slags forbehold er dog ikke hvad, der bliver rapporteret på diverse it-sites. Som datalogi-professoren Sebastiano Vigna skriver i en kommentar til Jeremy Mansons blog:

"Men hvad, der er slemt - rigtigt, rigtigt slemt - er, at nettet er oversvømmet med it-blogs og -sites, som siger, at 'C++ er klar vinder i Google-sprogtest'.

Det er latterligt. Det er ikke Google, som lavede testen, det er en enkelt Google-ansat. Og testen er meget fejlbehæftet. Og konklusionen er forkert."

Trods kritikken bør du læse rapporten og Jeremy Mansons blog, hvis du er udvikler. Der er masser af guldkorn af hente, når du får hele sammenhængen.

Læs også eventuelt Slashdot-kommentarerne. Der er også et par guldkorn og som altid god nørd-humor.

Læses lige nu

    En kaotisk verden kræver stærk cybersikkerhed, resiliens og digital suverænitet

    Mød David Heinemeier, Flemming Splidsboel Hansen, Casper Klynge, Rasmus Knappe, Jens Myrup Pedersen og forfattere som fhv. jægersoldat Thomas Rathsack og adfærdsforsker Henrik Tingleff.

    Computerworld afholder d. 4. og 5. november Cyber Security Festival i København - med fokus på sikkerhed, resiliens og digital suverænitet. Det er helt gratis - men reserver din plads allerede nu.

    Hele programmet er online lige nu - og du kan reservere din gratis plads lige her - jeg håber vi ses! 

    Lars Jacobsen

    Chefredaktør på Computerworld

    Se alle Lars's artikler her

    Netcompany A/S

    Test Consultant

    Nordjylland

    Netcompany A/S

    Managing Architect

    Midtjylland

    Netcompany A/S

    IT Manager

    Nordjylland

    Netcompany A/S

    Managing Architect

    Nordjylland

    Navnenyt fra it-Danmark

    Enterprise Rent-A-Car har pr. 1. september 2025 ansat Christian Kamper Garst som Senior Key Account Manager. Han skal især beskæftige sig med at vinde markedsandele i hele Norden som led i en storstilet turnaround-strategi. Han kommer fra en stilling som Salgsdirektør hos Brøchner Hotels. Nyt job

    Christian Kamper Garst

    Enterprise Rent-A-Car

    Netip A/S har pr. 19. august 2025 ansat Marck Stadel Klaris som Datateknikerelev ved netIP's kontor i Herning. Nyt job
    Norriq Danmark A/S har pr. 1. september 2025 ansat Alexander Bendix som Consultant. Han skal især beskæftige sig med tilføre nye, friske perspektiver og værdifuld viden til NORRIQS Data & AI-afdeling. Nyt job

    Alexander Bendix

    Norriq Danmark A/S

    Sentia har pr. 1. oktober 2025 ansat Morten Jørgensen som Chief Commercial Officer. Han skal især beskæftige sig med udbygning af Sentias markedsposition og forretningsområder med det overordnede ansvar for den kommercielle organisation. Han kommer fra en stilling som Forretningsdirektør hos Emagine. Nyt job