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 00:11 | Nová verze

    Open source modální textový editor Helix, inspirovaný editory Vim, Neovim či Kakoune, byl vydán ve verzi 25.07. Přehled novinek se záznamy terminálových sezení v asciinema v oznámení na webu. Detailně v CHANGELOGu na GitHubu.

    Ladislav Hagara | Komentářů: 0
    včera 20:44 | IT novinky

    Americký výrobce čipů Nvidia získal od vlády prezidenta Donalda Trumpa souhlas s prodejem svých pokročilých počítačových čipů používaných k vývoji umělé inteligence (AI) H20 do Číny. Prodej těchto čipů speciálně upravených pro čínský trh by tak mohl být brzy obnoven, uvedla firma na svém blogu. Americká vláda zakázala prodej v dubnu, v době eskalace obchodního sporu mezi oběma zeměmi. Tehdy to zdůvodnila obavami, že by čipy mohla využívat čínská armáda.

    Ladislav Hagara | Komentářů: 0
    včera 17:22 | Nová verze

    3D software Blender byl vydán ve verzi 4.5 s prodlouženou podporou. Podrobnosti v poznámkách k vydání. Videopředstavení na YouTube.

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

    Open source webový aplikační framework Django slaví 20. narozeniny.

    Ladislav Hagara | Komentářů: 0
    14.7. 16:11 | Komunita

    V Brestu dnes začala konference vývojářů a uživatelů linuxové distribuce Debian DebConf25. Na programu je řada zajímavých přednášek. Sledovat je lze online.

    Ladislav Hagara | Komentářů: 0
    14.7. 11:33 | IT novinky

    Před 30 lety, tj. 14. července 1995, se začala používat přípona .mp3 pro soubory s hudbou komprimovanou pomocí MPEG-2 Audio Layer 3.

    Ladislav Hagara | Komentářů: 26
    14.7. 10:55 | IT novinky

    Výroba 8bitových domácích počítačů Commodore 64 byla ukončena v dubnu 1994. Po více než 30 letech byl představen nový oficiální Commodore 64 Ultimate (YouTube). S deskou postavenou na FPGA. Ve 3 edicích v ceně od 299 dolarů a plánovaným dodáním v říjnu a listopadu letošního roku.

    Ladislav Hagara | Komentářů: 20
    13.7. 17:55 | Zajímavý projekt

    Společnost Hugging Face ve spolupráci se společností Pollen Robotics představila open source robota Reachy Mini (YouTube). Předobjednat lze lite verzi za 299 dolarů a wireless verzi s Raspberry Pi 5 za 449 dolarů.

    Ladislav Hagara | Komentářů: 17
    11.7. 16:44 | Komunita

    Dnes v 17:30 bude oficiálně vydána open source počítačová hra DOGWALK vytvořena v 3D softwaru Blender a herním enginu Godot. Release party proběhne na YouTube od 17:00.

    Ladislav Hagara | Komentářů: 3
    11.7. 14:55 | Humor

    McDonald's se spojil se společností Paradox a pracovníky nabírá také pomocí AI řešení s virtuální asistentkou Olivii běžící na webu McHire. Ian Carroll a Sam Curry se na toto AI řešení blíže podívali a opravdu je překvapilo, že se mohli přihlásit pomocí jména 123456 a hesla 123456 a získat přístup k údajům o 64 milionech uchazečů o práci.

    Ladislav Hagara | Komentářů: 16
    Jaký je váš oblíbený skriptovací jazyk?
     (59%)
     (26%)
     (7%)
     (3%)
     (1%)
     (1%)
     (4%)
    Celkem 398 hlasů
     Komentářů: 16, poslední 8.6. 21:05
    Rozcestník

    Dotaz: Ako odtestovať generický parameter na pole ľubovolnej

    11.10.2020 12:24 Naples
    Ako odtestovať generický parameter na pole ľubovolnej
    Přečteno: 264×
    Ako odtestovať generický parameter na pole ľubovolnej velkosti určitého typu?

    Včera som hľadal spôsob ako odtestovať či je generický parameter typu pole.

    problém je že funkcia is_same_v testuje pole len s presnou velkosťou.

    to znamená že ak mám pole:
    int[5]

    tak musím testovať
    is_same_v<T, int[5]>

    ale čo ak dopredu netuším veľkosť pola a potrebujem odtestovať či premenná má pole nejakého typu, ľubovolnej velkosti?

    testujem to zatiaľ takto:
    if constexpr (std::is_array_v<InputType> && std::is_same_v<InputType, ArrayType[std::extent_v<InputType>]>)
    {
        //niečo
    }
    else
    {
        static_assert(false, "Chyba, nesprávny typ")
    }
    Funguje to akurát som z toho chcel urobiť nejaký znovupoužiteľný kus kódu (trait, makro, alebo hocičo iné) a to už bolo nad moje sily. Celá tá template časť C++ je deklaratívna, pripomína mi trošku funkcionálne programovanie a vyzerá to dosť zaujímavo.
    1. Vedeli by ste mi poradiť ako si z tej podmienky urobiť trait?
    2. A tiež poradiť nejakú kvalitnú knihu (alebo iný zroj informácií kludne aj školenie) o šablónach v C++? Ja už mám doma 6 kníh o C++, niektoré sú riadne hrubé bichle, ale v žiadnej som nenašiel dostatočne obšírne vysvetlenú problematika šablón. Kniha môže byť kludne aj v AJ
    Ďakujem.

    Řešení dotazu:


    Odpovědi

    11.10.2020 13:25 z_sk | skóre: 34 | blog: analyzy
    Rozbalit Rozbalit vše Re: Ako odtestovať generický parameter na pole ľubovolnej
    Vo svete C by to tak mozno bolo:

    Nechces vela? Zakladne typy su pre nieco zakladne. Mozno by bolo dobre sa naucit C, pripadne ASM a ako funguje hardwer. Ked sa chces dobre. Ak ultra, tak elektroniku. Ono. Kazda technologia nieco dokaze, tak dalsia sa to snazi urobit, lahsie atd. A kazda technika ma svoje limity.

    struct { void *data; size_t bytes; int type; } data_t;
    debian.plus@protonmail.com
    11.10.2020 14:03 10minuteman
    Rozbalit Rozbalit vše Re: Ako odtestovať generický parameter na pole ľubovolnej
    1. mozna by ti pomohl enable_if ? Popravde nevim. Co te tu sleduju, prijde mi, ze s temi traity vytvaris nejake tezke voodoo. Proc nenechas kontrolu na prekladaci?

    2. Tahle je nejlepsi.
    Gréta avatar 11.10.2020 15:55 Gréta | skóre: 37 | blog: Grétin blogísek | 🇮🇱==❤️ , 🇵🇸==💩 , 🇪🇺==☭
    Rozbalit Rozbalit vše Re: Ako odtestovať generický parameter na pole ľubovolnej

    noa nestačilo by ti jakoby tam tu velikost pole prostě dycky zistit hele?? :O :O

    template <typename T, size_t n> constexpr size_t array_size(const T (&)[n]) { return n; }
    

    dyžtak se neuraz ale mam taky takovej pocit že se snažíš to cpp přivohnout ze silně typovýho jazyka na slabě typovej s timže tu kontrolu typů chceš asi nějak řešit sám :O ;D

    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.