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í
×
    dnes 03:33 | IT novinky

    Do prodeje jde tichá bezdrátová herní myš Logitech PRO X2 SUPERSTRIKE s analogovými spínači s haptickou odezvou (HITS, Haptic Inductive Trigger System). Cena je 4 459 Kč.

    Ladislav Hagara | Komentářů: 0
    včera 21:00 | Zajímavý projekt

    Microsoft na GitHubu zveřejnil zdrojový kód projektu LiteBox, jedná se o 'knihovní operační systém' (library OS) zaměřený na bezpečnost, využívající systémovou architekturu LVBS k ochraně jádra před útoky z uživatelského prostoru. LiteBox je napsán v Rustu a uvolněný pod licencí MIT. Projekt je teprve v rané fázi vývoje.

    NUKE GAZA! 🎆 | Komentářů: 0
    včera 16:11 | Zajímavý software

    BreezyBox je open-source shell a virtuální terminál pro populární jednočip ESP32. Nabízí základní unixové příkazy, sledování aktuálního pracovního adresáře (CWD), jednoduchý instalátor a spouštěč aplikací v podobě ELF binárních souborů, zabudovaný HTTP server nebo třeba ovládání WiFi - ukázka použití coby 'malého osobního počítače'. Ačkoliv je BreezyBox inspirovaný BusyBoxem, oproti němu má tento projekt několik externích závislostí, zejména na ESP-IDF SDK. BreezyBox je dostupný pod licencí MIT.

    NUKE GAZA! 🎆 | Komentářů: 0
    včera 16:00 | Humor

    Byl představen cross-assembler xa.sh, napsaný čistě v Bourne shell skriptu. Tento nástroj umožňuje zpracovávat assemblerový kód pro Intel 8080, přičemž je možné snadno přidat podporu i pro další architektury, například 6502 a 6809. Skript využívá pouze různé běžné unixové příkazy jako jsou awk, sed nebo printf. Skript si lze stáhnout z GitHubového repozitáře projektu.

    NUKE GAZA! 🎆 | Komentářů: 4
    6.2. 17:22 | IT novinky

    Byla představena nová verze modelu Claude Opus 4.6 od společnosti Anthropic. Jako demonstraci možností Anthropic využil 16 agentů Claude Opus 4.6 k vytvoření kompilátoru jazyka C, napsaného v programovacím jazyce Rust. Claude pracoval téměř autonomně, projekt trval zhruba dva týdny a náklady činily přibližně 20 000 dolarů. Výsledkem je fungující kompilátor o 100 000 řádcích kódu, jehož zdrojový kód je volně dostupný na GitHubu pod licencí Creative Commons.

    NUKE GAZA! 🎆 | Komentářů: 17
    6.2. 16:44 | Komunita

    Kultovní britský seriál The IT Crowd (Ajťáci) oslavil dvacáté výročí svého prvního vysílání. Sitcom o dvou sociálně nemotorných pracovnících a jejich nadřízené zaujal diváky svým humorem a ikonickými hláškami. Seriál, který debutoval v roce 2006, si i po dvou dekádách udržuje silnou fanouškovskou základnu a pravidelně se objevuje v seznamech nejlepších komedií své doby. Nedávné zatčení autora seriálu Grahama Linehana za hatecrime však vyvolává otázku, jestli by tento sitcom v současné Velké Británii vůbec vznikl.

    NUKE GAZA! 🎆 | Komentářů: 10
    6.2. 13:33 | IT novinky

    Společnost JetBrains oznámila, že počínaje verzí 2026.1 budou IDE založená na IntelliJ ve výchozím nastavení používat Wayland.

    Ladislav Hagara | Komentářů: 4
    6.2. 11:22 | IT novinky

    Společnost SpaceX amerického miliardáře Elona Muska podala žádost o vypuštění jednoho milionu satelitů na oběžnou dráhu kolem Země, odkud by pomohly zajistit provoz umělé inteligence (AI) a zároveň šetřily pozemské zdroje. Zatím se ale neví, kdy by se tak mělo stát. V žádosti Federální komisi pro spoje (FCC) se píše, že orbitální datová centra jsou nejúspornějším a energeticky nejúčinnějším způsobem, jak uspokojit rostoucí poptávku po

    … více »
    Ladislav Hagara | Komentářů: 26
    6.2. 11:11 | Nová verze

    Byla vydána nová verze 2.53.0 distribuovaného systému správy verzí Git. Přispělo 70 vývojářů, z toho 21 nových. Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    6.2. 04:22 | Komunita

    Spolek OpenAlt zve příznivce otevřených řešení a přístupu na 216. sraz, který proběhne v pátek 20. února od 18:00 v Red Hat Labu (místnost Q304) na Fakultě informačních technologií VUT v Brně na ulici Božetěchova 1/2. Tématem srazu bude komunitní komunikační síť MeshCore. Jindřich Skácel představí, co je to MeshCore, předvede nejrůznější klientské zařízení a ukáže, jak v praxi vypadá nasazení vlastního repeateru.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (19%)
     (6%)
     (0%)
     (10%)
     (25%)
     (3%)
     (5%)
     (2%)
     (12%)
     (29%)
    Celkem 795 hlasů
     Komentářů: 25, poslední 3.2. 19:50
    Rozcestník

    Dotaz: C++ ako na immutable štruktúry objekty?

    hermes avatar 12.9.2020 13:25 hermes | skóre: 7 | blog: Elektro | BA
    C++ ako na immutable štruktúry objekty?
    Přečteno: 620×
    Ahojte snažím sa v C++ zabrániť tomu aby mohol "vonkajší svet" meniť stav dátových štruktúr. Ale zároveň chcem aby sa niektoré propsy dali čítať.

    U properties som teda použil private membery, ktoré nastavuje konštruktor a na tie ukazujú public const referencie. Tým vlastne napodobňujem readonly atribúty z vyšších programovacích jazykov.

    Príklad:
    struct Pixel
    {
    private:
    	const float pX;
    	const float pY;
    	const RGBA128 pColour;
    public:
    	Pixel(
    		const float x,
    		const float y,
    		const RGBA128 colour
    	) :
    		pX(x),
    		pY(y),
    		pColour(colour)
    	{
    	}
    	const float X = pX;
    	const float Y = pY;
    	const RGBA128 Colour = pColour;
    };
    
    int main()
    {
    	auto pixel = Pixel{ 3840, 2160, RGBA128{ 245, 255, 255, 1 } };
    	std::wcout << "pixel.X = " << pixel.X << std::endl;
    	std::wcout << "pixel.Y = " << pixel.Y << std::endl;
    	pixel.X = 555; // chyba
    	return 0;
    }
    
    Lenže s referenciami sú problémy napríklad pri tom ak štruktúru prenesieme do iného procesu. Referecia stále ukazuje na rovnaké miesto v pamati, ale premenná medzitým zmenila svoju adresu, takže referencia po prenesení do iného procesu neukazuje na lokálnu premennú ale na hociaké random miesto, čo potom spôsobuje známy WTF efekt. Takže referencie sú pre mňa na tento účel out čím ich nahradiť?

    1. MS má svoje propertialne
    __declspec(property(get = get_prop)) int prop;
    ktoré síce nie sú súčasťou C++ štandardu, ale podporuje ich okrem MSVC aj Clang (ak je pouzity prepinac -fdeclspec). Keďže fungujem na Clangu tak by som to použil, ale táto konštrukcia má radu obmedzení najhoršie je, že ak chcem mať prop public tak aj get_prop musia byť public. Čo potom zneprehľadňuje celý interface. Takže táto možnosť vypadáva. Rovnaké propertialne riešenie má aj C++ Builder od Embarcadera (__property) ale ten ja nepoužívam. Každopádne __property má o niečo menej obmedzení.

    2. ďalšia možnosť je použiť templates a prekrývanie operátorov a naprogramovať si vlastnú implementáciu properties, ale to je za prvé pomalé a za druhé je to zbytočný overkill.

    3. ďalšia možnosť by bola použiť keyword implicit http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2004/n1611.pdf ktorý umožňuje zavolať funkciu bez zátvoriek čím vlastne nasimulujeme get property. Žiaľ tento keyword nepodporuje žiadny prehliadač.

    4. ďalšia možnosť by bola použiť get metódu, na štýl javy ale to mi príde neprirodzené:

    - keď chcem čítať pozíciu na Xovej osi, tak si intuitívne vypýtam X a nie getX() - slovo get niečo prikazuje a príkazy imho do funkcionálneho programovania nepatria. - okrem toho to je to 5 znakov navyše ktoré zhoršujú čitateľnosť kódu

    5. poznáte nejakú inú možnosť??? ako nasimulovať readonly atribút / property?

    POZN: Nepýtajte sa prečo používam na pozíciu pixela floaty, mám to kôli výpočtom ale to je na teraz implementačný detail.

    Řešení dotazu:


    Odpovědi

    hermes avatar 12.9.2020 13:27 hermes | skóre: 7 | blog: Elektro | BA
    Rozbalit Rozbalit vše Re: C++ ako na immutable štruktúry objekty?
    OPRAVA: ďalšia možnosť by bola použiť keyword implicit http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2004/n1611.pdf ktorý umožňuje zavolať funkciu bez zátvoriek čím vlastne nasimulujeme get property. Žiaľ tento keyword nepodporuje žiadny PREKLADAČ.
    12.9.2020 14:25 Ondra Holub
    Rozbalit Rozbalit vše Re: C++ ako na immutable štruktúry objekty?
    Reference tam nemáš, chybí tam ampersand: const float& X = pX;

    Jestli chápu správně, že ti vadí to, že reference i po vytvoření kopie instance odkazují na původní hodnoty, tak si prostě nadefinuj vlastní copy kontruktor tak, aby odkazovaly na správné hodnoty.

    A obecně - jestli jsou ty member hodnoty const, tak je prostě udělej public a není co řešit, ne?
    12.9.2020 15:45 MadCatX | skóre: 28 | blog: dev_urandom
    Rozbalit Rozbalit vše Re: C++ ako na immutable štruktúry objekty?
    Něco takového?
    #include <iostream>
    #include <string>
    
    template <typename T, bool>
    struct PTypeGetter {};
    
    template <typename T>
    struct PTypeGetter<T, true> {
            using Type = typename std::decay<T>::type;
    };
    
    template <typename T>
    struct PTypeGetter<T, false> {
            using Type = const typename std::decay<T>::type &;
    };
    
    template <typename T>
    struct PType {
            using Type = typename PTypeGetter<T, std::is_fundamental<T>::value>::Type;
    };
    template <typename T>
    using PType_t = typename PType<T>::Type;
    
    #define CONST_PROPERTY(type, name) \
            private: \
            const type m_##name; \
            public: \
            PType_t<type> name () const { return m_##name; }
    
    #define MUT_PROPERTY(type, name) \
            private: \
            type m_##name; \
            public: \
            PType_t<type> name () const { return m_##name; }
    
    class A {
    public:
            A(int x, std::string s) :
                    m_x{x},
                    m_s{std::move(s)},
                    m_f(x * 3.3f)
            {
                    std::cout << std::hex << &m_s << std::endl;
            }
    
            A & operator=(const A &other)
            {
                    m_x = other.m_x;
                    m_s = other.m_s;
                    const_cast<float&>(m_f) = other.m_f;
                    return *this;
            }
    
            MUT_PROPERTY(int, x)
            MUT_PROPERTY(std::string, s)
            CONST_PROPERTY(float, f)
    };
    
    int main()
    {
            A a(5, "abc");
            auto b = a;
    
            std::cout << b.x() << " " << b.s() << " " << b.f() << std::endl;
    }
    
    Sice bys mohl všechny properties udělat jako public const proměnné ale ty se dají modifikovat <const_castem. Hodnoty vrácené z getterů jsou vůči tomu imunní.
    12.9.2020 18:47 Kit | skóre: 46 | Brno
    Rozbalit Rozbalit vše Re: C++ ako na immutable štruktúry objekty?
    Zakomponuj výstup dovnitř struktury jako metodu.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    12.9.2020 19:10 .
    Rozbalit Rozbalit vše Re: C++ ako na immutable štruktúry objekty?
    Odpověď je, že v C++ tomu absolutně nezabráníš nikdy. A komentář těch nesmyslů je *facepalm*.
    17.9.2020 23:55 10minuteman
    Rozbalit Rozbalit vše Re: C++ ako na immutable štruktúry objekty?

    Těmi "vyššími programovacími jazyky" očividně myslíš C#. No, názory se liší. :D První věc auto pixel = Pixel{ 3840, 2160, RGBA128{ 245, 255, 255, 1 } }; je nesmysl. Není to syntakticky špatně, ale je to nesmysl a nedělá to to, co si myslíš. Nedržíš nějakou referenci na objekt, ale vytváříš objekt a pak jej přiřadíš jinému objektu. V C++ správně je to Pixel pixel { 3840, 2160, RGBA128{ 245, 255, 255, 1 } }; Dále, žádné reference nepoužíváš. Nastavuješ private atributy podle konstruktoru a pak nastavuješ další, nesouvisející public atributy podle hodnot private atributů. Dále, reference jsou jenom jiná jména pro objekty. Jediný způsob, jak objekt přenést do jiného procesu, je jej zkopírovat (pochopitelně; jiný proces ma jiný stack, heap i data segment). Reference stále ukazuje na to samé, protože je to to samé. (V zásadě je to const pointer.) Otázka zní, o co konkrétně se snažíš? Otázka druhá zní, proč si to tolik komplikuješ? (Ano, C++ má pověst komplikovaného jazyka, ale tak 80 % problémů si způsobují uživatelé sami.) C# property jsou obyčenjé gettery, prostě si je pojmenuj jinak. Upřímně, v C++ to stačí takhle:

    struct Pixel
    {
        const float X;
        const float Y;
        const float RGBA128 Colour;
    };
    
    int main()
    {
        const Pixel pixel { 3840, 2160, { 245, 255, 255, 1 }};
        std::wcout << "pixel.X = " << pixel.X << "\npixel.Y = " << pixel.Y << '\n';
        pixel.X = 555; // chyba
        return 0;
    }
    

    18.9.2020 11:02 ttttttttt
    Rozbalit Rozbalit vše Re: C++ ako na immutable štruktúry objekty?

    První věc auto pixel = Pixel{ 3840, 2160, RGBA128{ 245, 255, 255, 1 } }; je nesmysl. Není to syntakticky špatně, ale je to nesmysl a nedělá to to, co si myslíš. Nedržíš nějakou referenci na objekt, ale vytváříš objekt a pak jej přiřadíš jinému objektu

    auto pixel = Pixel{ 3840, 2160, RGBA128{ 245, 255, 255, 1 } }; zavolá konstruktor, ne copy assignment operátor, stejně jako Pixel pixel { 3840, 2160, RGBA128{ 245, 255, 255, 1 } }; . Ty zápisy jsou podle mě ekvivalentní.
    #include <iostream>
    
    class foo {
      int magic;
    
    public:
      foo(int magic) : magic(magic) {
        std::cout << "constructor called" << std::endl;
      }
    
      foo &operator=(const foo &other) {
        std::cout << "assignment operator called" << std::endl;
        this->magic = other.magic;
        return *this;
      }
    };
    
    int main(int argc, char *argv[]) {
      auto bar = foo{42};
      return 0;
    }
    
    $ ./a.out
    constructor called
    
    18.9.2020 22:13 10minuteman
    Rozbalit Rozbalit vše Re: C++ ako na immutable štruktúry objekty?
    Ano, překladač tohle může udělat, ale je to optimalizace. Osobně bych netvrdil, že jsou ekvivalentní, ale asi je to věc názoru.

    Je pravda, že třeba Herb Sutter podobnou syntaxi dříve prosazoval jako způsob, jak zabránit neinicializovaným proměnným (s auto musíte vždy inicializovat).
    18.9.2020 23:25 ttttttttt
    Rozbalit Rozbalit vše Re: C++ ako na immutable štruktúry objekty?
    Ano, překladač tohle může udělat, ale je to optimalizace.
    Ne, tohle rozhodně nemůže překladač udělat jako optimalizaci. Některé věci jsou ve specifikaci jako implementation dependent, ale tohle ne.
    Osobně bych netvrdil, že jsou ekvivalentní, ale asi je to věc názoru.
    Buď je ve speficikaci, že to je totéž, nebo ne.

    Přečti si třeba na http://www.cplusplus.com/doc/tutorial/classes/#uniform_initialization, jsou to jen různé zápisy konstruktoru. A říkají, že je víceméně jedno, kterou použít:
    The choice of syntax to call constructors is largely a matter of style. Most existing code currently uses functional form, and some newer style guides suggest to choose uniform initialization over the others, even though it also has its potential pitfalls for its preference of initializer_list as its type.

    19.9.2020 15:48 10minuteman
    Rozbalit Rozbalit vše Re: C++ ako na immutable štruktúry objekty?
    Máš pravdu, chová se to tak, jak říkáš.

    Ty čtyři varianty inicializace samozřejmě znám, ale považoval jsem za rozdílné
    auto pixel = { 3840, 2160, RGBA128{ 245, 255, 255, 1 } }; 
    a
    auto pixel = Pixel{ 3840, 2160, RGBA128{ 245, 255, 255, 1 } };
    Něco ve smyslu tohoto.

    Každopádně si nemyslím, že je to dobrá syntax.
    19.9.2020 15:51 10minuteman
    Rozbalit Rozbalit vše Re: C++ ako na immutable štruktúry objekty?
    oprava, mělo tam být
    Pixel pixel = { 3840, 2160, RGBA128{ 245, 255, 255, 1 } };
    nikoli
    auto pixel = { 3840, 2160, RGBA128{ 245, 255, 255, 1 } };

    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.