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 12:55 | Nová verze

The Document Foundation oznámila na svém blogu vydání verze 5.4 svobodného kancelářského balíku LibreOffice. Z novinek lze zmínit například podporu podepisování ODF dokumentů pomocí OpenPGP klíčů. Podrobnosti v poznámkách k vydání a na YouTube.

Ladislav Hagara | Komentářů: 0
dnes 12:11 | Zajímavý článek

Bylo vydáno (pdf) již šedesáté číslo stostránkového anglicky psaného časopisu MagPi věnovanému Raspberry Pi a projektům postaveným na tomto jednodeskovém počítači. K dispozici je také jako papírový časopis za 5,99 £.

Ladislav Hagara | Komentářů: 0
dnes 02:44 | Nová verze

Byl vydán Sway ve verzi 0.14. Přehled opravených chyb, změn a novinek v nejnovější verzi tohoto dlaždicového (tiling) správce oken pro Wayland kompatibilního s i3 na GitHubu. Do vývoje se zapojilo 12 vývojářů [reddit].

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

Byla vydána verze 4.0 svobodného systému pro detekci a prevenci průniků a monitorování bezpečnosti počítačových sítí Suricata (Wikipedie). Přehled novinek v poznámkách k vydání a v aktualizované dokumentaci. Ve dnech 15. až 17. listopadu proběhne v Praze konference vývojářů a uživatelů Suricaty SuriCon 2017.

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

Byla vydána dvaadvacátá alfa verze svobodné historické realtimové strategie 0 A.D. (Wikipedie). Kódový název této nejnovější verze je Venustas. Představení novinek také na YouTube.

Ladislav Hagara | Komentářů: 3
včera 11:33 | Zajímavý článek

Radek Vokál v článku Boltron – náhled modulárního operačního systému (en) na MojeFedora.cz představuje a informuje o možnosti vyzkoušet si Boltron, prototyp modulární distribuce. Pro Fedoru 26 je k dispozici testovací docker kontejner, který obsahuje modifikovanou verzi správce balíčků DNF, který na pozadí pracuje s moduly.

Ladislav Hagara | Komentářů: 3
včera 07:00 | Nová verze

ZFS on Linux, tj. implementace OpenZFS (Wikipedie) na Linuxu, byl vydán ve verzi 0.7.0. Přehled novinek v diskusním listu zfs-announce nebo na GitHubu. Nejnovější ZFS on Linux je kompatibilní s Linuxem 2.6.32 až 4.12.

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

V Las Vegas končí bezpečnostní konference Black Hat USA 2017 (Twitter) a začíná bezpečnostní konference DEF CON 25 (Twitter). V rámci Black Hat budou vyhlášeny výsledky letošní Pwnie Awards (Twitter). Pwnie Awards oceňují to nejlepší, ale i to nejhorší z IT bezpečnosti (bezpečnostní Oscar a Malina v jednom). V kategorii "Lamest Vendor Response" byl například nominován také Lennart Poettering za jeho přístup k řešení bezpečnostních chyb v systemd, viz například chyba s uživatelem 0day.

Ladislav Hagara | Komentářů: 5
včera 00:22 | Bezpečnostní upozornění

Nitay Artenstein z Exodus Intelligence se v příspěvku na blogu společnosti podrobně věnuje bezpečností chybě Broadpwn (CVE-2017-9417). Její analýzu provedl také Zhuowei Zhang na blogu Booster Ok. Jedná se o chybu ve firmwaru Wi-Fi chipsetů BCM43xx od Broadcomu. Útočník může vzdáleně získat kontrolu nad zařízením. Chyba byla již opravena v macOS, iOS i Androidu [Hacker News].

Ladislav Hagara | Komentářů: 4
26.7. 22:55 | IT novinky

Intel končí s vývojovými deskami Joule, Edison, Galileo a také s Arduino 101 a Curie.

Ladislav Hagara | Komentářů: 1
Těžíte nějakou kryptoměnu?
 (5%)
 (2%)
 (20%)
 (74%)
Celkem 133 hlasů
 Komentářů: 8, poslední včera 21:30
    Rozcestník
    Štítky: není přiřazen žádný štítek

    Dotaz: Jakasi magie pri dynamickem alokovani pameti [C++]

    Bundas avatar 30.8.2014 20:01 Bundas | skóre: 14 | Pardubice
    Jakasi magie pri dynamickem alokovani pameti [C++]
    Přečteno: 946×
    Jakto, ze tohle:
    using namespace std;
    
    int main()
    {
        int n = 7;
        int *slova2 = new int[n];
        slova2[0] += 23;
        slova2[0] += 32;
        cout << slova2[0] << endl;
        return 0;
    }
    
    na vystupu vyhodi pokazde random cislo? Treba tohle: 6230608
    Abe the Messiah has come.

    Řešení dotazu:


    Odpovědi

    Řešení 4× (Murry, Bundas (tazatel), rADOn, Vojtěch Trefný)
    Josef Kufner avatar 30.8.2014 20:05 Josef Kufner | skóre: 67
    Rozbalit Rozbalit vše Re: Jakasi magie pri dynamickem alokovani pameti [C++]
    Protože čteš neinicializovanou paměť na 3. řádku v těla main() operátorem +=.
    Hello world ! Segmentation fault (core dumped)
    8.9.2014 11:30 lofcek
    Rozbalit Rozbalit vše Re: Jakasi magie pri dynamickem alokovani pameti [C++]
    Presne tak .. suvisi to s tym, ze nepoznate zaklady. Premenne v C su defaultne neinicialovane - co znamena slova2 = new int[n], naalokuje 7 prvkov. Ale nikto vam nezaruci, aku hodnotu ma slova2[0], slova2[1] .. atd. Zvysok programu uz len k neznamenu cislu pripocita 55 a vypisuje.
    8.9.2014 11:37 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Jakasi magie pri dynamickem alokovani pameti [C++]
    Premenne v C su defaultne neinicialovane

    Jen pro pořádek: tohle není C. Takže přesnější vysvětlení je, že typ int nemá defaultní konstruktor, který by hodnotu inicializoval.

    8.9.2014 12:15 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Jakasi magie pri dynamickem alokovani pameti [C++]
    Premenne v C su defaultne neinicialovane

    A pro úplnost: tohle ani není obecně pravda.

    8.9.2014 16:05 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Jakasi magie pri dynamickem alokovani pameti [C++]

    A pro úplnost:

    V C jsou static a „globální“ proměnné inicializované (zjednodušeně na 0).

    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    9.9.2014 13:32 lertimir | skóre: 60 | blog: Par_slov
    Rozbalit Rozbalit vše Re: Jakasi magie pri dynamickem alokovani pameti [C++]
    Možná není na škodu očekávat vždy a všude neinicializované proměnné. Já se tímto řídím už 30 let ve všech jazycích, které jsem používal, (Algol, FORTRAN, Basic, Ada, Pascal, C, C++, perl, python, php, java, javascript, co si pamatuji). To že to inciální přiřazení má člověk explicitně zapsané v kódu mu dá jistotu, že , co v proměnné je. A to nejen při psaní, ale zvláště po čase, kdy si nad kódem říká: Sakra co jsem tím myslel. A duplicita takového přiřazení v případě, že to jazyk dělá sám je zanedbatelná.
    9.9.2014 15:39 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Jakasi magie pri dynamickem alokovani pameti [C++]

    Nic než souhlas(, nesouhlasil bych s „povinnou“ inicializací při deklaraci ;)).

    Přemýšlet nad tím jinak v C(/C++) je vždy kravina, bo tam je to nebo to(, ne ‚a‘), a „auto inicializace“ v těchto specifických případech je tam tak nějak z pohledu programátora navíc.

    static int i = 0;
    
    je to samé(, nebo by mělo být) co
    static int i;
    bo „auto inicializace“ se děje jen v 2. případě.
    u:
    static int i;
    i = 0;
    
    už může být incicializace (bez optimalizace) 2×.

    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    10.9.2014 09:01 Sten
    Rozbalit Rozbalit vše Re: Jakasi magie pri dynamickem alokovani pameti [C++]
    Není to to samé.
    static int i;
    Tohle tu proměnnou vytvoří vynulovanou při startu programu a pak už s ní nic nedělá.
    static int i = 0;
    Tohle tu proměnnou nastaví ještě jednou při inicializaci statických proměnných v dané kompilační jednotce. Tedy pokud jiná statická inicializace z jiné kompilační jednotky tu hodnotu změní, tohle ji může a nemusí přepsat (protože pořadí statických inicializací mezi kompilačními jednotkami není definované).

    To první se využívá u nifty counteru.
    10.9.2014 09:16 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Jakasi magie pri dynamickem alokovani pameti [C++]
    Tedy pokud jiná statická inicializace z jiné kompilační jednotky tu hodnotu změní

    Ta proměnná je static, takže ji z jiné kompilační jednotky z definice přepsat nemůžete.

    10.9.2014 21:01 Sten
    Rozbalit Rozbalit vše Re: Jakasi magie pri dynamickem alokovani pameti [C++]
    Pravda, není to vlastně static member.
    11.9.2014 00:19 ebik | skóre: 2
    Rozbalit Rozbalit vše Re: Jakasi magie pri dynamickem alokovani pameti [C++]
    Kdyz pouzijes nejake bloky co maji __attribute__((constructor)), tak ty se mohou provest drive nez inicializace globalni staticke promenne. Svanda je, z takoveho bloku zavolat funkci, ktera pristupuje ke globalni staticke promenne, a predpoklada, ze je naicializovana. Co hur, v C++ u globalnich statickych objektu typicky predpoklada, ze se provedl konstruktor.

    Rozlisovani ruznych typu konstruktoru a pretizeni operatoru = v C++ je pak kapitola sama o sobe.
    11.9.2014 00:22 ebik | skóre: 2
    Rozbalit Rozbalit vše Re: Jakasi magie pri dynamickem alokovani pameti [C++]
    Můžete ale z jiné kompilační jednotky zavolat funkci, která k té proměnné přistupuje (a třeba ji přepisuje). To se v C udělá zavoláním z bloku s __attribute__((constructor)) a v na to staci C++ proste volani z konstruktoru globalniho statickeho objektu.
    11.9.2014 00:23 ebik | skóre: 2
    Rozbalit Rozbalit vše Re: Jakasi magie pri dynamickem alokovani pameti [C++]
    ... a v C++ n to staci ...
    11.9.2014 08:40 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Jakasi magie pri dynamickem alokovani pameti [C++]
    Pominu-li, že __attribute__((constructor)) je GCC specific (není to standard), tak se stejně provádí až po inicializací static proměnných, nepletu-li se.
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    10.9.2014 12:41 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Jakasi magie pri dynamickem alokovani pameti [C++]

    Jak?

    Jsem přesvědčen, že ty zápisy jsou identické a gcc generuje identický kód.

    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    11.9.2014 23:22 Sten
    Rozbalit Rozbalit vše Re: Jakasi magie pri dynamickem alokovani pameti [C++]
    Tak jsem si prošel standard a je to takto:
    1. Prvně se provede zero inicializace
    2. Poté se provede konstantová inicializace; standard dovoluje tohle spojit s předchozím
    3. Nakonec se provede inicializace výrazy a tady nastává problém, protože není definováno pořadí
    Takže v C se to stát nemůže, protože nezná inicializaci výrazy (pokud pominu __attribute__((constructor))).

    Ale aby to nebylo tak snadné, tak konstantová inicializace se provádí jen compile-time konstantami, tj. literály či constexpry, nikoliv const proměnnými. Ten problém, co jsem měl, byl právě použití constu k inicializaci na 0 (v pre-C++11 jsem měl nullptr nadefinovaný jako const).
    12.9.2014 14:52 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Jakasi magie pri dynamickem alokovani pameti [C++]
    Jsem si myslel, a nechce se mi to hledat, že 1. je tak, že inicializace static se má dít v jednom kroku a buď se inicializuje na „0“, nebo na hodnotu, která je při deklaraci explicitně uvedena a const tam nehraje žádnou roli.
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    12.9.2014 16:58 Sten
    Rozbalit Rozbalit vše Re: Jakasi magie pri dynamickem alokovani pameti [C++]
    Nikoliv inicializace proměnné, která je const, ale inicializace proměnné hodnotou jiné proměnné, která je const.
    10.9.2014 19:10 lertimir | skóre: 60 | blog: Par_slov
    Rozbalit Rozbalit vše Re: Jakasi magie pri dynamickem alokovani pameti [C++]
    Já to téměř vždy dělal tím 3. způsobem. Právě proto, že takto mi to umožní každý jazyk, dostanu tím oddělený kus kodu
    // inicializace promměných
    i=0;
    ...
    // konec inicializace
    po kterém vím, že všechny proměnné musí mít hodnotu. A jak jsem říkal, ten řádek kódu navíc mi nevadil ani v dobách Fortranu, děrných štíků a mainframu s 256 kB operační paměti, natož dnes.
    11.9.2014 08:27 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Jakasi magie pri dynamickem alokovani pameti [C++]
    Blbé je, když je to právě static a, tak máš inicializace dvě, jedna při deklaraci a druhá při tvé inicializaci. Asi to v 99% případech nevadí, ale já když to vím, tak mě to žere…
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    11.9.2014 16:19 lertimir | skóre: 60 | blog: Par_slov
    Rozbalit Rozbalit vše Re: Jakasi magie pri dynamickem alokovani pameti [C++]
    :-) To máš pravdu. Je to síla zvyku. Ale to víš, FORTRANský programátor může psát aritmetické IF v jakémkoliv jazyce. :-) (A odkaz pro ty, co neví, co je artimetické IF)
    11.9.2014 19:54 Op
    Rozbalit Rozbalit vše Re: Jakasi magie pri dynamickem alokovani pameti [C++]
    Mám pocit, že s tou dvojí inicializací příliš podceňuješ inteligenci dnešních kompilátorů.
    12.9.2014 14:29 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Jakasi magie pri dynamickem alokovani pameti [C++]

    Mám pocit, že moc věříš optimalizaci, která by, dle mého, mohla být nad rámec povoleného.

    Zatímco s static int j = 0; a static int j; gcc generuje identický kód, s static j; j = 0; již jiný/delší (nenamáhám se to disasemblovat, stačí fstat a md5sum).

    Zkus si:

    //use: gcc -O3 test.c -o test && md5sum ./test
    //cygwin use: gcc -O3 test.c -o test.exe && md5sum ./test
    
    #include <stdio.h>
    #include <limits.h>
    
    int main(){
      int iii = INT_MAX;
      /* 1. --- explicit --- */
      static int i = 0;
      /* ---------------- */
      
      /* 2. --- implicit --- */
      //static int i;
      /* ---------------- */
      
      /* 3. ---- twice ---- */
      //static int i;
      //i = 1;
      /* ---------------- */
      
      printf("%d",iii - i);
      return 0;
    }
    

    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    12.9.2014 15:49 ebik | skóre: 2
    Rozbalit Rozbalit vše Re: Jakasi magie pri dynamickem alokovani pameti [C++]
    O tom ze 3. je jine nez 1. a 2. snad nepochybuje nikdo. main() je totiz funkce jako kazda jina, 3. /musi/ nastavit "i" pri /kazdem/ zavolani. (A v pripade 3 nedava moc velky smysl mit takovou promennou jako statickou. Snad jen ze nebude na zasobniku, nebo kdyz bude nekdo vymyslet reentrant detection.)

    Myslim, ze predrecnici se bavili o optimalizaci v pripade nestatickych lokalnich promennych.
    12.9.2014 16:08 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Jakasi magie pri dynamickem alokovani pameti [C++]

    O tom ze 3. je jine nez 1. a 2. snad nepochybuje…
    No a o tom to právě je, že jsou tam ty dvě inicializace, které nemohou/by neměly být při kompilaci optimalizovány, i když by to v tomto případě, nemělo žádný faktický dopad.

    Myslim, ze predrecnici se bavili o optimalizaci v pripade nestatickych lokalnich promennych.
    Co to?, mně přijde, že se bavíme o static od začátku, a pak píšu právě o static a na to je reakce o podcenění optimalizace.

    PS: Ad. pochyby o smyslu, on ten příklad nedává smysl ani jako celek, to je častý úděl moc krátkých příkladů. Tak si představ, že je tam nějaké if a fce se volá opakovaně.

    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    12.9.2014 22:38 ebik | skóre: 2
    Rozbalit Rozbalit vše Re: Jakasi magie pri dynamickem alokovani pameti [C++]
    Omlouvam se, myslel jsem jeste na jine veci, a cetl jsem jiz jen par poslednich prispevku, mate samozrejme pravdu ze o static se jedna.

    Co se tyce disasemblovani, tak na produkty gcc lze spustit objdump. Tim se napriklad zjisti, ze standardni elf na linuxu inicializuje lokalni staticke promenne (C) nactenim sekce .data do pameti. Tedy stara se o to elf loader a nikoli program samotny. Take se tim zjisti, ze "static int foo = 12;" se vubec nikam neulozi, pokud se do te lokalni promenne foo nikdy nezapise. Tedy kompilator to zoptimalizuje jako konstantu.
    11.9.2014 19:28 kuka
    Rozbalit Rozbalit vše Re: Jakasi magie pri dynamickem alokovani pameti [C++]
    Jestlize uvadis javu, tak tam je toto antipattern. Pokud se ponecha neinicializovana (plati pro lokalni promennou), kompilator vyhodi chybu, pokud by se v tomto stavu pouzila. Tim se odchyti pripady, kdy ucelem bylo hodnotu pozdeji naplnit smysluplne (napriklad vekem cloveka), ale v kodu je chyba, treba if vetveni nepokryva vsechny pripady apod. Pokud si tam dam inicialne 0, tak se mi to prelozi a zavola s nulou, coz jsem nechtel.

    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.