C ++ - C++

C ++
ISO C++ Logo.svg
Logo C ++ schválené standardem C ++
ParadigmataMulti-paradigma: procesní, funkční, objektově orientovaný, obecný, modulární
RodinaC
NavrhlBjarne Stroustrup
VývojářISO / IEC JTC1 (Společná technická komise 1) / SC22 (subkomise 22) / WG21 (pracovní skupina 21)
Poprvé se objevil1985; Před 35 lety (1985)
Stabilní uvolnění
C ++ 17 (ISO / IEC 14882: 2017) / 1. prosince 2017; před 3 lety (2017-12-01)
Náhled verze
C ++ 20
Psací disciplínaStatický, jmenovaný, částečně odvozeno
OSNejvětší major
Přípony názvu souboru.C, .cc, .cpp, .cxx, .c ++, .h, .hh, .hpp, .hxx, .h ++
webová stránkaisocpp.org
Hlavní, důležitý implementace
GCC, LLVM Clang, Microsoft Visual C ++, Embarcadero C ++ Builder, Překladač Intel C ++, IBM XL C ++, EDG
Ovlivněno
Ada,[1] ALGOL 68, C, CLU,[1] ML, Mesa,[1] Modula-2,[1] Simula, Pokec[1]
Ovlivněno
Ada 95, C#,[2] C99, Kaple,[3] Clojure,[4] D, Jáva,[5] JS ++,[6] Lua, Nim,[7] Perl, PHP, Krajta,[8] Rez, 7. semeno

C ++ (/ˌsˌstrlʌsˈstrlʌs/) je univerzální programovací jazyk vynalezl Bjarne Stroustrup jako rozšíření Programovací jazyk C., nebo „C s Třídy ". Jazyk se postupem času významně rozšířil a moderní C ++ se nyní rozšířil." objektově orientovaný, obecný, a funkční funkce kromě zařízení pro nízká úroveň Paměť manipulace. Je téměř vždy implementován jako kompilovaný jazyk a mnoho prodejců poskytuje Překladače C ++, včetně Free Software Foundation, LLVM, Microsoft, Intel, Věštec, a IBM, takže je k dispozici na mnoha platformách.[9]

C ++ byl navržen s předpojatostí vůči programování systému a vložený, software omezený na zdroje a velké systémy, s výkon, účinnost a flexibilita použití, jak zdůrazňuje jeho design.[10] C ++ byl také shledán užitečným v mnoha dalších kontextech, přičemž hlavními silnými stránkami jsou softwarová infrastruktura a aplikace omezené zdroji,[10] počítaje v to desktopové aplikace, videohry, servery (např. elektronický obchod, webové vyhledávání nebo SQL servery) a aplikace kritické z hlediska výkonu (např. telefonní spínače nebo vesmírné sondy ).[11]

C ++ je standardizováno Mezinárodní organizace pro normalizaci (ISO), přičemž nejnovější standardní verze byla ratifikována a zveřejněna ISO v prosinci 2017 jako ISO / IEC 14882: 2017 (neformálně známý jako C ++ 17 ).[12] Programovací jazyk C ++ byl původně standardizován v roce 1998 jako ISO / IEC 14882: 1998, který byl poté změněn C ++ 03, C ++ 11 a C ++ 14 standardy. Aktuální C ++ 17 standard je nahrazuje novými funkcemi a rozšířeným standardní knihovna. Před počáteční standardizací v roce 1998 vyvinul C ++ dánský počítačový vědec Bjarne Stroustrup na Bell Labs od roku 1979 jako rozšíření Jazyk C.; chtěl efektivní a flexibilní jazyk podobný jazyku C, který také poskytoval funkce na vysoké úrovni pro organizaci programu.[13] Od roku 2012 má C ++ tříletý plán vydání,[14] s C ++ 20 další plánovaný standard (a poté C ++ 23 ).[15]

Dějiny

Bjarne Stroustrup, tvůrce C ++, ve své kanceláři AT&T New Jersey c. 2000

V roce 1979 Bjarne Stroustrup, Dán počítačový vědec, začal pracovat na „C s Třídy", předchůdce C ++.[16] Motivace pro vytvoření nového jazyka vycházela ze Stroustrupových zkušeností s programováním jeho disertační práce. Stroustrup to zjistil Simula měl funkce, které byly velmi užitečné pro vývoj velkého softwaru, ale jazyk byl příliš pomalý pro praktické použití BCPL byl rychlý, ale příliš nízký, aby byl vhodný pro vývoj velkého softwaru. Když začal pracovat Stroustrup AT&T Bell Labs, měl problém analyzovat UNIX jádro s ohledem na distribuované výpočty. Vzpomínka na jeho Ph.D. zkušenosti, Stroustrup se rozhodl zlepšit C jazyk s Simula -jako funkce.[17] C byl vybrán, protože byl univerzální, rychlý, přenosný a široce používaný. Kromě vlivů C a Simuly ovlivnily tento nový jazyk i jiné jazyky ALGOL 68, Ada, CLU a ML.

Zpočátku Stroustrupovo „C with Classes“ přidalo funkce do kompilátoru C, včetně Cpre třídy, odvozené třídy, silné psaní, vložka a výchozí argumenty.[18]

V roce 1982 začal Stroustrup vyvíjet nástupce jazyka C s Classes, kterému dal název „C ++“ (++ být operátor přírůstku v C) poté, co prošel několika dalšími jmény. Byly přidány nové funkce, včetně virtuální funkce, název funkce a přetížení operátora, Reference, konstanty, typově bezpečné přidělení volné paměti (nové / odstranit), vylepšená kontrola typu a jednořádkové komentáře ve stylu BCPL se dvěma lomítky (//). Dále Stroustrup vyvinul nový samostatný kompilátor pro C ++, Cfront.

V roce 1984 Stroustrup implementoval první knihovnu vstupů a výstupů proudu. Myšlenku poskytnout výstupní operátor namísto pojmenované výstupní funkce navrhl Doug McIlroy[1] (kdo předtím navrhoval Unixové trubky ).

V roce 1985, první vydání Programovací jazyk C ++ byl vydán, což se stalo definitivní referencí pro jazyk, protože dosud neexistovala oficiální norma.[19] První komerční implementace C ++ byla vydána v říjnu téhož roku.[16]

V roce 1989 vyšlo C ++ 2.0, následované aktualizovaným druhým vydáním Programovací jazyk C ++ v roce 1991.[20] Nové funkce v 2.0 zahrnovaly vícenásobnou dědičnost, abstraktní třídy, statické členské funkce, const členské funkce a chránění členové. V roce 1990 Anotovaná referenční příručka C ++ byl publikován. Tato práce se stala základem pro budoucí standard. Včetně pozdějších funkcí šablony, výjimky, jmenné prostory, Nový obsazení a Booleovský typ.

Kvíz o funkcích C ++ 11 uvedený v Paříži v roce 2015

V roce 1998 vyšlo C ++ 98, standardizující jazyk, a menší aktualizace (C ++ 03 ) byla vydána v roce 2003.

Po C ++ 98 se C ++ vyvíjel relativně pomalu, dokud v roce 2011 C ++ 11 byl vydán standard, který přidal řadu nových funkcí, dále rozšířil standardní knihovnu a poskytl programátorům C ++ více možností. Po nezletilém C ++ 14 aktualizace vydaná v prosinci 2014, byly v roce představeny různé nové přírůstky C ++ 17.[21] Standard C ++ 20 byl technicky dokončen v únoru 2020,[22] a návrh byl schválen 4. září 2020; očekává se, že bude zveřejněno do konce roku 2020.[23][24]

Od roku 2019 C ++ je nyní čtvrtým nejpopulárnějším programovacím jazykem Jáva, C a Krajta.[25][26]

3. ledna 2018 byl Stroustrup vyhlášen vítězem soutěže Cena Charlese Starka Drapera pro strojírenství, „pro konceptualizaci a vývoj programovacího jazyka C ++“.[27]

Etymologie

Podle Stroustrupa „název znamená evoluční povahu změn oproti C“.[28] Toto jméno je připsáno Ricku Mascittimu (polovina roku 1983)[18] a byl poprvé použit v prosinci 1983. Když byl Mascitti v roce 1992 neformálně dotazován na pojmenování, uvedl, že byl uveden v jazyk ve tváři duch. Název pochází z C. ++ operátor (který přírůstcích the hodnota a proměnná ) a obyčejný konvence pojmenování použití „+“ k označení vylepšeného počítačového programu.

Během vývojového období C ++ byl jazyk označován jako „nový C“ a „C s třídami“[18][29] před získáním konečného názvu.

Filozofie

Po celý život C ++ se jeho vývoj a vývoj řídil souborem principů:[17]

  • Musí být poháněn skutečnými problémy a jeho funkce by měly být okamžitě užitečné v programech reálného světa.
  • Každá funkce by měla být implementovatelná (s rozumně zřejmým způsobem, jak to udělat).
  • Programátoři by měli mít možnost zvolit si vlastní styl programování a tento styl by měl být plně podporován v C ++.
  • Povolení užitečné funkce je důležitější než zabránění každému možnému zneužití C ++.
  • Měl by poskytovat prostředky pro organizaci programů do samostatných, dobře definovaných částí a poskytovat prostředky pro kombinování samostatně vyvinutých částí.
  • Žádné implicitní porušení typový systém (ale povolte výslovná porušení, tj. výslovně požadovaná programátorem).
  • Typy vytvářené uživateli musí mít stejnou podporu a výkon jako vestavěné typy.
  • Nepoužívané funkce by neměly negativně ovlivnit vytvořené spustitelné soubory (např. S ​​nižším výkonem).
  • Pod C ++ by neměl být žádný jazyk (kromě montážní jazyk ).
  • C ++ by měl fungovat společně s dalšími existujícími programovací jazyky, spíše než podporovat své vlastní oddělené a nekompatibilní programovací prostředí.
  • Pokud záměr programátora není znám, umožněte programátorovi, aby jej určil pomocí ručního ovládání.

Standardizace

Scéna během zasedání Výboru pro standardy C ++ ve Stockholmu v roce 1996
C ++ standardy
RokC ++ StandardNeformální název
1998ISO / IEC 14882: 1998[30]C ++ 98
2003ISO / IEC 14882: 2003[31]C ++ 03
2011ISO / IEC 14882: 2011[32]C ++ 11, C ++ 0x
2014ISO / IEC 14882: 2014[33]C ++ 14, C ++ 1 rok
2017ISO / IEC 14882: 2017[12]C ++ 17, C ++ 1z
2020být odhodlánC ++ 20,[21] C ++ 2a

C ++ je standardizováno pomocí ISO pracovní skupina známá jako JTC1 / SC22 / WG21. Dosud vydala pět revizí standardu C ++ a v současné době pracuje na další revizi, C ++ 20.

V roce 1998 pracovní skupina ISO poprvé standardizovala C ++ jako ISO / IEC 14882: 1998, který je neformálně známý jako C ++ 98. V roce 2003 vydala novou verzi standardu C ++ nazvanou ISO / IEC 14882: 2003, který opravil problémy identifikované v C ++ 98.

Další velká revize standardu byla neformálně označována jako „C ++ 0x“, ale byla vydána až v roce 2011.[34] C ++ 11 (14882: 2011) zahrnoval mnoho dodatků jak k základnímu jazyku, tak ke standardní knihovně.[32]

V roce 2014 C ++ 14 (také známý jako C ++ 1y) byl vydán jako malé rozšíření pro C ++ 11, obsahující hlavně opravy chyb a drobná vylepšení.[35] Postupy návrhu mezinárodního standardního hlasování byly dokončeny v polovině srpna 2014.[36]

Po C ++ 14, zásadní revize C ++ 17, neformálně známý jako C ++ 1z, byl dokončen výborem ISO C ++ v polovině července 2017 a byl schválen a zveřejněn v prosinci 2017.[37]

V rámci procesu standardizace ISO také publikuje technické zprávy a specifikace:

  • ISO / IEC TR 18015: 2006[38] o používání C ++ ve vestavěných systémech a o dopadech na výkon funkcí jazyka C ++ a knihoven,
  • ISO / IEC TR 19768: 2007[39] (také známý jako C ++ technická zpráva 1 ) na rozšířeních knihoven většinou integrovaných do C ++ 11,
  • ISO / IEC TR 29124: 2010[40] na speciální matematické funkce,
  • ISO / IEC TR 24733: 2011[41] na desetinná plovoucí desetinná čárka aritmetický,
  • ISO / IEC TS 18822: 2015[42] na standardní knihovně souborového systému,
  • ISO / IEC TS 19570: 2015[43] na paralelní verze standardních knihovních algoritmů,
  • ISO / IEC TS 19841: 2015[44] na softwaru transakční paměť,
  • ISO / IEC TS 19568: 2015[45] na nové sadě rozšíření knihoven, z nichž některé jsou již integrovány do C ++ 17,
  • ISO / IEC TS 19217: 2015[46] na C ++ koncepty, Integrovaný do C ++ 20
  • ISO / IEC TS 19571: 2016[47] na rozšíření knihovny pro souběžnost
  • ISO / IEC TS 19568: 2017[48] na nové sadě univerzálních rozšíření knihoven
  • ISO / IEC TS 21425: 2017[49] na rozšíření knihovny pro rozsahy, integrovaný do C ++ 20
  • ISO / IEC TS 22277: 2017[50] na korutinách
  • ISO / IEC TS 19216: 2018[51] v síťové knihovně
  • ISO / IEC TS 21544: 2018[52] na modulech
  • ISO / IEC TS 19570: 2018[53] na nové sadě rozšíření knihoven pro paralelismus

Další technické specifikace jsou ve vývoji a čekají na schválení, včetně statického odrazu.[54]

Jazyk

Jazyk C ++ má dvě hlavní součásti: přímé mapování hardwarových funkcí poskytovaných primárně podmnožinou C a abstrakce s nulovou režií na základě těchto mapování. Stroustrup popisuje C ++ jako „lehký abstrakční programovací jazyk [navržený] pro vytváření a používání efektivních a elegantních abstrakcí“;[10] a „základem C ++ je nabídka hardwarového přístupu i abstrakce. To, co ji odlišuje od ostatních jazyků, je efektivní.“[55]

C ++ dědí většinu Syntaxe C.. Toto je verze Bjarne Stroustrupa Program Hello world který používá C ++ standardní knihovna streamovat zařízení pro psaní zprávy standardní výstup:[56][57]

1 #zahrnout <iostream>2 3 int hlavní()4 {5     std::cout << "Ahoj světe! n";6 }

Úložiště objektů

Stejně jako v C podporuje C ++ čtyři typy správa paměti: statické objekty s délkou úložiště, objekty s délkou úložiště vláken, objekty s délkou automatického ukládání a objekty s délkou dynamického úložiště.[58]

Statické objekty trvání úložiště

Objekty s trváním statického úložiště jsou vytvořeny dříve hlavní() je zadáno (viz výjimky níže) a zničeno v opačném pořadí po vytvoření hlavní() východy. Přesné pořadí vytvoření není standardem specifikováno (i když jsou zde definována některá pravidla), aby implementacím byla poskytnuta určitá volnost při organizaci jejich implementace. Formálněji mají objekty tohoto typu životnost, která „vydrží po dobu trvání programu“.[59]

Objekty trvání statického úložiště jsou inicializovány ve dvou fázích. Nejprve se provede „statická inicializace“ a pouze po provede se veškerá statická inicializace, provede se „dynamická inicializace“. Při statické inicializaci jsou všechny objekty nejprve inicializovány nulami; poté jsou všechny objekty, které mají konstantní inicializační fázi, inicializovány konstantním výrazem (tj. proměnné inicializované literálem nebo constexpr). Ačkoli to není ve standardu specifikováno, fázi statické inicializace lze dokončit v době kompilace a uložit do datového oddílu spustitelného souboru. Dynamická inicializace zahrnuje veškerou inicializaci objektu provedenou pomocí volání konstruktoru nebo funkce (pokud není funkce označena.) constexpr, v C ++ 11). Pořadí dynamické inicializace je definováno jako pořadí deklarace v kompilační jednotce (tj. Stejný soubor). Nejsou poskytovány žádné záruky ohledně pořadí inicializace mezi kompilačními jednotkami.

Objekty trvání úložiště vláken

Proměnné tohoto typu jsou velmi podobné statickým objektům trvání úložiště. Hlavní rozdíl spočívá v tom, že čas vytvoření je těsně před vytvořením vlákna a destrukce se provádí po připojení vlákna.[60]

Objekty s délkou automatického ukládání

Nejběžnějšími typy proměnných v C ++ jsou místní proměnné uvnitř funkce nebo bloku a dočasné proměnné.[61] Společným rysem automatických proměnných je, že mají životnost omezenou na rozsah proměnné. Jsou vytvořeny a potenciálně inicializovány v místě deklarace (podrobnosti viz níže) a zničeny v zvrátit pořadí vytvoření, když je rozsah ponechán. To se provádí přidělením na zásobník.

Místní proměnné se vytvářejí, když bod provedení prochází bodem deklarace. Pokud má proměnná konstruktor nebo inicializátor, slouží k definování počátečního stavu objektu. Místní proměnné jsou zničeny, když je uzavřen místní blok nebo funkce, ve které jsou deklarovány. C ++ destruktory pro lokální proměnné jsou volány na konci životnosti objektu, což umožňuje disciplínu pro automatickou správu prostředků nazvanou RAII, který je v C ++ široce používán.

Členské proměnné se vytvářejí při vytváření nadřazeného objektu. Členové pole jsou inicializováni od 0 do posledního člena pole v pořadí. Členské proměnné jsou zničeny, když je nadřazený objekt zničen v opačném pořadí než vytvoření. tj. pokud je nadřazený objekt „automatický objekt“, bude zničen, jakmile vyjde z rozsahu, což způsobí zničení všech jeho členů.

Dočasné proměnné jsou vytvořeny jako výsledek vyhodnocení výrazu a jsou zničeny, když byl příkaz obsahující výraz plně vyhodnocen (obvykle na ; na konci prohlášení).

Objekty trvání dynamického úložiště

Tyto objekty mají dynamickou životnost a lze je vytvořit přímo pomocí volání na Nový a výslovně zničen voláním vymazat.[62] C ++ také podporuje malloc a volný, uvolnit, z C, ale nejsou kompatibilní s Nový a vymazat. Použití Nový vrátí adresu do přidělené paměti. Hlavní pokyny C ++ nedoporučují používat Nový přímo pro vytváření dynamických objektů ve prospěch inteligentních ukazatelů make_unique<T> pro jedno vlastnictví a make_shared<T> pro vícenásobné vlastnictví počítané jako reference,[63] které byly představeny v C ++ 11.

Šablony

C ++ šablony umožnit generické programování. C ++ podporuje šablony funkcí, tříd, aliasů a proměnných. Šablony mohou být parametrizovány podle typů, časových konstant kompilace a dalších šablon. Šablony implementuje instance v době kompilace. Chcete-li vytvořit instanci šablony, kompilátoři nahradí konkrétní argumenty parametry šablony, aby vygenerovali konkrétní funkci nebo instanci třídy. Některé substituce nejsou možné; jsou eliminovány zásadou řešení přetížení popsanou frází „Selhání substituce není chyba "(SFINAE). Šablony jsou mocným nástrojem, pro který lze použít generické programování, metaprogramování šablon a optimalizace kódu, ale tato síla znamená cenu. Použití šablony může zvýšit velikost kódu, protože každá instance šablony vytvoří kopii kódu šablony: jednu pro každou sadu argumentů šablony, ale toto je stejné nebo menší množství kódu, které by se vygenerovalo, kdyby byl kód napsán ručně.[64] To je na rozdíl od generických run-time generik viděných v jiných jazycích (např. Jáva ) kde v době kompilace je typ vymazán a je zachováno jedno tělo šablony.

Šablony se liší od makra: zatímco obě tyto jazykové funkce při kompilaci umožňují podmíněnou kompilaci, šablony nejsou omezeny na lexikální substituci. Šablony jsou si vědomy sémantiky a typového systému svého doprovodného jazyka, stejně jako všech definic typů v době kompilace, a mohou provádět operace na vysoké úrovni včetně programového řízení toku na základě vyhodnocení přísně kontrolovaných parametrů. Makra jsou schopná podmíněně ovládat kompilaci na základě předem stanovených kritérií, ale nemohou vytvářet instance nových typů, opakovat nebo provádět hodnocení typů a ve skutečnosti jsou omezena na předkompilaci nahrazení textu a zahrnutí / vyloučení textu. Jinými slovy, makra mohou řídit tok kompilace na základě předdefinovaných symbolů, ale na rozdíl od šablon nemohou nezávisle vytvořit instanci nových symbolů. Šablony jsou nástrojem pro statické zobrazení polymorfismus (viz níže) a generické programování.

Kromě toho jsou šablony kompilačním časovým mechanismem v C ++, který je Turing-kompletní, což znamená, že jakýkoli výpočet vyjádřený počítačovým programem lze v nějaké formě vypočítat pomocí a metaprogram šablony před runtime.

Stručně řečeno, šablona je parametrizovaná funkce nebo třída v době kompilace napsaná bez znalosti konkrétních argumentů použitých k její instanci. Po vytvoření instance je výsledný kód ekvivalentní kódu napsanému speciálně pro předané argumenty. Tímto způsobem šablony poskytují způsob, jak oddělit obecné, široce použitelné aspekty funkcí a tříd (zakódované v šablonách) od konkrétních aspektů (zakódované v parametrech šablony), aniž by došlo ke snížení výkonu kvůli abstrakci.

Objekty

C ++ zavádí objektově orientované programování (OOP) nabízí C. Nabízí třídy, které poskytují čtyři funkce běžně přítomné v jazycích OOP (a některých jiných než OOP): abstrakce, zapouzdření, dědictví, a polymorfismus. Jedním z charakteristických rysů tříd C ++ ve srovnání s třídami v jiných programovacích jazycích je podpora deterministických destruktory, které zase poskytují podporu pro Akvizice zdrojů je inicializace (RAII) koncept.

Zapouzdření

Zapouzdření je skrývání informací, aby se zajistilo, že se datové struktury a operátoři používají, jak bylo zamýšleno, a aby se vývojový model stal jasnějším pro model využití. C ++ poskytuje možnost definovat třídy a funkce jako své primární zapouzdřovací mechanismy. V rámci třídy mohou být členové deklarováni jako veřejní, chránění nebo soukromí, aby explicitně vynutili zapouzdření. Veřejný člen třídy je přístupný jakékoli funkci. Soukromý člen je přístupný pouze funkcím, které jsou členy dané třídy, a funkcím a třídám výslovně uděleným přístupovým oprávněním třídy („přátelé“). Chráněný člen je přístupný členům tříd, které dědí z třídy kromě samotné třídy a všem přátelům.

Objektově orientovaný princip zajišťuje zapouzdření všech a pouze funkcí, které přistupují k interní reprezentaci typu. C ++ podporuje tento princip prostřednictvím členských funkcí a funkcí přátel, ale nevynucuje jej. Programátoři mohou deklarovat části nebo celou reprezentaci typu za veřejnou a je jim povoleno, aby veřejné entity nebyly součástí reprezentace typu. Proto C ++ podporuje nejen objektově orientované programování, ale i další paradigmata rozkladu, jako např modulární programování.

Obecně se považuje za dobrou praxi dělat vše data soukromé nebo chráněné a zveřejnit pouze ty funkce, které jsou součástí minimálního rozhraní pro uživatele třídy. To může skrýt podrobnosti implementace dat, což umožňuje návrháři později zásadně změnit implementaci bez jakékoli změny rozhraní.[65][66]

Dědictví

Dědictví umožňuje jednomu datovému typu získat vlastnosti jiných datových typů. Dědičnost z a základní třída mohou být prohlášeny za veřejné, chráněné nebo soukromé. Tento specifikátor přístupu určuje, zda nesouvisející a odvozené třídy mohou přistupovat k zděděným veřejným a chráněným členům základní třídy. Pouze veřejné dědictví odpovídá tomu, co se obvykle rozumí „dědictvím“. Další dvě formy se používají mnohem méně často. Pokud je specifikátor přístupu vynechán, „třída“ dědí soukromě, zatímco „struktura“ dědí veřejně. Základní třídy mohou být deklarovány jako virtuální; tomu se říká virtuální dědičnost. Virtuální dědičnost zajišťuje, že v grafu dědičnosti existuje pouze jedna instance základní třídy, čímž se zabrání některým problémům s nejednoznačností vícenásobné dědičnosti.

Vícenásobné dědictví je funkce C ++, která se nenachází ve většině ostatních jazyků, což umožňuje odvození třídy z více než jedné základní třídy; to umožňuje propracovanější dědické vztahy. Například třída „Flying Cat“ může dědit z „Cat“ i „Flying Mammal“. Některé další jazyky, například C# nebo Jáva, dosáhnout něčeho podobného (i když omezenějšího) povolením dědičnosti více rozhraní zatímco omezuje počet základních tříd na jednu (rozhraní, na rozdíl od tříd, poskytují pouze deklarace členských funkcí, žádná implementace nebo členské údaje). Rozhraní jako v C # a Javě lze v C ++ definovat jako třídu obsahující pouze čisté virtuální funkce, často známé jako abstraktní základní třída nebo „ABC“. Členské funkce takové abstraktní základní třídy jsou obvykle explicitně definovány v odvozené třídě, ne implicitně zděděné. Virtuální dědičnost C ++ vykazuje funkci řešení nejednoznačnosti nazvanou dominance.

Operátoři a přetížení operátorů

Operátory, které nelze přetížit
OperátorSymbol
Provozovatel řešení rozsahu::
Podmíněný operátor?:
operátor tečky.
Operátor výběru členů.*
"velikost "operátorvelikost
"psí typ "operátorpsí typ

C ++ poskytuje více než 35 operátorů, které pokrývají základní aritmetiku, bitovou manipulaci, indirekci, srovnání, logické operace a další. Téměř všichni operátoři mohou být přetížený pro typy definované uživatelem, s několika významnými výjimkami, jako je přístup členů (. a .*) a také podmíněný operátor. Bohatá sada přetížitelných operátorů je zásadní pro to, aby se uživatelem definované typy v C ++ zdály jako předdefinované typy.

Přetížitelní operátoři jsou také nezbytnou součástí mnoha pokročilých programovacích technik C ++, jako je inteligentní ukazatele. Přetížení operátoru nezmění prioritu výpočtů zahrnujících operátor, ani nezmění počet operandů, které operátor používá (operátor však může být jakýkoli operand ignorován, i když bude vyhodnocen před provedením). Přetíženo “&&" a "||"operátoři ztrácejí vyhodnocení zkratu vlastnictví.

Polymorfismus

Polymorfismus umožňuje jedno společné rozhraní pro mnoho implementací a pro objekty, aby za různých okolností jednaly odlišně.

C ++ podporuje několik druhů statický (vyřešeno v čas kompilace ) a dynamický (vyřešeno v run-time ) polymorfismy, podporované výše popsanými jazykovými funkcemi. Polymorfismus v době kompilace neumožňuje určitá rozhodnutí za běhu, zatímco běhový polymorfismus obvykle způsobí výkonnostní trest.

Statický polymorfismus

Přetížení funkce umožňuje programům deklarovat více funkcí se stejným názvem, ale s různými argumenty (tj. ad hoc polymorfismus ). Funkce se liší podle počtu nebo typů formální parametry. Stejný název funkce tedy může odkazovat na různé funkce v závislosti na kontextu, ve kterém se používá. Typ vrácený funkcí se nepoužívá k rozlišení přetížených funkcí a měl by za následek chybovou zprávu při kompilaci.

Při deklaraci funkce může programátor zadat jeden nebo více parametrů a výchozí hodnota. Tímto způsobem lze volitelně vynechat parametry s výchozími hodnotami při volání funkce, v takovém případě se použijí výchozí argumenty. Když je funkce volána s menším počtem argumentů, než kolik je deklarovaných parametrů, jsou explicitní argumenty porovnány s parametry v pořadí zleva doprava, přičemž všem nepřizpůsobeným parametrům na konci seznamu parametrů jsou přiřazeny jejich výchozí argumenty. V mnoha případech je lepší zadat výchozí argumenty v deklaraci jedné funkce než poskytnout přetížené definice funkcí s různými počty parametrů.

Šablony v jazyce C ++ poskytuje propracovaný mechanismus pro psaní obecného, ​​polymorfního kódu (tj. parametrický polymorfismus ). Zejména prostřednictvím podivně se opakující vzor šablony, je možné implementovat formu statického polymorfismu, která úzce napodobuje syntaxi pro přepsání virtuálních funkcí. Protože šablony C ++ jsou typové a Turing-kompletní, mohou být také použity k tomu, aby kompilátor umožnil vyřešit rekurzivní podmínky a generovat podstatné programy metaprogramování šablon. Na rozdíl od nějakého názoru nebude kód šablony generovat hromadný kód po kompilaci se správným nastavením kompilátoru.[64]

Dynamický polymorfismus

Dědictví

Variabilní ukazatele a odkazy na typ základní třídy v C ++ mohou také odkazovat na objekty všech odvozených tříd daného typu. To umožňuje, aby pole a jiné druhy kontejnerů obsahovaly ukazatele na objekty různých typů (odkazy nelze přímo uchovávat v kontejnerech). To umožňuje dynamický (běhový) polymorfismus, kdy se uvedené objekty mohou chovat odlišně, v závislosti na jejich (skutečných, odvozených) typech.

C ++ také poskytuje dynamic_cast operátor, který umožňuje kódu bezpečně se pokusit o převod objektu pomocí základního odkazu / ukazatele na odvozenější typ: vylidňování. The pokus je nutné, protože často nevíte, na který odvozený typ se odkazuje. (Upcasting, převod na obecnější typ, lze vždy zkontrolovat / provést v době kompilace pomocí static_cast, protože třídy předků jsou specifikovány v rozhraní odvozené třídy, viditelné pro všechny volající.) dynamic_cast spoléhá na informace o typu běhu (RTTI), metadata v programu, která umožňují rozlišování typů a jejich vztahů. Pokud dynamic_cast na ukazatel selže, výsledkem je nullptr konstanta, zatímco pokud je cílem odkaz (který nemůže mít hodnotu null), vyvolání vyvolá výjimku. Objekty známý být určitého odvozeného typu lze vrhnout na to s static_cast, obejde RTTI a bezpečnou runtime kontrolu typu dynamic_cast, takže toto by mělo být použito pouze v případě, že si programátor je velmi jistý, že obsazení je a vždy bude platné.

Virtuální členské funkce

Obvykle, když je funkce v odvozené třídě přepíše funkce v základní třídě, funkce, která se má volat, je určena typem objektu. Daná funkce je přepsána, pokud mezi dvěma nebo více definicemi této funkce neexistuje žádný rozdíl v počtu nebo typu parametrů. Proto v době kompilace nemusí být možné určit typ objektu, a tedy správnou funkci, která se má volat, vzhledem k tomu, že je uveden pouze ukazatel základní třídy; rozhodnutí je proto odloženo na dobu běhu. Tomu se říká dynamické odesílání. Virtuální členské funkce nebo metody[67] umožňuje volat nejkonkrétnější implementaci funkce podle skutečného typu běhu objektu. V implementacích C ++ se to běžně provádí pomocí virtuální tabulky funkcí. Pokud je známý typ objektu, lze jej obejít prepending a plně kvalifikovaný název třídy před voláním funkce, ale obecně se volání virtuálních funkcí vyřeší za běhu.

Kromě standardních členských funkcí mohou být přetížení operátoru a destruktory virtuální. Pravidlem je, že pokud je jakákoli funkce ve třídě virtuální, měl by být také destruktor. Protože typ objektu při jeho vytvoření je znám v době kompilace, konstruktory a konstruktory rozšíření kopírování nemohou být virtuální. Může však nastat situace, kdy je třeba vytvořit kopii objektu, když je ukazatel na odvozený objekt předán jako ukazatel na základní objekt. V takovém případě je běžným řešením vytvoření a klon() (nebo podobná) virtuální funkce, která při volání vytvoří a vrátí kopii odvozené třídy.

Členskou funkci lze také vytvořit „čistě virtuální“ připojením k = 0 za koncovou závorkou a před středníkem. Třída obsahující čistě virtuální funkci se nazývá abstraktní třída. Objekty nelze vytvořit z abstraktní třídy; lze je pouze odvodit. Jakákoli odvozená třída zdědí virtuální funkci jako čistou a před vytvořením objektů odvozené třídy musí poskytnout její čistou definici (a všechny ostatní čisté virtuální funkce). Program, který se pokusí vytvořit objekt třídy s čistou virtuální členskou funkcí nebo zděděnou čistou virtuální členskou funkcí, má nesprávný tvar.

Lambda výrazy

C ++ poskytuje podporu pro anonymní funkce, známé také jako výrazy lambda, v následující podobě:

[zajmout](parametry) -> návratový_typ { function_body }

Pokud lambda nepřijímá žádné parametry, lze vynechat (), tj.

[zajmout] -> návratový_typ { function_body }

Také návratový typ výrazu lambda lze automaticky odvodit, pokud je to možné, např .:

[](int X, int y) { vrátit se X + y; } // odvozeno[](int X, int y) -> int { vrátit se X + y; } // explicitní

The [zajmout] seznam podporuje definici uzávěry. Takové výrazy lambda jsou ve standardu definovány jako syntaktický cukr pro nejmenovaného funkční objekt.

Zpracování výjimek

Zpracování výjimek se používá ke komunikaci existence runtime problému nebo chyby z místa, kde byl zjištěn, do místa, kde lze problém vyřešit.[68] Umožňuje to provést jednotným způsobem a odděleně od hlavního kódu při detekci všech chyb.[69] Pokud dojde k chybě, je vyvolána (vyvolána) výjimka, která je poté zachycena nejbližší vhodnou obsluhou výjimky. Výjimka způsobí ukončení aktuálního oboru a také každého vnějšího oboru (šíření), dokud se nenajde vhodný obslužný program, který zase volá destruktory všech objektů v těchto vyjmutých oborech.[70] Zároveň je výjimka prezentována jako objekt nesoucí data o zjištěném problému.[71]

Někteří průvodci stylem C ++, například Google,[72] LLVM,[73] a Qt[74] zakazovat používání výjimek.

Kód způsobující výjimku je umístěn uvnitř a Snaž se blok. Výjimky jsou zpracovávány samostatně chytit bloky (manipulátory); každý Snaž se block can have multiple exception handlers, as it is visible in the example below.[75]

 1 #zahrnout <iostream> 2 #zahrnout <vector> 3 #zahrnout <stdexcept> 4  5 int hlavní() { 6     Snaž se { 7         std::vektor<int> vec{3, 4, 3, 1}; 8         int i{vec.na(4)}; // Vyvolá výjimku, std :: out_of_range (indexování pro vec je od 0-3 ne 1-4) 9     }10     // Obslužný program výjimek, zachytí std :: out_of_range, který je vyvolán vec.at (4)11     chytit (std::mimo dosah &E) {12         std::cerr << "Přístup k neexistujícímu prvku:" << E.co() << ' n';13     }14     // Chcete-li zachytit jakékoli další standardní výjimky knihovny (jsou odvozeny od std :: výjimka)15     chytit (std::výjimka &E) {16         std::cerr << "Vyvolána výjimka:" << E.co() << ' n';17     }18     // Chyťte všechny nerozpoznané výjimky (tj. Ty, které nejsou odvozeny od std :: výjimky)19     chytit (...) {20         std::cerr << „Nějaká závažná chyba n";21     }22 }

Je také možné účelově vyvolat výjimky pomocí házet klíčové slovo; tyto výjimky jsou zpracovány obvyklým způsobem. V některých případech nelze z technických důvodů použít výjimky. Jedním z takových příkladů je kritická součást vestavěného systému, kde musí být zaručeno, že každá operace bude dokončena ve stanoveném čase. To nelze určit s výjimkami, protože neexistují žádné nástroje k určení maximální doby potřebné pro zpracování výjimky.[76]

Na rozdíl od zpracování signálu, ve kterém je funkce zpracování volána z bodu selhání, zpracování výjimek ukončí aktuální rozsah před zadáním bloku zachycení, který může být umístěn v aktuální funkci nebo v některém z předchozích volání funkce aktuálně v zásobníku.

Standardní knihovna

Návrh standardu „Working Paper“, který byl schválen jako C ++ 98; polovina jeho velikosti byla věnována standardní knihovně C ++

C ++ Standard se skládá ze dvou částí: základního jazyka a standardní knihovny. Programátoři C ++ očekávají to druhé při každé hlavní implementaci C ++; zahrnuje typy agregátů (vektory, seznamy, mapy, sady, fronty, komíny, pole, n-tice), algoritmy (nalézt, pro každého, binární_vyhledávání, random_shuffle atd.), vstupní / výstupní zařízení (proud, pro čtení a zápis do konzoly a souborů), knihovna souborového systému, podpora lokalizace, inteligentní ukazatele pro automatickou správu paměti, regulární výraz Podpěra, podpora, vícevláknové knihovna, podpora atomů (umožnění čtení nebo zápisu proměnné nejvýše jedním vláknem najednou bez jakékoli externí synchronizace), časové nástroje (měření, získání aktuálního času atd.), systém pro převod hlášení chyb, který nedělá t používat C ++ výjimky do C ++ výjimek, a generátor náhodných čísel a mírně upravenou verzi C standardní knihovna (aby to vyhovovalo systému typu C ++).

Velká část knihovny C ++ je založena na Standardní knihovna šablon (STL). Mezi užitečné nástroje poskytované STK patří kontejnery jako sbírky předmětů (např vektory a seznamy ), iterátory které poskytují přístup ke kontejnerům jako pole a algoritmy které provádějí operace, jako je vyhledávání a třídění.

Dále (multi) mapy (asociativní pole ) a (multi) sady jsou k dispozici, přičemž všechny exportují kompatibilní rozhraní. Proto pomocí šablon je možné psát obecné algoritmy, které fungují s jakýmkoli kontejnerem nebo s libovolnou posloupností definovanou iterátory. Stejně jako v C, funkce z knihovna jsou přístupné pomocí #zahrnout směrnice zahrnout a standardní záhlaví. The C ++ standardní knihovna poskytuje 105 standardních záhlaví, z nichž 27 je zastaralých.

Standard zahrnuje STL, kterou původně navrhl Alexander Stepanov, kteří mnoho let experimentovali s obecnými algoritmy a kontejnery. Když začal s C ++, konečně našel jazyk, kde bylo možné vytvořit obecné algoritmy (např. Řazení STL), které fungují ještě lépe než například standardní knihovna qsort C, a to díky funkcím C ++, jako je použití vložení a kompilace časové vazby místo ukazatelů funkcí. Norma o něm nehovoří jako o „STL“, protože je pouze součástí standardní knihovny, ale tento termín je stále široce používán k odlišení od zbytku standardní knihovny (vstupní / výstupní proudy, internacionalizace, diagnostika, podmnožina knihovny C atd.).[77]

Většina překladačů C ++ a všechny hlavní kompilátory poskytují implementaci standardní knihovny C ++ vyhovující standardům.

Základní pokyny C ++

Hlavní pokyny C ++[78] jsou iniciativou vedenou Bjarnem Stroustrupem, vynálezcem C ++, a Herbem Sutterem, svolatelem a předsedou pracovní skupiny ISO C ++, aby pomohli programátorům psát „Modern C ++“ pomocí osvědčených postupů pro jazykové standardy C ++ 14 a novější a pomáhat vývojářům překladačů a statických kontrolních nástrojů vytvářet pravidla pro zachycení špatných programovacích postupů.

Hlavním cílem je efektivně a důsledně psát C ++ bezpečný pro typ a zdroje.

Byly oznámeny hlavní pokyny[79] v úvodní hlavní řeči na CPPCon 2015.

K pokynům je přiložena Knihovna podpory pokynů (GSL),[80] Knihovna typů a funkcí pouze pro záhlaví k implementaci Core Guidelines a nástroje statické kontroly pro vynucování pravidel Guideline.[81]

Kompatibilita

Aby se dodavatelům překladačů poskytla větší svoboda, rozhodl se výbor pro standardy C ++ nediktovat implementaci zmanipulované jméno, zpracování výjimek a další funkce specifické pro implementaci. Nevýhodou tohoto rozhodnutí je to kód objektu produkoval různé překladače se očekává, že bude nekompatibilní. Byly však pokusy o standardizaci překladačů pro konkrétní stroje nebo operační systémy (například C ++ ABI),[82] i když se zdá, že jsou nyní z velké části opuštěni.

S C.

C ++ se často považuje za nadmnožinu C ale to není úplně pravda.[83] Většinu C kódu lze snadno provést tak, aby se správně zkompilovala v C ++, ale existuje několik rozdílů, které způsobují, že některý platný C kód je neplatný nebo se v C ++ chová odlišně. Například C umožňuje implicitní převod z prázdnota* na jiné typy ukazatelů, ale C ++ nikoli (z bezpečnostních důvodů typu). C ++ také definuje mnoho nových klíčových slov, například Nový a třída, které lze použít jako identifikátory (například názvy proměnných) v programu C.

Některé nekompatibility byly odstraněny revizí standardu C z roku 1999 (C99 ), který nyní podporuje funkce C ++, jako jsou řádkové komentáře (//) a prohlášení smíchaná s kódem. Na druhou stranu C99 představil řadu nových funkcí, které C ++ nepodporovaly, které byly v C ++ nekompatibilní nebo nadbytečné, jako například pole proměnné délky, nativní typy komplexních čísel (nicméně std::komplex třída ve standardní knihovně C ++ poskytuje podobné funkce, i když není kompatibilní s kódem), určené inicializátory, složené literály a omezit klíčové slovo.[84] Některé z funkcí zavedených v C99 byly zahrnuty do následující verze standardu C ++, C ++ 11 (z těch, kteří nebyli nadbyteční).[85][86][87] Standard C ++ 11 však zavádí nové nekompatibility, například zakázání přiřazení řetězcového literálu znakovému ukazateli, který zůstává platný C.

Chcete-li promíchat kód C a C ++, musí být jakákoli deklarace funkce nebo definice, která má být volána z / používaná v C i C ++, deklarována pomocí C vazby umístěním do externí "C" {/*...*/} blok. Taková funkce se nemusí spoléhat na funkce v závislosti na zmanipulované jméno (tj. přetížení funkce).

Kritika

Přes jeho široké přijetí někteří významní programátoři kritizovali jazyk C ++, včetně Linus Torvalds,[88] Richard Stallman,[89] Joshua Bloch, Ken Thompson,[90][91][92] a Donald Knuth.[93][94]

Jedním z nejčastěji kritizovaných bodů C ++ je jeho vnímaná složitost jako jazyka s kritikou, že velké množství neortogonálních rysů v praxi vyžaduje omezení kódu na podmnožinu C ++, čímž se vyhýbá výhodám čitelnosti společného stylu a idiomů. Jak vyjádřil Joshua Bloch:

Myslím, že C ++ bylo posunuto daleko za prahovou hodnotu jeho složitosti, a přesto ho spousta lidí programuje. Ale to, co děláte, je nutíte lidi, aby to podmnožili. Takže téměř každý obchod, o kterém vím, že používá C ++, říká: „Ano, používáme C ++, ale neděláme dědičnost více implementací a nepoužíváme přetížení operátorů.“ Existuje jen spousta funkcí, které nebudete používat, protože složitost výsledného kódu je příliš vysoká. A nemyslím si, že je dobré, když s tím musíte začít. Ztratíte přenositelnost programátoru, kde si každý může přečíst kód všech ostatních, což je podle mě tak dobrá věc.

Donald Knuth (1993, komentující předstandardizovaný C ++), který řekl o Edsger Dijkstra že „přemýšlet o programování v C ++“ „by mu fyzicky onemocněl“:[93][94]

Problém, který s nimi dnes mám, je, že ... C ++ je příliš komplikovaný. V tuto chvíli pro mě není možné psát přenosný kód, o kterém se domnívám, že by fungoval na mnoha různých systémech, pokud se nevyhnu všem exotickým funkcím. Kdykoli návrháři jazyka C ++ měli dva konkurenční nápady, jak by měli vyřešit nějaký problém, řekli „OK, uděláme je oba“. Jazyk je tedy na můj vkus příliš barokní.

Ken Thompson, který byl kolegou Stroustrupa v Bell Labs, hodnotí:[91][92]

Určitě má své dobré stránky. Ale obecně si myslím, že je to špatný jazyk. Dělá spoustu věcí napůl dobře a je to jen hromada nápadů, které se vzájemně vylučují. Každý, koho znám, ať už je to osobní nebo firemní, vybere podmnožinu a tyto podmnožiny se liší. Není tedy dobrý jazyk přenášet algoritmus - říci: „Napsal jsem to; tady, vezmi si to. “ Je příliš velký, příliš složitý. A je to samozřejmě postavený výborem. Stroustrup kampaň po léta a roky a roky, daleko za jakýmkoli technickým přínosem, který do jazyka vložil, aby byl adoptován a používán. A tak nějak řídil všechny výbory pro standardy bičem a židlí. A nikomu neřekl „ne“. Vložil všechny funkce do toho jazyka, který kdy existoval. Nebylo to čistě navrženo - bylo to jen spojení všeho, co přišlo. A myslím, že to tím drasticky trpělo.

nicméně Brian Kernighan, také kolega v Bell Labs, toto hodnocení zpochybňuje:[95]

C ++ byl nesmírně vlivný. ... Spousta lidí říká, že C ++ je příliš velký a příliš komplikovaný atd. Atd., Ale ve skutečnosti je to velmi silný jazyk a skoro všechno, co tam je, je tam ze skutečně zdravého důvodu: není to někdo, kdo dělá náhodný vynález , ve skutečnosti se lidé snaží vyřešit problémy v reálném světě. Mnoho programů, které dnes považujeme za samozřejmost, které právě používáme, jsou nyní programy C ++.

Sám Stroustrup poznamenává, že sémantika C ++ je mnohem čistší než jeho syntaxe: „v C ++ existuje mnohem menší a čistší jazyk, který se snaží dostat ven“.[96]

Mezi další stížnosti může patřit nedostatek odraz nebo odvoz odpadu, vnímána dlouhá doba kompilace funkce tečení,[97] a podrobné chybové zprávy, zejména z metaprogramování šablony.[98]

Viz také

Reference

  1. ^ A b C d E F Bjarne Stroustrup. „A History of C ++: 1979-1991“. doi:10.1145/234286.1057836. Citovat deník vyžaduje | deník = (Pomoc)
  2. ^ Naugler, David (květen 2007). "C # 2.0 pro programátory C ++ a Java: konferenční workshop". Journal of Computing Sciences in Colleges. 22 (5). Ačkoli C # byl silně ovlivněn Javou, byl také silně ovlivněn C ++ a je nejlépe vnímán jako potomek C ++ i Javy.
  3. ^ „Specifikace kaple (Poděkování)“ (PDF). Cray Inc. 1. října 2015. Citováno 14. ledna 2016.
  4. ^ „Rich Hickey Q&A by Michael Fogus“. Archivovány od originál dne 11. ledna 2017. Citováno 11. ledna 2017.
  5. ^ Harry. H. Chaudhary (28. července 2014). "Cracking The Java Programming Interview :: 2000+ Java Interview Que / Ans". Citováno 29. května 2016.
  6. ^ Roger Poon (1. května 2017). „Škálování JS ++: Abstrakce, výkon a čitelnost“. Citováno 21. dubna 2020.
  7. ^ "FAQ Nim Programovací jazyk". Citováno 21. dubna 2020.
  8. ^ "9. Třídy - dokumentace k Pythonu 3.6.4". docs.python.org. Citováno 9. ledna 2018.
  9. ^ Stroustrup, Bjarne (1997). "1". Programovací jazyk C ++ (Třetí vydání.). ISBN  0-201-88954-4. OCLC  59193992.
  10. ^ A b C Stroustrup, B. (6. května 2014). „Přednáška: Podstata jazyka C ++. Univerzita v Edinburghu“. Citováno 12. června 2015.
  11. ^ Stroustrup, Bjarne (17. února 2014). "C ++ aplikace". stroustrup.com. Citováno 5. května 2014.
  12. ^ A b „ISO / IEC 14882: 2017“. Mezinárodní organizace pro normalizaci.
  13. ^ „Domovská stránka Bjarne Stroustrupa“. www.stroustrup.com.
  14. ^ "Plán IS C ++" (PDF).
  15. ^ „C ++; Kam směřuje“.
  16. ^ A b Stroustrup, Bjarne (7. března 2010). „Časté dotazy Bjarne Stroustrupa: Kdy byl C ++ vynalezen?“. stroustrup.com. Citováno 16. září 2010.
  17. ^ A b Stroustrup, Bjarne. „Vývoj jazyka v reálném světě a pro něj: C ++ 1991-2006“ (PDF).
  18. ^ A b C Stroustrup, Bjarne. „A History of C ++: 1979− 1991“ (PDF).
  19. ^ Stroustrup, Bjarne. „Programovací jazyk C ++“ (První vydání.). Citováno 16. září 2010.
  20. ^ Stroustrup, Bjarne. „Programovací jazyk C ++“ (Druhé vydání). Citováno 16. září 2010.
  21. ^ A b https://herbsutter.com/2016/06/30/trip-report-summer-iso-c-standards-meeting-oulu/ „dalším standardem po C ++ 17 bude C ++ 20“
  22. ^ Dusíková, Hana (6. listopadu 2019). „N4817: 2020 Pozvánka na Pražské setkání a informace“ (PDF). Citováno 13. února 2020.
  23. ^ "Aktuální stav". isocpp.org. Citováno 7. září 2020.
  24. ^ „C ++ 20 Approved - Herb Sutter“. isocpp.org. Citováno 8. září 2020.
  25. ^ "Poslední zprávy." Rejstřík TIOBE | TIOBE - společnost zabývající se kvalitou softwaru. N.p., n.d. Web. 5. června 2017.
  26. ^ Krill, Paul. „Java, C, C čelí rostoucí popularitě.“ InfoWorld. InfoWorld, 10. února 2017. Web. 5. června 2017.
  27. ^ https://www.nae.edu/177355.aspx „Průkopník počítačové vědy Bjarne Stroustrup obdrží cenu Charlese Starka Drapera za strojírenství 2018“
  28. ^ „Časté dotazy Bjarne Stroustrupa - Odkud pochází název„ C ++ “?“. Citováno 16. ledna 2008.
  29. ^ „C pro programátory v C ++“. Severovýchodní univerzita. Archivovány od originál dne 17. listopadu 2010. Citováno 7. září 2015.
  30. ^ „ISO / IEC 14882: 1998“. Mezinárodní organizace pro normalizaci.
  31. ^ „ISO / IEC 14882: 2003“. Mezinárodní organizace pro normalizaci.
  32. ^ A b „ISO / IEC 14882: 2011“. Mezinárodní organizace pro normalizaci.
  33. ^ „ISO / IEC 14882: 2014“. Mezinárodní organizace pro normalizaci.
  34. ^ „Máme mezinárodní standard: C ++ 0x je jednomyslně schválen“. Sutterův mlýn.
  35. ^ „Budoucnost C ++“.
  36. ^ „Máme C ++ 14!: Standardní C ++“.
  37. ^ Zpráva o cestě: Setkání letních norem ISO C ++ (Toronto)
  38. ^ „ISO / IEC TR 18015: 2006“. Mezinárodní organizace pro normalizaci.
  39. ^ „ISO / IEC TR 19768: 2007“. Mezinárodní organizace pro normalizaci.
  40. ^ „ISO / IEC TR 29124: 2010“. Mezinárodní organizace pro normalizaci.
  41. ^ „ISO / IEC TR 24733: 2011“. Mezinárodní organizace pro normalizaci.
  42. ^ „ISO / IEC TS 18822: 2015“. Mezinárodní organizace pro normalizaci.
  43. ^ „ISO / IEC TS 19570: 2015“. Mezinárodní organizace pro normalizaci.
  44. ^ „ISO / IEC TS 19841: 2015“. Mezinárodní organizace pro normalizaci.
  45. ^ „ISO / IEC TS 19568: 2015“. Mezinárodní organizace pro normalizaci.
  46. ^ „ISO / IEC TS 19217: 2015“. Mezinárodní organizace pro normalizaci.
  47. ^ „ISO / IEC TS 19571: 2016“. Mezinárodní organizace pro normalizaci.
  48. ^ „ISO / IEC TS 19568: 2017“. Mezinárodní organizace pro normalizaci.
  49. ^ „ISO / IEC TS 21425: 2017“. Mezinárodní organizace pro normalizaci.
  50. ^ „ISO / IEC TS 22277: 2017“. Mezinárodní organizace pro normalizaci.
  51. ^ „ISO / IEC TS 19216: 2018“. Mezinárodní organizace pro normalizaci.
  52. ^ „ISO / IEC TS 21544: 2018“. Mezinárodní organizace pro normalizaci.
  53. ^ „ISO / IEC TS 19570: 2018“. Mezinárodní organizace pro normalizaci.
  54. ^ Viz seznam na https://en.cppreference.com/w/cpp/experimental navštívil 15. února 2019.
  55. ^ B. Stroustrup (rozhovor s Sergiem De Simonem) (30. dubna 2015). „Stroustrup: Thoughts on C ++ 17 - An Interview“. Citováno 8. července 2015.
  56. ^ Stroustrup, Bjarne (2000). Programovací jazyk C ++ (Special ed.). Addison-Wesley. str. 46. ISBN  0-201-70073-5.
  57. ^ Stroustrup, Bjarne. „Otevřená čísla pro programovací jazyk C ++ (3. vydání)“. Tento kód je zkopírován přímo ze stránky s chybami Bjarne Stroustrup (str. 633). Řeší použití ' n' spíše než std :: endl. Viz také Mohu napsat „void main ()“? pro vysvětlení implicitního návrat 0; v hlavní funkce. Tento implicitní návrat je ne k dispozici v dalších funkcích.
  58. ^ ISO /IEC. Programovací jazyky - C ++ 11 Draft (n3797) Archivováno 2. října 2018 v Wayback Machine §3.7 Doba skladování [basic.stc]
  59. ^ ISO /IEC. Programovací jazyky - C ++ 11 Draft (n3797) Archivováno 2. října 2018 v Wayback Machine §3.7.1 Doba statického úložiště [basic.stc.static]
  60. ^ ISO /IEC. Programovací jazyky - C ++ 11 Draft (n3797) Archivováno 2. října 2018 v Wayback Machine §3.7.2 Trvání úložiště vláken [basic.stc.thread]
  61. ^ ISO /IEC. Programovací jazyky - C ++ 11 Draft (n3797) Archivováno 2. října 2018 v Wayback Machine §3.7.3 Doba automatického ukládání [basic.stc.auto]
  62. ^ ISO /IEC. Programovací jazyky - C ++ 11 Draft (n3797) Archivováno 2. října 2018 v Wayback Machine §3.7.4 Doba dynamického úložiště [basic.stc.dynamic]
  63. ^ „Základní pokyny pro C ++“. isocpp.github.io. Citováno 9. února 2020.
  64. ^ A b „Nikdo nerozumí C ++: Část 5: Naštvaný kód šablony“. articles.emptycrate.com/: Software EmptyCrate. Cestovat. Věci. 6. května 2008. Citováno 8. března 2010. Někdy budete číst nebo slyšet někoho, kdo mluví o šablonách C ++, které způsobují nafouknutí kódu. Myslel jsem na to druhý den a pomyslel jsem si: „já, pokud kód dělá přesně to samé, pak zkompilovaný kód už opravdu nemůže být větší, že?“ [...] A co velikost kompilovaného kódu? Každá byla kompilována pomocí příkazu g ++ .cpp -O3. Verze bez šablony: 8140 bajtů, verze šablony: 8028 bajtů!
  65. ^ Sutter, Herb; Alexandrescu, Andrei (2004). Standardy kódování C ++: 101 pravidel, pokynů a osvědčených postupů. Addison-Wesley.
  66. ^ Henricson, Mats; Nyquist, Erik (1997). Průmyslová síla C ++. Prentice Hall. ISBN  0-13-120965-5.
  67. ^ Stroustrup, Bjarne (2000). Programovací jazyk C ++ (Special ed.). Addison-Wesley. str. 310. ISBN  0-201-70073-5. Virtuální členská funkce se někdy nazývá a metoda.
  68. ^ Mycroft, Alan (2013). "Výjimky C a C ++ | Šablony" (PDF). Cambridge Computer Laboratory - Materiály ke kurzu 2013-14. Citováno 30. srpna 2016.
  69. ^ Stroustrup, Bjarne (2013). Programovací jazyk C ++. Addison Wesley. str. 345. ISBN  9780321563842.
  70. ^ Stroustrup, Bjarne (2013). Programovací jazyk C ++. Addison Wesley. str. 363–365. ISBN  9780321563842.
  71. ^ Stroustrup, Bjarne (2013). Programovací jazyk C ++. Addison Wesley. 345, 363. ISBN  9780321563842.
  72. ^ „Průvodce stylem Google C ++“. Citováno 25. června 2019.
  73. ^ „Standardy kódování LLVM“. Dokumentace LLVM 9. Citováno 25. června 2019.
  74. ^ „Konvence kódování“. Qt Wiki. Citováno 26. června 2019.
  75. ^ Stroustrup, Bjarne (2013). Programovací jazyk C ++. Addison Wesley. 344, 370. ISBN  9780321563842.
  76. ^ Stroustrup, Bjarne (2013). Programovací jazyk C ++. Addison Wesley. str. 349. ISBN  9780321563842.
  77. ^ Graziano Lo Russo (2008). „Rozhovor s A. Stepanovem“. stlport.org. Citováno 8. října 2015.
  78. ^ „Základní pokyny pro C ++“.
  79. ^ „Bjarne Stroustrup ohlašuje základní pokyny pro C ++“.
  80. ^ „Knihovna podpory pokynů“.
  81. ^ „Use the C ++ Core Guidelines checkers“.
  82. ^ "C ++ ABI Summary". 20. března 2001. Citováno 30. května 2006.
  83. ^ „Časté dotazy Bjarne Stroustrupa - je C podmnožinou C ++?“. Citováno 5. května 2014.
  84. ^ „C9X - nový standard C“. Citováno 27. prosince 2008.
  85. ^ „Podpora C ++ 0x v GCC“. Citováno 12. října 2010.
  86. ^ „Funkce jádra jazyka C ++ 0x ve VC10: Tabulka“. Citováno 12. října 2010.
  87. ^ „Clang - C ++ 98, C ++ 11 a C ++ 14 Status“. Clang.llvm.org. 12. května 2013. Citováno 10. června 2013.
  88. ^ „Re: [RFC] Convert builin-mailinfo.c to use The Better String Library“ (Poštovní seznam). 6. září 2007. Citováno 31. března 2015.
  89. ^ „Re: Snahy přilákat více uživatelů?“ (Poštovní seznam). 12. července 2010. Citováno 31. března 2015.
  90. ^ Andrew Binstock (18. května 2011). „Dr. Dobb's: Interview with Ken Thompson“. Citováno 7. února 2014.
  91. ^ A b Peter Seibel (16. září 2009). Coders at Work: Úvahy o řemesle programování. Apress. 475–476. ISBN  978-1-4302-1948-4.
  92. ^ A b https://gigamonkeys.wordpress.com/2009/10/16/coders-c-plus-plus/
  93. ^ A b https://www.drdobbs.com/architecture-and-design/an-interview-with-donald-knuth/228700500
  94. ^ A b http://tex.loria.fr/litte/knuth-interview
  95. ^ Brian Kernighan (18. července 2018). Brian Kernighan Otázky a odpovědi - Computerphile.
  96. ^ http://www.stroustrup.com/bs_faq.html#really-say-that
  97. ^ Pike, Rob (2012). „Méně je exponenciálně více“.
  98. ^ Kreinin, Yossi (13. října 2009). „Defective C ++“. Citováno 3. února 2016.

Další čtení

externí odkazy