abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    včera 16:44 | Nová verze

    Svobodný multiplatformní herní engine Bevy napsaný v Rustu byl vydán ve verzi 0.18. Díky 174 přispěvatelům.

    Ladislav Hagara | Komentářů: 2
    včera 15:11 | IT novinky

    Miliardy korun na digitalizaci služeb státu nestačily. Stát do ní v letech 2020 až 2024 vložil víc než 50 miliard korun, ale původní cíl se nepodařilo splnit. Od loňského února měly být služby státu plně digitalizované a občané měli mít právo komunikovat se státem digitálně. Do tohoto data se povedlo plně digitalizovat 18 procent agendových služeb státu. Dnes to uvedl Nejvyšší kontrolní úřad (NKÚ) v souhrnné zprávě o stavu digitalizace v Česku. Zpráva vychází z výsledků víc než 50 kontrol, které NKÚ v posledních pěti letech v tomto oboru uskutečnil.

    Ladislav Hagara | Komentářů: 9
    včera 13:55 | IT novinky

    Nadace Wikimedia, která je provozovatelem internetové encyklopedie Wikipedia, oznámila u příležitosti 25. výročí vzniku encyklopedie nové licenční dohody s firmami vyvíjejícími umělou inteligenci (AI). Mezi partnery encyklopedie tak nově patří Microsoft, Amazon a Meta Platforms, ale také start-up Perplexity a francouzská společnost Mistral AI. Wikimedia má podobnou dohodu od roku 2022 také se společností Google ze skupiny

    … více »
    Ladislav Hagara | Komentářů: 0
    včera 02:22 | Nová verze

    D7VK byl vydán ve verzi 1.2. Jedná se o fork DXVK implementující překlad volání Direct3D 5, 6 a 7 na Vulkan. DXVK zvládá Direct3D 8, 9, 10 a 11.

    Ladislav Hagara | Komentářů: 0
    včera 02:00 | Nová verze

    Byla vydána verze 12.0.0 knihovny libvirt (Wikipedie) zastřešující různé virtualizační technologie a vytvářející jednotné rozhraní pro správu virtuálních strojů. Současně byl ve verzi 12.0.0 vydán související modul pro Python libvirt-python. Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    15.1. 19:22 | Humor

    CreepyLink.com je nový zkracovač URL adres, 'díky kterému budou vaše odkazy vypadat tak podezřele, jak je to jen možné'. Například odkaz na abclinuxu.cz tento zkracovač převádí do podoby 'https://netflix.web-safe.link/logger_8oIlgs_free_money.php'. Dle prohlášení autora je CreepyLink alternativou ke zkracovači ShadyURL (repozitář na githubu), který dnes již bohužel není v provozu.

    NUKE GAZA! 🎆 | Komentářů: 3
    15.1. 12:33 | IT novinky

    Na blogu Raspberry Pi byla představena rozšiřující deska Raspberry Pi AI HAT+ 2 s akcelerátorem Hailo-10 a 8 GB RAM. Na rozdíl od předchozí Raspberry Pi AI HAT+ podporuje generativní AI. Cena desky je 130 dolarů.

    Ladislav Hagara | Komentářů: 3
    15.1. 12:11 | Komunita

    Wikipedie slaví 25. výročí svého založení. Vznikla 15. ledna 2001 jako doplňkový projekt k dnes již neexistující encyklopedii Nupedia. Doména wikipedia.org byla zaregistrována 12. ledna 2001. Zítra proběhne v Praze Večer svobodné kultury, který pořádá spolek Wikimedia ČR.

    Ladislav Hagara | Komentářů: 1
    15.1. 04:44 | Nová verze

    Po více než dvou letech od vydání předchozí verze 2.12 byla vydána nová stabilní verze 2.14 systémového zavaděče GNU GRUB (GRand Unified Bootloader, Wikipedie). Přehled novinek v souboru NEWS a v aktualizované dokumentaci.

    Ladislav Hagara | Komentářů: 2
    15.1. 02:22 | Nová verze

    Google Chrome 144 byl prohlášen za stabilní. Nejnovější stabilní verze 144.0.7559.59 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 10 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře (YouTube).

    Ladislav Hagara | Komentářů: 4
    Které desktopové prostředí na Linuxu používáte?
     (14%)
     (5%)
     (0%)
     (9%)
     (19%)
     (3%)
     (6%)
     (3%)
     (11%)
     (42%)
    Celkem 465 hlasů
     Komentářů: 12, poslední 14.1. 21:12
    Rozcestník

    Dotaz: C++: jak lokální proměnná dokáže způsobit chybu při linkování?

    23.1.2020 18:30 ttt
    C++: jak lokální proměnná dokáže způsobit chybu při linkování?
    Přečteno: 1205×
    Mám následující kód v C++:
    template <typename Stringish>
    http_rep http_client::post(const std::string& path, Stringish&& body) const
    {
    	std::map<std::string, std::string> foo; // po odstranění tohoto řádku chyba zmizí
    	return http_rep();
    }
    template http_rep http_client::post<>(
    	const std::string& path, std::string&& body) const;
    
    Kompilace skončí s chybou:

    Error LNK2005 "public: class std::_Tree_iterator<class std::_Tree_val<struct std::_Tree_simple_types<struct std::pair<class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> > const ,class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> > > > > > __cdecl std::_Tree<class std::_Tmap_traits<class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> >,class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> >,struct std::less<class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> > >,class std::allocator<struct std::pair<class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> > const ,class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> > > >,0> >::end(void)" (?end@?$_Tree@V?$_Tmap_traits@V?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@V12@U?$less@V?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@@2@V?$allocator@U?$pair@$$CBV?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@V12@@std@@@2@$0A@@std@@@std@@QEAA?AV?$_Tree_iterator@V?$_Tree_val@U?$_Tree_simple_types@U?$pair@$$CBV?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@V12@@std@@@std@@@std@@@2@XZ) already defined in http.obj

    Pokud zakomentuju řádek std::map<std::string, std::string> foo;, projekt se zkompiluje. I třeba pokud změním první typ na int (std::map<int, std::string> foo;). Na jménu proměnné nezáleží, chová se to stejně.

    Co se tam může dít? Nerozumím, proč zavedení lokální proměnné má vliv na linkování. Tuším, že jsem tu chybu viděl i jindy, ve stejně "divných" případech, třeba po přidání const k jiné lokální proměnné.

    Myslím si, že tenhle konkrétní kus kódu je ok, ale jinde v projektu je něco hodně špatně. Ale nenapadá mě co hledat a ta chybová hláška mi zrovna nepomáhá ...

    Odpovědi

    23.1.2020 21:35 debian+
    Rozbalit Rozbalit vše Re: C++: jak lokální proměnná dokáže způsobit chybu při linkování?
    Jendа avatar 23.1.2020 23:02 Jendа | skóre: 78 | blog: Jenda | JO70FB
    Rozbalit Rozbalit vše Re: C++: jak lokální proměnná dokáže způsobit chybu při linkování?
    Chci, aby u automatických odpovědí mohli ostatní nějak flagnout že je mimo.
    24.1.2020 11:50 _
    Rozbalit Rozbalit vše Re: C++: jak lokální proměnná dokáže způsobit chybu při linkování?
    To za tebe dělá nick debian+
    24.1.2020 04:15 linuxák
    Rozbalit Rozbalit vše Re: C++: jak lokální proměnná dokáže způsobit chybu při linkování?
    Možná bude problém v tomhle:

    An explicit specialization of a function or variable template is inline only if it is declared with the inline specifier or defined as deleted, and independently of whether its function or variable template is inline.

    Takže zkus:

    template inline http_rep http_client::post<>(...

    24.1.2020 11:42 tttt
    Rozbalit Rozbalit vše Re: C++: jak lokální proměnná dokáže způsobit chybu při linkování?
    Zkusil jsem, beze změny. Podařilo se mi teď zreprodukovat chováni i bez šablony, s hlavičkou
    http_rep http_client::post(const std::string& path, const std::string& body) const
    
    Přijde mi, že někde přeteče nějaký limit v kompilátoru a on se začne chovat jinak, a pak se projeví chyba, která doteď nebyla vidět. Existuje něco jako nedefinované chování kompilátoru při špatné konstrukci?
    24.1.2020 12:14 linuxák
    Rozbalit Rozbalit vše Re: C++: jak lokální proměnná dokáže způsobit chybu při linkování?
    Nedefinované chování překladače při špatné konstrukci neexistuje, ale může to být bug v překladači. Dokážeš do zredukovat na nějaký elementární příklad, který bys sem dal? Případně můžeš zkusit jiný překladač?
    24.1.2020 12:59 tttt
    Rozbalit Rozbalit vše Re: C++: jak lokální proměnná dokáže způsobit chybu při linkování?
    Ne jednoduše – projekt má pár desítek tisíc řádek a magický build systém, já tam jen něco dopisuju. Přijde mi pravděpodobnější, že tam je někde něco hodně ošklivého, co se nikdy nemá dělat, než že za to může překladač, ten projekt na to vypadá. Ale pustím se to toho, nic lepšího v zásobě nemám.
    24.1.2020 13:16 Peter Golis | skóre: 65 | blog: Bežné záležitosti | Bratislava
    Rozbalit Rozbalit vše Re: C++: jak lokální proměnná dokáže způsobit chybu při linkování?
    Tak to gratulujem. Ako starý je ten projekt, v päťročniciach? Vyzerá že ich mal viac ako 4.
    24.1.2020 11:11 rodi
    Rozbalit Rozbalit vše Re: C++: jak lokální proměnná dokáže způsobit chybu při linkování?
    Řádky 7 a 8 jsou také v hlavičkovém souboru? Pokud ano, tak se pravděpodobně pokoušíte vytvořit tu explicitní instanci šablony vícekrát, což není správně.

    https://en.cppreference.com/w/cpp/language/function_template - Explicit instantiation - deklarace vizte případy 3 a 4
    24.1.2020 11:47 tttt
    Rozbalit Rozbalit vše Re: C++: jak lokální proměnná dokáže způsobit chybu při linkování?
    Ne, explicitní instance šablony byly jen v .cpp. V hlavičkových souborech jsou makra, která hlídají opakované načtení (guards nebo #pragma once). Každopádně teorie o chybě v šabloně padly s tím, že to jde zopakovat i bez šablony.
    24.1.2020 13:24 Radek Isa | skóre: 14
    Rozbalit Rozbalit vše Re: C++: jak lokální proměnná dokáže způsobit chybu při linkování?

    Hele nechybí ti náhodou v hlavičkovém souboru

    #ifndef _TEST_HEADER_ #define _TEST_HEADER_ #endif

    Případně nadáváš linkeru dvakrát jeden objektový soubor? "already defined in http.obj" tohle znamená, že existují minimálně dva objekty stejně pojmenované. Proto bych hledal chybu v překladovém systému, nebo něco na způsob vkládání (include) jednoho stejného souboru dvakrát.

    24.1.2020 14:14 tttt
    Rozbalit Rozbalit vše Re: C++: jak lokální proměnná dokáže způsobit chybu při linkování?
    V hlavičkových souborech je
    #ifndef _TEST_HEADER_ #define _TEST_HEADER_ #endif 
    nebo
    #pragma once
    ověřoval jsem, že pragmu kompilátor podporuje.

    Mám teď teorii, že je někde v hlavičkovém souboru i definice a linker ten soubor dostane dvakrát, jak píšeš. Pokud překladač danou funkci inlinuje, tak se chyba neprojeví. Dává mi smysl, že kompilátor při objevení složitější proměnné přehodnotí inlinování, což vysvětluje, proč se to chování mění s odstraněním řádku. Příklad na to linkování je třeba na http://www.cplusplus.com/forum/beginner/104849/
    24.1.2020 14:44  
    Rozbalit Rozbalit vše Re: C++: jak lokální proměnná dokáže způsobit chybu při linkování?
    objdump toho http.obj by nepomohl?
    24.1.2020 15:25 MadCatX | skóre: 28 | blog: dev_urandom
    Rozbalit Rozbalit vše Re: C++: jak lokální proměnná dokáže způsobit chybu při linkování?
    Pokud to čtu dobře, dochází k násobné definici symbolu KUREVSKY_SLOŽITÁ_TEMPLATE::end(), v tvém případě iterátorové funkce end() pro std::map. Podívej se, kde jinde v kódu používáš std::map<std::string, std::string> a jak. Když změníš typ klíče na int, vypadá funkce end() jinak a už k té kolizi nedojde. Skoro to vypadá, jako by se ti z nějaké překladové jednotky jiné než http.obj ta funkce end() exportovala a proto se ti to srazí. Absolutní rána do prázdna: neprovádíš tam někde explicitní instanciace funkcí, co by žraly std:map<std::string, std::string> jako parametr?
    24.1.2020 17:03 tttt
    Rozbalit Rozbalit vše Re: C++: jak lokální proměnná dokáže způsobit chybu při linkování?
    std::map se tam skoro nepoužívá, šel jsem po výskytech. V jiném .cpp souboru je tato třída (ořezal jsem ji na minimum)
    namespace {
    	class foo {
    	public:
    		foo();
                    std::map<std::string, std::string> namespaces; 
    	};
    	foo::foo() {};
    }
    
    Takto to vyvolá chybu [1], což čtu jako konstruktor std::map<std::string, std::string>(). Zakomentování řádku v původním postu stačí, aby se to zkompilovalo. Kompilace také projde, pokud kód vypadá takto:
    namespace {
    	class foo {
    	public:
    		foo();
    		// std::map<std::string, std::string> namespaces;
    	};
    	foo::foo() {};
    }
    
    nebo takto
    namespace {
     class foo { 
        public: foo() {}; 
        std::map<std::string, std::string> namespaces; 
      }; 
    }
    
    V příslušném hlavičkovém souboru se třída foo nevyskytuje, jen v .cpp souboru. Nepoužívá se nikde (smazal jsem výskyty). Vysvětlení mě zatím nenapadá, zatím přemýšlím, co to říká.

    [1] Error LNK2005 "public: __cdecl std::map<class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> >,class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> >,struct std::less<class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> > >,class std::allocator<struct std::pair<class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> > const ,class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> > > > >::map<class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> >,class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> >,struct std::less<class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> > >,class std::allocator<struct std::pair<class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> > const ,class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> > > > >(void)" (??0?$map@V?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@V12@U?$less@V?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@@2@V?$allocator@U?$pair@$$CBV?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@V12@@std@@@2@@std@@QEAA@XZ) already defined in http.obj
    25.1.2020 12:02 MadCatX | skóre: 28 | blog: dev_urandom
    Rozbalit Rozbalit vše Re: C++: jak lokální proměnná dokáže způsobit chybu při linkování?
    Je zřejmé, že se definice funkcí pro std::map<std::string, std::string> objevují ve více překladových jednotkách a mají externí linkage, ale to ti asi došlo. S touhle situací by si měl linker poradit, protože u šablonových funkcí se tohle prostě děje. Zmínil jsi, že ten projekt má nějaký podivný build systém, možná bych se podíval, jestli se tam nějak podivně nešaškuje s STL kontejnery. Fakt by to chtělo nějaký minimální zkompilovatelný příklad, kdy se to rozbije.
    26.1.2020 16:08 Jardik
    Rozbalit Rozbalit vše Re: C++: jak lokální proměnná dokáže způsobit chybu při linkování?
    namespace {
        class foo {
        public:
            foo();
                    std::map<std::string, std::string> namespaces; 
        };
        inline foo::foo() {};
    }
    Zkus to takto. Chybi ti tam inline a pokud ten header includnes ze 2 cpp, budes tam mit 2 symboly pro ten jeden ctor. To, ze to funguje se zakomentovanou mapou, bude mozna kvuli optimalizaci, protoze ctor je pak noop.

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.