• ú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
    /* Toto je klub především pro lidi, pro které je programování jednou z mnoha massive multiplayer online počítačových her, které lze hrát.
        V tomto klubu hrozí sémantická hereze a nezdravě vysoký obsah syntaktického cukru. Nevhodné pro algoritmické diabetiky.
        Od účastníků debaty se předpokládá automaticky přístup k instalovanému GNU C: sudo apt-get install build-essential
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    C (programovací jazyk)#C99 Heslo na české Wikipedii
    Jazyk C - Základy praktického programování V Praze 2oo7 pro SSPŠ Tomáš Harvie Mudruňka a kolektiv - jak si programování v C představuje většina lidí
    http://stevenkobes.com/ctest.html C Programming Puzzlers - nepouštějte se do flamewars v tomhle klubu, pokud neuhodnete aspoň polovinu správně!
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    http://en.wikipedia.org/wiki/C99 C99 is a modern dialect of the C programming language.
    http://cprogramminglanguage.net/ C programming language
    http://cprogramminglanguage.net/c-programming-language-tutorial.aspx C programming language - úvod
    http://en.wikipedia.org/wiki/Criticism_of_the_C_programming_language C makes it easy to shoot yourself in the foot. (ještě že ne do hlavy...)
    http://en.wikipedia.org/wiki/C_preprocessor
    http://gcc.gnu.org/onlinedocs/gcc/Variadic-Macros.html C99 makra s proměnným počtem argumentů - __VA_ARGS__
    http://gcc.gnu.org/onlinedocs/gcc/ GNU C Compiler
    http://gcc.gnu.org/onlinedocs/gcc-4.2.2/gcc/Optimize-Options.html
    http://bellard.org/tcc/ Tiny C Compiler - prý C99 compliant (min. umí __VA_ARGS__) - vhodný pro skriptování v C - umí #!/usr/bin/tcc -run
    http://en.wikipedia.org/wiki/International_Obfuscated_C_Code_Contest - pokud jste neviděli tohle, tak jste ještě neviděli opravdu nečitelný C zdroják
    http://bellard.org/otcc/ Obfuscated Tiny C Compiler - z tohohle vtípku vznikl Tiny C compiler
    http://en.wikipedia.org/wiki/ANSI_C Jak se střelit do nohy standardizovaným způsobem.
    http://eli-project.sourceforge.net/c_html/c.html ANSI C Specification
    http://www.lysator.liu.se/c/ Různý ANSI C bordel
    http://www.cs.rit.edu/~ats/books/ooc.pdf Object Oriented Programming with ANSI-C - a pak že to nejde
    http://en.wikipedia.org/wiki/Longjmp co jsou to setjmp()/longjmp() knihovní funkce (pro všechny, podle kterých to bez C++ try { } catch() ... nejde)
    http://groups.google.com/group/comp.lang.c++.moderated/browse_thread/thread/dcdc710c27f47c72 C neumí správně počítat (?)
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    http://www.fastcgi.com/ FastCGI is simple because it is actually CGI with only a few extensions.
    http://www.metalshell.com/source_code/18/Mysql_Select.html How to do a simple connection and select with mysql
    http://xmlsoft.org/ The XML C parser and toolkit of Gnome
    http://curl.haxx.se/libcurl/ libcurl - the multiprotocol file transfer library
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    https://dev.arachne.cz/svn/cll1h SVN/Trac jazyka C<<1 (user-friendly nadstavba nad ANSI C99 - ve stylu JQuery vs. JavaScript)
    Benchmark iterace a serializace stringů v různých jazycích vs. v C
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
        moderátor se velice zhruba řídí zvyklostmi moderace, která kdysi platila v řadě konferencí sítě FidoNet ... C != 0xdead */
    rozbalit záhlaví
    XCHAOS
    XCHAOS --- ---
    REDGUY: je to trochu jinak.. právě proto jsem chtěl to flow-control makro forget{ } (jak si zašal prudit, že uvnitř toho není definovaný chování continue a break :-)

    v podstatě jsem si představoval, že ty režimy jsou dva - ale spíše jsou tři, a jen jeden z nich je standardní malloc

    představ si tyhle vnoření

    main { /*alloc=malloc*/ forget { /*alloc=xalloc*/ remember { /*alloc=malloc*/ } } }

    vs.

    main { /*alloc=malloc*/ forget { /*alloc=xalloc0*/ forget { /*alloc=xalloc1*/ remember { /*alloc=xalloc0 */ } } } }

    v podstatě moje myšlenka na promísení forget{ } a remember{ } maker vede ke třem možným stavům (pokud ten top-level očekávaný stav má být malloc) ... a ještě bych to doplnil o nějaké allocate{ } flow control makro, ve kterém by alloc byl vždy malloc().

    tím, že nepřepínám kontexty, ale tvrdě hlídám začátek a konec scope je to zejména vhodné ke strukturám typu

    forget {void *tmp1r=get_něco(), *tmp1r=get_něco() }

    protože se ti naalokovaná paměť na konci místní scope uvolní spolu s definicema těch proměnných, co na ní odkazují. já takto víceméně jednak programovat chci, jednak už vím, jak toho dosáhnu, ovšem jak už jsem citoval Henryho Forda jinde - stěží si vybuduju reputaci na tom, že se to chystám udělat - budu muset jít a udělat to :-) důvod proč jsem to neudělal je prostě ten, že mi některé kombinace nebyly jasné, a že jsem pořád dost tvrdě ignoroval, že jeden z režimů ve kterých se budu chtít pohybovat, by měl natvrdo být "fallback na malloc()" - tedy ta samá moje funkce (postavená na toolkitu) použije malloc() když jí zavolám jen tak z main() bez uvedení další speficikace, ale že naopak použije bleskové memory pooly, když jí zavolám uvnitř svého forget { } scope.

    takže zadání pro sebe mám jasné - nepíšu univerzální náhradu malloc(), ale píšu jakési svoje "get_cosi(...)" či "get(cosi,...), které má jako jeden z režimů malloc(): na uvolňované pointery se může free() v případě, že volající ví, co dělá - typicky se free zavolá na nějaké více "vnější" vrstvě programu.

    další možnost je definovat dispose(), které si zkontroluje, zda pointer neukazuje dovnitř aktuálního memory poolu - a teprve pokud ne, tak na to zavolat free a pokud ano, tak snižovat nějaký vnitřní counter memory poolu až do té míry, že by např. stránka memory poolu obsahující právě jeden záznam byla ozačená jako volná...

    lze si to představit jako trochu sofistikovanější přepínání mezi malloc() a alloca() - s tím, že alloca() není omezené na velikost stacku.

    víceméně vám tohle může připadat jako dlouhé a jako blábol - ale pro mě je to naopak zdůvodnění toho, proč se o tom s někým radím online (a musím přetrpět všechen výsměch a flamewary) - protože se víceméně pořád držím své původní koncepce, ale zahrnul jsem do ní některé docela chytré přípomínky, které tu zazněly. a teď bych asi fakt měl sednout a naprogramovat to :-)
    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.
    REDGUY
    REDGUY --- ---
    XCHAOS: a další debata o tom "pro koho a proč" je podle mě v tomhle klubu offtopic. - obavam se ze jsi nepochopil proc ty otazky kladu. Jejich smyslem neni zjistit "jestli" to delat, ale "jak" to delat. Pokud si ani tohle neujasnis, narazis po ceste na velke problemy. Ostatne, uz jenom z te jedne zpravy je videt krapet problem: na jedne strane chces univerzalni alokator pro vsechny svoje aplikace, na druhe strane chces "pruzkum technik, bez debat proc by to nekdo chtel delat". Zakladni vyzkum a aplikovany vyzkum jsou dve ruzne veci a delat oboje soucasne mi prijde jako docela spatny napad. Jestli chces nahradu mallocu, mel bys bejt schopnej aspon rict co konkretne je na mallocu spatne. Ne proto ze te s tim otravuje nekdo na nyxu, ale proto abys nakonec poznal jestli se ti to podarilo nebo ne. Jestli chces zkoumat techniky, je dobre zacit tim podivat se jak to delaji ostatni. Co si kuprikladu myslis o tom, jak funguje alokace pameti v ObjC? 8))

    DAVIDOWITCH
    DAVIDOWITCH --- ---
    XCHAOS: Jezismarja to je TAK arogantni odpoved ze sem to ani od tebe necekal...
    A naproste nepochopeni otazky..

    To zes redguye po svejch offtopic vylevech zabanoval mne uz ani neprekvapuje, jelikoz zacnes kricet offtopic kdykoliv se ti to hodi.. ale ze vcetne otazek jako "jake je planovane pouziti daneho konstruktu"...
    ANT_39
    ANT_39 --- ---
    XCHAOS: Jestli ti nevadi zaviset na GNU rozsirenich, tak asprintf je jako sprintf, ale buffer si alokuje sam na halde, a pak do nej retezec nakopiruje. Konkatenace by pak byla proste asprintf(&buf, "%s%s%s%s", str1, str2, str3, str4);
    XCHAOS
    XCHAOS --- ---
    REDGUY: připomínky jsou to dobré. odpovím ti stručně (přeci jen je neděle) na tvoje první dvě otázky:

    - alokátor má být určen především pro mě (a dále pro lidi, co se mnou budou chtít spolupracovat)
    - alokátor bude použit ve všech příštích userspace aplikacích, které plánuji v C vyvíjet

    je to podle mě dostačující vysvětlení, které má právo uvést kdokoliv u všech svých dalších dotazů na jakouliv feature jazyka C, kterou v tomhle klubu vznese. Doufám, že je to nyní jasné - a další debata o tom "pro koho a proč" je podle mě v tomhle klubu offtopic. budeme se zde bavit o naprosté jakékoliv (jakkoliv technicky nesmyslné) feature jazyka C - včetně hledání všemožných bezpečnostních děr typu buffer overrun a stack insertion i debat, jak jim zamezit - a nebudeme se prosím bavit proč by toto někdo chtěl zneužít nebo se proti tomu bránit.

    prostě mě zajímá průzkum co nejširší možné množiny programátorských technik, které se týkají čistého jazyka C (a to konkrétně na úrovni předposlední specifikace C99, která mi vyhovuje více, než předchozí norma C89, na které jsem vyrůstal) - a nebudeme ztrácet čas debatami, kdo a proč by mohl chtít něco takového dělat (případná snaha o účast v "C obfuscated code contest" je dostatečný argument, kterým lze argumentovat na zcela jakoukoliv námitku)
    XCHAOS
    XCHAOS --- ---
    ANT_39: ano, tak já už nějaký čas vím, že bych takto měl se stringy pracovat. moje starší programy to ale obchází, a trapně používají buď MAXLEN buffery na stacku (a nebo MAXLEN alokují). právě že směřuji k tomu, že moje novější C aplikace budou používat vlastní mini-knihovnu se základní funkcí na řetězení a současnou alokaci stringů a jejich následnou efektivní masivní dealokaci (obdoba operátoru + v Pythonu či JavaScriptu nebo operátoru . v PHP)
    REDGUY
    REDGUY --- ---
    A hle, stejne jako Zombie Jesus, po trech dnech vstavam z banu a jsem zpet 8)

    Nejdriv troska offtopic, coz?
    XCHAOS: moderátor občas musí holt poněkud offtopic komentovat počíná ostatních Coz by bylo dobre zduvodneni, kdyby ty tvoje off-topic prispevky byly skutecne moderovani, a nikoliv mentalni masturbace nad vlastni kreativitou, nesmyslne obvinovani oponenta z chybne argumentace, podsouvani oponentovi neceho, co nikdy nerekl nebo blaboleni o smyslu zivota Kdybys skutecne jen moderoval, tak ano, mas pravdu. Coz jsi ovsem nedelal. A pokud off-topicujes uplne stejne jako ja, tak kdyz potom vytahnes moderatoske kladivo, je to proste jen zbabelost (a rekneme "neuprimnost", pokud to vydavas za moderovani). Jen tak do zaznamu 8)

    No, ted ale neco k veci, coz?

    Zakladni vec ktera v cele tehle dbate chybi, je kdyz uz ne analyza, tak aspon zduvodneni:

    - Pro koho ma byt xallokator urcen?
    - Pro co je to urceno?
    - Ma to byt nahrada nebo doplnek stavajicich zpusobu alokace pameti?
    - V cem jsou soucasne zpusoby alokace pameti nedostacne a proc?
    - V cem (a jak moc) chces byt lepsi?
    - Jak dobre to ma fungovat s jinejma knihovnama?
    - Jak to celkove koncepcne zapadne do celeho jazyka?

    Chapu ze kdyz si takhle aspon trochu nadefinujeme co vlastne delame, tak se pozdeji bude mnohem hur vyhybat pripadnym namitkam pomoci ukroku stranou, ale toho uz jsme si driv uzili dost, ne?


    XCHAOS: "tradiční" stringovou gymnastiku v C (ta je prováděna na stacku, tradičně vázaná na nějaké to "MAXLEN" - ne, neni. Ze to tak delas ty neznamena, ze to je obecna tradice.

    A btw, dival ses jak funguje alokace pameti v Objective C, jak uz jsem ti nekolikrat doporucoval? Docela by me to zajimalo - kdyz mi vycitas off-topic prispevky, rad bych vedel jaky efekt maji ty on-topic 8)
    ANT_39
    ANT_39 --- ---
    XCHAOS: Ano, co ti chodi zvenku. Uvnitr programu si to zmeris. MAXLEN nepotrebujes.
    XCHAOS
    XCHAOS --- ---
    ANT_39: tak já to chystám přesně jak říkáš - už mám hotovou funkci get_str(), která změří délku všech svých (1 ... n) argumentů, alokuje prostor a nakopíruje do něj obsah stringu (a toto jsem měl mít už dávno a měla by to být podle mě v C norma).

    zdrojem řetězců náhodné délky je vše: stringy přicházející z textových konfiguráků, z databáze, z webových formulářů... string známé délky je naprosto speciální případ a mimo chráněný svět zdrojového kódu programů a počítačových her se prakticky nevyskytuje.
    MYSHAAK
    MYSHAAK --- ---
    Prosím o pomoc, dokázal by někdo z vás zkompilovat toto pod Windows? https://github.com/spekode/sskey, zkoušel jsem CygWin, MinGW, ale nedaří se mi :(
    ANT_39
    ANT_39 --- ---
    XCHAOS: Rekl bych, ze vetsinou vis, jak dlouhe tve retezce budou, a podle toho si alokujes presne tolik mista, kolik potrebujes. Alokovat MAXLEN a pak doufat, ze se to tam vejde, je nerozum. Vyjimkou je urcite pripad, kdy nacitas retezec nezname delky, a delas prubezne realokace, tam bys pomoci nejakeho MAXLEN mohl hlidat, aby ti mamuti retezec nedosnul masinu.
    XCHAOS
    XCHAOS --- ---
    ISTEVE: tak typicky delší životnost než funkce, ve které vznikají, mají "moje" spojové seznamy (viz předchozí flamewar - ale i navzdory argumentům, které zde padly, je to stále moje oblíbená datová struktura...).

    typickým příkladem dočasné alokace jsou pak různé operace na bázi immutable stringů (ve stylu Pythonu), které pokládám za bezpečnější, než "tradiční" stringovou gymnastiku v C (ta je prováděna na stacku, tradičně vázaná na nějaké to "MAXLEN" se kterým je alokován každý string)
    ISTEVE
    ISTEVE --- ---
    DAVIDOWITCH: ...pokud nebude funkce brat ownership toho co je ji predano jako argument, treba proto ze ocekava delsi zivotnost tech dat nez caller (ala multithreadovy aplikace)...

    ...a to s alloca (jak rika janfrog) nemuze vubec, coz je ponekud vetsi omezeni;]
    DAVIDOWITCH
    DAVIDOWITCH --- ---
    XCHAOS: Tak s mallocem tohle stejne udelat nesmis, protoze si zahodil pointer a nezvladas free, zeano...
    XCHAOS
    XCHAOS --- ---
    DAVIDOWITCH: no tak mě v podstatě ne... ale právě třeba moje makro-zápisy často vedly přesně k něčemu podobnému a byl jsem tady za to dost kritizován...
    DAVIDOWITCH
    DAVIDOWITCH --- ---
    XCHAOS: Sorry, ale to ze musim udelat:
    int *foo = alloca(5*sizeof(int));
    bar(foo);

    misto

    bar(alloca(5*sizeof(int)));

    Mi az tak omezujici neprijde. Ale pochopitelne, ymmv
    XCHAOS
    XCHAOS --- ---
    DAVIDOWITCH: jo. já teda používám -std=c99 takže mě asi něco z toho trápit nebude... ale spíš mě jde o to "On many systems alloca() cannot be used inside the list of arguments of a function call, because the stack space reserved by alloca() would appear on the stack in the middle of the space for the function arguments. " - to mě přijde jednak logické, jednak jako vážné omezení.

    kdybych věděl, jak zjistit kolik mi zbývá místa na stacku, tak můžu zavolat set_rlimit() pokaždé, když by další alokace to místo spotřebovala :-) ale co jsem tam googlil, tak zjistit tohle vůbec není triviální.

    můj závěr je, že pro svojí službu bleskové dealokace celého poolu paměti současně nebudu používat alloca() (ani kdyby to náhodou v gcc fungovalo jak očekávám) - i když to automatické uvolnění po návratu z jakékoliv funkce je samozřejmě lákavé.
    DAVIDOWITCH
    DAVIDOWITCH --- ---
    XCHAOS: http://linux.die.net/man/3/alloca
    Myslis to varovani tady?
    XCHAOS
    XCHAOS --- ---
    HARVIE: o to nejde, jestli je to do nekonečna... malloc() má k dispozici v podstatě veškerou momentálně zbývající RAM + velikost swapu k tomu + ještě vypudíš z RAM diskovou cache, než to začne swapovat. velikost stacku je naproti tomu nastavená fixně (a výchozí velikost je zjevně 0.5 MB).
    Kliknutím sem můžete změnit nastavení reklam