• úvod
  • témata
  • události
  • tržiště
  • diskuze
  • nástěnka
  • přihlásit
    registrace
    ztracené heslo?
    XCHAOSANSI C/C99 (specifikace), GNU C (gcc, glibc), Tiny C (tcc) a POSIX - ne nutně C++,g++,libstdc++ nebo Win32 API
    XCHAOS
    XCHAOS --- ---
    DAVIDOWITCH: mě přijde, že ten malloc() je docela rychlej, ale to může záležet na implementaci ... v některý implementaci malloc() může být klidně schovaný volání garbabge collectoru, který hledá volné místo...
    XCHAOS
    XCHAOS --- ---
    ANT_39: to je zajímavý odkaz, ale upozorňuju, že moje (rozpracované) memory pooly nejsou plnohodnotná náhrada obecného alokátoru zahrnujícího zcela obecnou garbage collection... od začátku počítám s tím, že je tam nějaký tradeoff, tedy že něco bude rychlejší - a na oplátku to něco jiného nebude umět vůbec
    REDGUY
    REDGUY --- ---
    XCHAOS: a proc nemuzes kratke stringy a docasne veci drzet na stacku?
    XCHAOS
    XCHAOS --- ---
    ANT_39: no tak s tím reallocem právě moc nepočítám - resp. neumím si to představit. pokud si budeš chtít pole reallocovat, mělo by to být pole alokované v první řadě normálním allocem().

    mám to myšlené hlavně na krátké stringy a různé dočasné obsahy textových souborů či HTTP requestů načtené do paměti... jinak moje oblíbená struktura spojový seznam je s touto metodou alokace kompatibilnější, než právě třeba pole náhodné délky :-) vlastně jste mě moje vize nejvíc rozbili tím, jak jste mě upozornili, že díky cacheování paměti přímo v jádře CPU už nejsou spojové seznamy až tak efektivní, jako byly např. v éře před 15ti lety (kdy se _už_ nedělalo onboard cacheování RAM, ale současně se _ještě_ nedělalo onchip cacheování...)
    REDGUY
    REDGUY --- ---
    JANFROG: ehm. OSX neni slusny system?
    JANFROG
    JANFROG --- ---
    JACHYMKO: Budes se divit, ale je. Protoze pri pocitani referenci, overhead prirazeni je
    - fetch, decrement, store
    - fetch, increment, store

    To je duvod - krom cyklickych referenci - proc se pocitani referenci nepouziva jako garbage collector (ve slusnych systemech)


    REDGUY
    REDGUY --- ---
    kolikrát by si se zdržoval počítáním referencí i ve chvíli, kdy ti je jasné, že paměť o pět řádků dál zase zahodíš - nerozumim. Jak, zdrzoval? Reknu si o pamet, o pet radku dal reknu at se zmensi pocet referenci a pamet se uvolni. Kde je zdrzovani? Mozna bys mel ukazat nejake konrektni use-case kde si myslis ze bude tvuj pristup lepsi, ne?
    DAVIDOWITCH
    DAVIDOWITCH --- ---
    Skoro vubec? Alokovat pamet na pet trivialnich radku je samo o sobe podezrely, na pet komplexnich radku te to nezdrzi a tech pet komplexnich radku muze delat veci volnejc.
    XCHAOS
    XCHAOS --- ---
    REDGUY: no ano, já dokonce chvíli vymýšlel, že kdyby se místo = použilo nějaké makro - třeba let( ) - tak by to šlo poloautomatizovat. ale fakt je, že na to prostě kašlu - vezmi si jen, kolikrát by si se zdržoval počítáním referencí i ve chvíli, kdy ti je jasné, že paměť o pět řádků dál zase zahodíš...
    REDGUY
    REDGUY --- ---
    XCHAOS: počítaný reference jsou v C vyloučený, v podstatě. - ale kdeze. Kdyz uz, tak _automaticky_ pocitany reference jsou vylouceny. Normalni pocitani referenci delat muzes zcela bez problemu, akorat se o to musis starat (uplne stejne jako se budes aspon castecne muset starat o alokaci pameti v tvem systemu).
    DAVIDOWITCH
    DAVIDOWITCH --- ---
    XCHAOS: Nebyla tu uz debata o pocitanejch referencich?
    Shrnu co si pamatuju: Ne, nejsou vylouceny. Ne, nepotrebujes pretizeny operatory. Ano, musis pak delat add/remove manualne. Koukni se na ObjectiveC jak to dela.
    (netreba se o tom hadat, ja svoji pozici nezmenim, ty svoji pozici nezmenis, jen sem to chtel pripomenout).

    To co tu resis je uplne klasickej mempool. Ma to spoustu vyhod (rychla alokace, rychla dealokace), ale jakmile to jednou alokujes, nemuzes to uvolnit jinak nez vsechno najednou. Obal si necim mallocy a zjisti jaky mas bezny access patterns pro svoje planovany pouziti.
    XCHAOS
    XCHAOS --- ---
    DAVIDOWITCH: počítaný reference jsou v C vyloučený, v podstatě.

    uvažuju "ukusovat" malé kousky paměti z větších bloků a hlídat jen "kolik ještě zbývá"... a pak zahazovat ty větší bloky najednou.

    spíš nevím, jestli to dělit na "malloc/krátkodobé" nebo "malloc/střednědobé/krátkodobé".
    DAVIDOWITCH
    DAVIDOWITCH --- ---
    Ten handoff pameti by mozna sel udelat tak, ze by pointer mel nejakej flag (ze se nema volat explicitni free) a celej ten memory blok by mel pocitany reference, aby vedel jestli se mu jeste nekde neco necoura... ale je to natolik convoluted, ze bych radsi exekutivne zakazal jakejkoliv handoff.
    DAVIDOWITCH
    DAVIDOWITCH --- ---
    Ja mam vzdycky pocit ze mne vic trapi trvani mallocu nez free.
    Protoze pokud mam tendence hodne delat malloc/free pattern, tak se pokusim tu pamet prepouzit (s nejakym reallocem treba).

    Jinak s xallocem bude problem ze nejde udelat handoff pameti (tj. stejnej jako ma alloca). Knihovne vubec ne, a i mimo knihovny to bude prinejlepsim tricky.
    REDGUY
    REDGUY --- ---
    REDGUY: Jenom pro jistotu, aby si to xchaos nevzal nejak extra osobne. Druhej odstavec minuly zpravy bych klidne naformuloval i "... ze vetsina z nas v zivote nepsala ...".
    REDGUY
    REDGUY --- ---
    ANT_39: No presne proto mi prijde rozumne si predem udelat nejakou analyzu soucasneho stavu, aby pozdeji sel zmerit prinos (nebo postih) kterej xallokator prinesl.

    (a radsi vubec nebudu mluvit o tom, ze (a) jsem si na 95% jistej, ze xchaos v zivote nepsal a ani psat nebude prakticky uzivany program, ve kterem by nahrazeni free necim rychlejsim melo pro uzivatele viditelny prinos a (b) pokud nahodou ano, tak ten program lze na 99% urychlit necim jinym vic nez rychlejsim free. Cili ze cviceni "potrebuju bleskovy free" je predcasna a zcela zbytecna optimalizace. Ale budiz, pravo hrat si se zbytecnejma vecma mu nikdy upirat nebudu, naopak 8) )
    ANT_39
    ANT_39 --- ---
    REDGUY: Je fakt, ze free je celkem netrivialni, a nahradit deset volani free jednim by mohlo byt znat. Nehlede na to, ze malloc je taky slozity, kdezto alokace z poolu bude proste posunuti nejakeho interniho citace. (Btw, XCHAOSi, budou pooly umet realloc? Budou umet pooly rust podle potreby?)

    Na druhou stranu, tim ze bude pool velky, tak hrozi, ze ten malloc, nad kterym je postaveny, pouzije ke splneni pozadavku mmap. (Ev. to nebude stavet na mallocu, ale primo na mmapu, to je jedno.) Pamet pridelenou mmapem kernel musi smaznout, coz chvili trva. Takze neni vyloucene, ze nevhodne pouzite pooly vykonnost programu snizi.

    Zkratka, tesim se na detailni vykonnostni analyzu v zavislosti na ruznych workloadech. Kolega o tom psal diplomku, treba by to mohlo byt uzitecne. (Necetl jsem.)
    REDGUY
    REDGUY --- ---
    XCHAOS: nevidím nic špatného na tom mít jako jeden z přepínatelných režimů alokace konzervativní malloc - cili nevidis problem v tom, ze u kazde dynamicky alokovane pameti budes muset navic sledovat, jak jsi alokoval, protoze kdyz neuvolnis pamet alokovanou mallocem, budes leakovat a kdyz uvolnis pamet allokovanou xallocem, dostanes v lepsim pripade core dump, v hosrsim nejaky nahodny poskozeni pameti? To mi neprijde jako zrovna pritulne, jednu vec delat dvema ruznejma zpusobama, ktery kdyz si spletu, dostanu nahodnou, typicky bezprostredne neviditelnou chybu.

    jednoduše si nechci pamatovat, co vše musím na konci dealokovat. - coz mi ale prijde ze tvuj pristup neresi, jen to komplikuje - prijde mi, ze "nekterou pameti musim odalokovat a nekterou ne" je _slozitejsi_ nez "vsechnu pamet musim odalokovat".

    A jak myslis ten "prepinatelnej rezim"? Jako nejakej globalni stav, podle kteryho se vybira zpusob alokace?

    a dealokace by navíc byla blesková - jak dlouho podle tebe trva normalni free a proc to nepovazujes za bleskove?

    s jinejma knihovnama by to mělo fungovat tak, že o tom nebudou věddět: - coz jenom pokracuje v problemu z prvniho odstavce.
    XCHAOS
    XCHAOS --- ---
    DAVIDOWITCH: no, čirou náhodou jsem hned v předchozím příspěvku [ XCHAOS @ ANSI C/C99 (specifikace), GNU C (gcc, glibc), Tiny C (tcc) a POSIX - ne nutně C++,g++,libstdc++ nebo Win32 API ] jsem svůj záměr vysvětlil...

    ANT_39: asprintf() znám a líbí se mi... až na to, že nechci záviset jen na mallocu(). vlastně ano... u toho svého get_str() (či jak se to bude jmenovat) plánuju ještě mutaci get_str(), která se bude lišit tím, že místo prostého řetězení se použije první parametr jako formátovací string pro sprintf()... jde čistě jen o to, že nechci záviset na malloc(), protože si nechci pamatovat na které všechny pointery bude nutné ručně zavolat free().

    REDGUY: dobře, tak aby si neřekl:
    REDGUY: ...odpovědi na zbývající otázky:

    - nevidím nic špatného na tom mít jako jeden z přepínatelných režimů alokace konzervativní malloc() - a použít ho např. když budu chtít implementovat ve svém toolkitu nějakou veřejnou knihovní funkci a alokovat konzervativním způsobem prostor pro její návratovou hodnotu. nicméně chci mít možnost triviálním způsobem přepínat ještě minimálně mezi dvěma dalšími způsoby alokace, u kterých bych tak či onak nemusel volat free() - a dealokace by navíc byla blesková (tedy, i ta alokace - což mimochodem taky chci přesně proměřit, jestli zvládnu více alokací za sekundu, než malloc())

    - v čem jsou přesně nedostatečné? jednoduše si nechci pamatovat, co vše musím na konci dealokovat. často používám několik "dočasných proměnných" (například pointeru na stringy), jejichž obsah se průběžně mění pomocí aktuální situace - a na konci prostě už nevím, co vše jsem alokoval, na co chvíli ukazovaly. nechci pro 10 po sobě jdoucích aktivit deklarovat deset různých jednoúčelových proměnných jen proto, abych je na konci mohl dealokovat. nechci ani manuálně dealokovat po každé alokaci, apod.

    - jestli chci být v něčem nejlepší, to je zajímavá otázka :) chci být nejlepší v uživatelské přítulnosti pro moje vlastní použití. tedy je to v podstatě forma programátorské onanie - na čemž ovšem nevidím nic špatného :-)

    - s jinejma knihovnama by to mělo fungovat tak, že o tom nebudou věddět: nechci jim podsouvat jinej "univerzální" malloc() - chci jen sám občas použít něco jiného než malloc(), když to uznám za vhodné.

    - jaká je v případě C "koncepce celého jazyka", to je velká otázka - např. ostatní moje makra jsou obecně speciálním případem věcí jako va_args() (což je taky dost bordel, ale současně i součást "koncepce").

    C obecně rozlišuje "lokální" a "globální" - jedna možnost je, že každá další funkce by podle měla implicitně alokovat s využitím globální alokační funkce, dokud není definován lokální override. a nebo může funkce pokačovat dle aktuálně nastaveného kontextu - pokud si výslovně neřekne, že chce něco dělat jinak...

    v krajním případě by alokační strategie mohly být jen dvě: "chci malloc" (včetně toho, že si ručně zavolám) a "chci zapomenout vše alokované odsud až podsud". já celou dobu žiju v domění, že je praktické vymýšlet ještě nějakou "třetí cestu", ale možná je to overkill.
    Kliknutím sem můžete změnit nastavení reklam