• ú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í
    KEYMASTER
    KEYMASTER --- ---
    KLEINZACH: v prosinci jsem strávil reálně tak 7-14 dní řešením JEN rebuild časů který se za poslední rok neúměrně protáhly... a bylo to asi poprvé co jsem proklínal C++ ;)
    KLEINZACH
    KLEINZACH --- ---
    letmo nejak vidim akorat fnukani na dobu kompilace :)
    KOJA
    KOJA --- ---
    ALMAD: Clanek o C++17, 190 komentaru a jeden clovek zmini C++11 fycuru pricemz jeste neni jasny jestli si ji vic pochvaluje nebo na nic vic nadava. Sakra, ty mas ale zarputilej optimismus ;-)

    Brat prosim s velkou rezervou, delam si legraci. Nicmene ten fakt, ze sami uzivatele jsme k C++ vyznamne kriticti mi jako zajimavej prijde i bez legrace.
    KOJA
    KOJA --- ---
    Tohle je zajimavy.

    Diskuze ke clanku o vydobytkach C++17 na hacker news.
    C++17 – Why it's better than you might think | Hacker News
    https://news.ycombinator.com/item?id=13276351

    Aktualne 71 komentaru a ani jeden nadseny, pochvalny, pozitivni.
    XCHAOS
    XCHAOS --- ---
    REDGUY: mno, já nikdy nepolemizoval s tím, že vždy bude existovat nějaký další level abstrakce, kterému už nerozumím ... tedy cokoliv, v čem programuju, je pro mě "programovací jazyk Blub", neboli: jsem účastník matematické (či v tomto spíše programátorské) paralympiády :-)

    Teorie jazyka Blub ovšem taky předpokládá, že každý, kdo používá vyšší level abstrakce, plně chápe všechny nižší levely abstrakce, které jsou pod ním. Ale to je právě ten háček!

    Debata v tomhle klubu (a u Céčka) je ale zajímavá subverze: ptám se často, jestli všichni, kteří používají vyšší jazyky (dnes hlavně Java, Javascript... z těch ostatních Python, PHP, Perl, největší guruové pak C++) plně chápou ty nižší levely abstrakce a důsledky, které vyplývají z toho, že ten jejich level musel někdo implementovat na tom nižším levelu.

    No nic. Dnes asi na to opravdu nemám čas. Možná ale začínáš chápat, v čem u mě byl vždycky problém - je to v tom, že mám problém přijmout ten další level abstrakce "nad Blubem", aniž bych chápal, jak je to udělané "uvnitř" (ale současně taky "k čemu je") (S tím, že poté, co to pochopím, se možná smířím s tím, že to budu používat stejně, jako všichni ostatní, a ne nějak samorostle...)
    REDGUY
    REDGUY --- ---
    XCHAOS: No budiz ti to poucenim, ze odmitanim informaci jen proto, ze ti je poskytl nekdo, na koho ses nasranej, skodis jen a jen sam sobe 8))
    XCHAOS
    XCHAOS --- ---
    REDGUY: no ale tím, že mě na něco nasměruješ ty, to spíš oddálí :) nevím, dostal jsem se k tomu přes "Sapir–Whorf hypothesis or Whorfianism, is a concept-paradigm in linguistics and cognitive science that holds that the structure of a language affects its speakers' cognition or world view."
    REDGUY
    REDGUY --- ---
    XCHAOS: Ten samej Graham, o kterym jsem mluvil v souvislosti s Lispem? Zda se, ze jsi na dobre ceste 8))
    XCHAOS
    XCHAOS --- ---
    XCHAOS
    XCHAOS --- ---
    DAVIDOWITCH
    DAVIDOWITCH --- ---
    UETOYO: To je tak kdyz nekdo cte neco o pravech na muziku a pritom zkousi psat o RAII. (Melo to bejt RAII)
    KOJA
    KOJA --- ---
    DAVIDOWITCH: Jj, jasny. Sice mi pripada, ze jde spis o to jaky ma rozhrani ten stream (srovnano treba s volanim destruktoru joinable std::thread) nez obecnou vadu RAII ale rozumim. Mit na zreteli kontext ve kterym vyvijim smysl dava.
    UETOYO
    UETOYO --- ---
    DAVIDOWITCH: Co to je RIAA?
    DAVIDOWITCH
    DAVIDOWITCH --- ---
    KOJA: Spravne by to asi melo bejt "nema rad slepe spolehani na to ze RIAA uklidi jak ma".
    Myslim ze na soubory mame specialni wrapper kterej proste jeste bere pointer na nas logger.. ale nikdo to moc nepouziva protoze u nas to ze doslo misto na disku a neni kam udelat fflush je neco co se bezne nedeje a kdyz, tak to holt proste o kus pozdejc segfaultne, nekdo na to koukne ocima a po naprave situace process zrestartuje.
    ANT_39
    ANT_39 --- ---
    DAVIDOWITCH: Hm, jo, s tema souborama je to prusvih. Proste close neni cista destrukce, je to nejakej rekneme fflush + fclose (u kteryho ted uz snad muzes zarucit, ze projde...?). Ten flush musi byt zvlastni volani. Coz znamena, ze to budes muset hlidat, a bude se na to zapominat. Opruz.
    KOJA
    KOJA --- ---
    DAVIDOWITCH: Copak o to, na nejaky flamovani uz jsem moc starej, to me nezajima. Tomuhle uz rozumim. Taky to nezni tak senzacne jako , ze nekdo nema rad RAII ;-)
    DAVIDOWITCH
    DAVIDOWITCH --- ---
    KOJA: Tenhle rant se vesmes tyka ciste pouzivani std::streamu, ktery samy od sebe nelogujou. A nahrazovat se to ma tim ze veci explicitne zavres v objektech a mistech ktera kontrolujes (abys mohl logovat), misto toho abys to nechal zavrit tim ze zabijes objekt kterej nekontrolujes (a nemuze logovat). Takze nic moc nazi flamewar worthy :-)
    KOJA
    KOJA --- ---
    DAVIDOWITCH: Asi bych s vasim safety guy rad podiskutoval. Nerikam, ze nema pravdu ale je to zajimavej pristup k veci. Prvni co me napada je, ze stejne musis logovat protoze jsou situace kdy ani tvuj error handling nebude fungovat jak zamysleno (bug, hw chyba ...). Takze pokud clovek loguje a logy monitoruje, tak faily v destruktoru zalogovat neni tak nesmyslny, ne? A propos - cim teda nahrazejete (nebo by vas SG rad nahradil) RAII?
    DAVIDOWITCH
    DAVIDOWITCH --- ---
    ANT_39: Nas nejvic "safety conscious" guy hodne nema rad RIAA, protoze "destruktory nemuzou reportovat chyby". Takze kdyz zkusis zavrit soubor a dojde k nejaky chybe, tak std::stream to (udajne) nema jak nahlasit. Na druhou stranu, v tom co delam je to uplne burta, takze to je jen takovy doplneni k debate :-D
    ANT_39
    ANT_39 --- ---
    ANT_39: Jeste bych k tomu doplnil, ze ten "náš" coding style dost trpi kdyz se alokuje nejaky resource cyklicky. Vypada to nejak takhle:
    for (...) {
        bar_destroy(&bar);
        err = bar_create(&bar);
        bail_error_null(err, bar);
        /* Tady se pak s time barem pracuje.  */
    }

    Je tam ten neintuitivni pattern uvolnovani zdroje nez se alokuje. Ale tim, jak ty funkce funguji (destroy nuluje predany ukazatel, destroy NULLu je nop), tak to vsechno do sebe zapadne, a dela to to, co ma.

    Taky pouziti v makrech neni uplne idealni, protoze to makro potom schovava baily, ktery pouziva, prepisuje err, prestoze to neni zrejme, a tak. Idealne by se takovy makro expandovalo na ({statement expression}), melo by svuj lokalni bail (deklarovany pres __label__), a svuj vlastni error code. V podstate by se chovalo jako funkce, akorat by to generovalo nejaky kus kodu, a pouzivalo by se taky tak: err = blah_that_happens_to_be_a_macro(...); bail_error(err);. Ale tyhle vyfikundace mi samozrejme (a pochopitelne) hodi na hlavu code reviewer, protoze je nikdo nezna.
    Kliknutím sem můžete změnit nastavení reklam