Portál AbcLinuxu, 5. května 2025 09:21
V C++ 20 budú majú byť heradery nahradené plnohodnotnými modulmi s exportami, ale čo dovtedy?modules[48] – experimentally supported in Clang 5[49] and Visual Studio 2015 Update 1[50] as well as GCC[51] zdroj Nie je to tak tazke: https://gcc.gnu.org/wiki/cxx-modules Zas, kto ma rad veci pod kontrolou, tak to pouzivat nebude chciet.
Ale dnes? V dobe IDEčiek? WTF?V IDE mas alebo si vies vytvorit addon, ktory ti vytvori definicie (vytvor .h subor z *.c). Ale zas 100% istotu to zautomatizovat brani implementacia, ze definicia prototypu funkcie nie je rychlim pozretim jednoznacne jasne (chyba klucove slovo function). Ale to by sa dalo rozsirit ako rozsirenie prehladavaca, ak by to niekto chcel. A na preklad tu mas make, cmake. C/C++ je blizko hardveru a ten system prekladanie je kvoli velkym projektom (sak kludne si mozes vsetko hodit do jedneho *.c a tak to prekladat. A to potom ocenis (pri hrach alebo webovom engine), ze zmenou jedneho riadku nemusis cakat na preklad 20 minut ale 30s (nemusis mat extra nadupany notebook).
…a tiež tým, že šablóny musia byť vcelku.
Někdy nemusí. Klíčové slovo: explicit instantiation. Samozřejmě se to nedá použít u šablon typu kontejnery, které musí podporovat (skoro) libovolný uživatelem specifikovaný typ. Nicméně pokud má člověk aspoň trochu kontrolu nad tím, které typy nějaká šablona bude podporovat, pak se dá úplně oddělit header od implementace i u šablon.
1) Ano, je to utrpení (např. ve srovnání s Javou), zvlášť pokud chceš dodržovat zpětnou kompatibilitu. Nechutně tam prosakuje abstrakce resp. technické detaily, které ti narušují logický návrh rozhraní. Ale takové už C++ je.
2) Řešitelné je to přes Opaque pointer (a.k.a. PImpl idiom, D-Pointer)
3) IDE v tomhle docela dost pomáhají – dá se proklikávat mezi hlavičkovým souborem a implementací, v .cpp souborech ti to bude napovídat metody z .h souborů, které můžeš implementovat, měl by fungovat i refaktoring atd.
4) Lze dát všechno do .h souboru, některé tzv. „header-only“ knihovny to tak dělají. AFAIK to není optimální z hlediska rychlosti kompilace, ale u menších věcí to asi nevadí.
Tiskni
Sdílej:
ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.