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 17:33 | IT novinky

    Americký prezident Donald Trump vyzval nového generálního ředitele firmy na výrobu čipů Intel, aby odstoupil. Prezident to zdůvodnil vazbami nového šéfa Lip-Bu Tana na čínské firmy.

    Ladislav Hagara | Komentářů: 6
    včera 16:55 | Nová verze

    Bylo vydáno Ubuntu 24.04.3 LTS, tj. třetí opravné vydání Ubuntu 24.04 LTS s kódovým názvem Noble Numbat. Přehled novinek a oprav na Discourse.

    Ladislav Hagara | Komentářů: 0
    včera 16:44 | Nová verze

    Byla vydána verze 1.89.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.

    Ladislav Hagara | Komentářů: 0
    včera 12:22 | IT novinky

    Americká technologická společnost Apple uskuteční v USA další investice ve výši sta miliard dolarů (2,1 bilionu korun). Oznámil to ve středu šéf firmy Tim Cook při setkání v Bílém domě s americkým prezidentem Donaldem Trumpem. Trump zároveň oznámil záměr zavést stoprocentní clo na polovodiče z dovozu.

    Ladislav Hagara | Komentářů: 3
    včera 04:55 | Nová verze

    Zálohovací server Proxmox Backup Server byl vydán v nové stabilní verzi 4.0. Založen je na Debianu 13 Trixie.

    Ladislav Hagara | Komentářů: 0
    6.8. 16:33 | Nová verze

    Byla vydána nová verze 1.54.0 sady nástrojů pro správu síťových připojení NetworkManager. Novinkám se v příspěvku na blogu NetworkManageru věnuje Jan Václav.

    Ladislav Hagara | Komentářů: 0
    6.8. 14:11 | IT novinky

    Knižní edice správce české národní domény přináší novou knihu zkušeného programátora Pavla Tišnovského s názvem Programovací jazyk Go. Publikace nabízí srozumitelný a prakticky zaměřený pohled na programování v tomto moderním jazyce. Nejedná se však o klasickou učebnici, ale spíše o průvodce pro vývojáře, kteří s Go začínají, nebo pro ty, kdo hledají odpovědi na konkrétní otázky či inspiraci k dalšímu objevování. Tištěná i digitální verze knihy je již nyní k dispozici u většiny knihkupců.

    Ladislav Hagara | Komentářů: 2
    6.8. 13:11 | IT novinky

    OpenAI zpřístupnila (en) nové nenáročné otevřené jazykové modely gpt-oss (gpt-oss-120b a gpt-oss-20b). Přístupné jsou pod licencí Apache 2.0.

    Ladislav Hagara | Komentářů: 5
    6.8. 04:33 | Nová verze

    Byla vydána RC verze openSUSE Leap 16. S novým instalátorem Agama, Xfce nad Waylandem a SELinuxem.

    Ladislav Hagara | Komentářů: 0
    6.8. 03:44 | Nová verze

    Google Chrome 139 byl prohlášen za stabilní. Nejnovější stabilní verze 139.0.7258.66 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 12 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře. S verzí 139 přestal být podporován Android 8.0 (Oreo) a Android 9.0 (Pie).

    Ladislav Hagara | Komentářů: 0
    Kolik tabů máte standardně otevřeno ve web prohlížeči?
     (41%)
     (23%)
     (4%)
     (6%)
     (3%)
     (1%)
     (1%)
     (20%)
    Celkem 277 hlasů
     Komentářů: 23, poslední 4.8. 13:01
    Rozcestník

    Dotaz: kratky dotaz k iteratoru - C++

    20.11.2010 20:25 sranda_zitra
    kratky dotaz k iteratoru - C++
    Přečteno: 354×
    Dobry vecer a dobrou chut, pokud prave vecerite. Mel bych mensi dotaz k iteratoru od kontejneru vector. Vector ma v sobe pole toho, co zrovna drzi. Pokud bych se chtel k tomuto poli dostat (resp. k ukazateli na 1. prvek tohoto pole), provedu to tak, ze do L-Hodnoty dam promennou typu pointer na typ, ktery zrovna vector drzi a do R-Hodnoty napisu: &*mujVector.begin();

    napriklad: short int* p_sh = &*mujVector.begin().
    Muzu si tento kus kodu prelozit nasledovne? Hvezdickou rikam "vrat hodnotu" prvniho prvku v poli a ampersand + hvezdickou reknu "vrat adresu prvniho prvku v poli". Je to tak a nebo se mylim?

    Predem diky.

    Odpovědi

    20.11.2010 21:32 mrk
    Rozbalit Rozbalit vše Re: kratky dotaz k iteratoru - C++
    Je to skoro správne, &*mujVector.begin() vráti pointer na prvý prvok. Len menšia oprava - *mujVector.begin() nie je hodnota, ale referencia. Takže je možné napísať

    *mujVector.begin() = 42;
    

    21.11.2010 09:24 sranda_zitra
    Rozbalit Rozbalit vše Re: kratky dotaz k iteratoru - C++
    Diky, naprosto srozumitelne vysvetleni.
    vlastikroot avatar 20.11.2010 21:46 vlastikroot | skóre: 24 | blog: vlastikovo | Milevsko
    Rozbalit Rozbalit vše Re: kratky dotaz k iteratoru - C++
    Tohle by mě nenapadlo, proč to neni normálně int * p = mujVector.begin() ?
    We will destroys the Christian's legion ... and the cross, will be inverted
    20.11.2010 23:23 jekub
    Rozbalit Rozbalit vše Re: kratky dotaz k iteratoru - C++
    tohle je normalne?
    21.11.2010 00:06 Sinuhet | skóre: 31
    Rozbalit Rozbalit vše Re: kratky dotaz k iteratoru - C++
    Protoze nikde nemate zaruceno, ze iterator musi jit konvertovat na ukazatel na danny typ (pripadne, ze je primo jako ukazatel implementovan).
    vlastikroot avatar 21.11.2010 09:50 vlastikroot | skóre: 24 | blog: vlastikovo | Milevsko
    Rozbalit Rozbalit vše Re: kratky dotaz k iteratoru - C++
    Aha, díky. Takže u vectoru to sice funguje, ale je to prasárna.
    We will destroys the Christian's legion ... and the cross, will be inverted
    22.11.2010 17:14 Jirka P
    Rozbalit Rozbalit vše Re: kratky dotaz k iteratoru - C++
    Ne tak úplně, funguje to jen na konkrétní implementaci vectoru. Např. na MSVC v Debug módu jsou všechny iterátory objekty, jejichž metody obsahují (kromě předepsané funkčnosti) navíc asserty, takže tam to nefunguje.
    22.11.2010 14:54 Sten
    Rozbalit Rozbalit vše Re: kratky dotaz k iteratoru - C++
    Protože normálně je to:
    std::vector<int>::iterator it = mujVector.begin();
    Iterátor se chová stejně jako pointer.
    22.11.2010 14:51 Sten
    Rozbalit Rozbalit vše Re: kratky dotaz k iteratoru - C++
    Nedoporučuji to používat. Pokud vím, není zaručeno, že pole je souvislé, pouze že přístup k jednomu prvku má konstantní složitost. Místo pointerů používejte přímo iterátory, které se chovají jako stejně jako pointery.
    22.11.2010 15:22 Sinuhet | skóre: 31
    Rozbalit Rozbalit vše Re: kratky dotaz k iteratoru - C++

    Mylite se, u vektoru je vyslovne receno, ze polozky musi byt usporadany souvisle za sebou.

    The elements of a vector are stored contiguously, meaning that if v is a vector<T, Allocator> where T is some type other than bool, then it obeys the identity &v[n] == &v[0] + n for all 0 <= n < v.size().

    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.