• ú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 --- ---
    DAVIDOWITCH: ASIC na řetězení stringů? jako alternativa akcelerované grafárny pro webservery? :-))
    DAVIDOWITCH
    DAVIDOWITCH --- ---
    KOJA: ASICy muzou bejt zajimavy kvuli spotrebe. Obecne, dedikovanej HW je zajimavej kvuli spotrebe.
    KOJA
    KOJA --- ---
    JANFROG: Zajimavy. Chapu spravne, ze ocekavas, ze vyznam optimalizace kodu poroste? Kdybys chtel rozvest svoji perspektivu, rad si poctu. Sam o tom obcas popremyslim a zaver zadny nemam - na jedne strane si google vyrabi asicy (proc?), na strane druhe mam obcas pocit, ze na hromadu problemu staci rozumny navrh na urovni architektury a (pardon) "mikrooptimalizace" nejsou potreba (nanejvys tak jeste poresit cachovani vsude kde to dava smysl).
    KOJA
    KOJA --- ---
    REDGUY: Jo, sorry, tak jsem to i myslel a prislo mi, ze to tak myslite oba. Ten linkovany benchmark uz jsem v myslenkach uplne opustil.
    REDGUY
    REDGUY --- ---
    KOJA: Kdyz rikam nanobenchmark tak myslim to, co tady bylo nalinkovany, cili opravdu nano vec, ktera v podstate testuje jednu jedinou funkci v dost trivialnich podminkach. V okamziku, kdy mluvis o "skladani benchmarku", tak uz to imho je neco jineho a k tomu jsem se nevyjadroval.
    KOJA
    KOJA --- ---
    REDGUY, JANFROG: Myslim, ze to "podobne" asi implicitne myslite oba. Problem syntetickych benchmarku mi prijde dost slozity na to aby byl zajimavy sam o sobe. Nektere "low hanging fruit" jde asi pocesat obecne - napr. knihovna facebook folly ktera "nikdy neni pomalejsi a obvykle je rychlejsi" nez STL implementace v libstdc++. Ale namixovat synteticky benchmark tak, aby byl relevantni a pomohl zvolit statisticky vyhodny kompromis bude asi dost zajimave. Skladat treba benchmark na kterem se otestuji ruzne branch prediction algoritmy pri vyvoji noveho desktopoveho CPU muze byt dost dobra zabava.
    JANFROG
    JANFROG --- ---
    XCHAOS: staci -m32
    XCHAOS
    XCHAOS --- ---
    JANFROG: no, můžu se mrknout, co to dělá na noťasu :-)
    JANFROG
    JANFROG --- ---
    XCHAOS: na jakou cílovou platformu to kompiluješ: to je dobra poznamka...i386.
    XCHAOS
    XCHAOS --- ---
    JANFROG: tak tím switchem to nebude:
    xchaos@hyperion:~$ gcc pokus-compare.c -o pokus-compare -ggdb3 -O0
    xchaos@hyperion:~$ ./pokus-compare
    ===
    long a = -1;
    unsigned int b = 1;
    a == b // -> false
    a < b // -> true
    a > b // -> false
    ===
    unsigned int a = 1;
    long b = 1;
    a == b // -> true
    a < b // -> false
    a > b // -> false

    pořád si neuvedl, na jakou cílovou platformu to kompiluješ... ale oceňuju, že tenhle klub _konečně_ začíná zvolna fungovat k tomu, k čemu byl založen :-)

    (jo a dík, že si mi nasměřoval na to #makro (evidentně vložení tokenu do úvozovek, jako stringový literál) - konkrétně tohle využití preprocesoru jsem neznal, a napadá mi okamžitě spousta ďábelských věcí, jak to využít - hlavně třeba v konstruktorech objektů, resp. ještě spíš jejich interfejsů, které se alokují typicky v jediné instanci za celou dobu běhu programu - objekt za běhu takhle může například jednoduše vědět, jak se jmenuje jeho interface ... což je zhruba stejné, jako vědět, do jaké patří třídy...)
    JANFROG
    JANFROG --- ---
    XCHAOS:
    XCHAOS: Se svetem to jde z kopce, ale z jinych duvodu :-)
    Tohle neni dukaz zkazenosti sveta, to je jen ta nejjednodussi demonstrace toho, ze myslet si ze o programu v C vis co se deje uvnitr je - rekneme - velmi naivni. Pro uplnost, prekladano s -ggdb3 -O0

    A ne, neni to tim ze by veci byli v roce 2014 a 2016 jinak. Pokud pouziji 4.9.x dopadne to stejne...
    XCHAOS
    XCHAOS --- ---
    Takže v roce 2014 ještě záporné číslo v Céčku bylo menší, než kladné.. a v roce 2016 už není? no to je jen další důkaz, že se světem to jde z kopce a end is near (unless declared far).
    XCHAOS
    XCHAOS --- ---
    JANFROG: divný, použil jsem make bez jakýchkoliv optimalizací a extravuřtů, na téhle archaické platformě:

    xchaos@hyperion:~$ cat /proc/cpuinfo
    processor : 0
    vendor_id : AuthenticAMD
    cpu family : 15
    model : 67
    model name : AMD Athlon(tm) 64 X2 Dual Core Processor 5000+
    stepping : 2
    cpu MHz : 2611.979
    cache size : 512 KB
    physical id : 0
    siblings : 2
    core id : 0
    cpu cores : 2
    apicid : 0
    initial apicid : 0
    fpu : yes
    fpu_exception : yes
    cpuid level : 1
    wp : yes
    flags : fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush mmx fxsr sse sse2 ht syscall nx mmxext fxsr_opt rdtscp lm 3dnowext 3dnow rep_good nopl pni cx16 lahf_lm cmp_legacy svm extapic cr8_legacy
    bogomips : 5223.95
    TLB size : 1024 4K pages
    clflush size : 64
    cache_alignment : 64
    address sizes : 40 bits physical, 48 bits virtual
    power management: ts fid vid ttp tm stc

    sice porovnávání různých typů integerů, aniž člověk použije implicitní přetypování, je v C poněkud sázka do loterie (já právě implicitní přetypování čísel, než s nima vůbec začnu něco dělat, celkem i používám...), ale přeci jen: kdyby porovnání longu a unsigned intu nějak často dopadalo tak, jako u tebe, tak mi to přijde celkem nebezpečné (zvlášť pokud má být v céčku napsán třeba firmware pro samořídící auta :-))
    JANFROG
    JANFROG --- ---
    XCHAOS: No vidis, me to pise zase tohle:
    ===
    long a = -1;
    unsigned int b = 1;
       a == b // -> false
       a < b  // -> false
       a > b  // -> true
    ...
    

    jv@sao:~/Projects/jv-knowledgebase/C$ gcc --version
    gcc (Debian 6.1.1-11) 6.1.1 20160802
    Copyright (C) 2016 Free Software Foundation, Inc.
    This is free software; see the source for copying conditions.  There is NO
    warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
    

    Jak je to jen mozne v tak transparentnim jazyku, kde je videt co se vevnitr deje :-)
    (omlouvam se za trochu sarkasmu, nekdy si nemuzu pomoci...)
    XCHAOS
    XCHAOS --- ---
    K předchozímu:

    xchaos@hyperion:~$ gcc --version
    gcc (Debian 4.9.2-10) 4.9.2
    Copyright (C) 2014 Free Software Foundation, Inc.
    This is free software; see the source for copying conditions. There is NO
    warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
    XCHAOS
    XCHAOS --- ---
    JANFROG: mě to vypsalo tohle:
    xchaos@hyperion:~$ ./pokus-compare
    ===
    long a = -1;
    unsigned int b = 1;
    a == b // -> false
    a < b // -> true
    a > b // -> false
    ===
    unsigned int a = 1;
    long b = 1;
    a == b // -> true
    a < b // -> false
    a > b // -> false

    ... což, ať se na to koukám z jakéhokoliv úhlu, je asi to, co bych intuitivně čekal, ne? :-)
    XCHAOS
    XCHAOS --- ---
    JANFROG: jako v podstatě ano - přirovnání ke koloběžkám, skateboardům, apod. uznávám. speciálně se mi líbí tahle verze
    Onewheel: The World is Your Playground
    https://www.youtube.com/watch?v=XNqOU4jx62I

    ...sežere fakt málo benzínu :-)
    JANFROG
    JANFROG --- ---
    REDGUY: Jo. sice ne ve vsem myslitelnem ale na (v danem kontextu) relevantnim vzorku. Dneska je dost rozdil mezi tim co napises v kodu a co se doopravdy pousti a je dobre vedet, co kdo dela aby to urychlil...a poucit se z chyb jinych :-)
    REDGUY
    REDGUY --- ---
    JANFROG: Garantuji Ti, ze vetsina vyvojari runtimu tehle syntetickych nanobenchmarku pisou, pousti a ladi mraky. - ehm. Takovejch, ve kterejch pousti jednu funkci ve vsem od tcl/tk po c? Urcite?

    Sam jsem meril dva systemy, dost podobne - myslim, ze klicove slovo je to "podobne".
    JANFROG
    JANFROG --- ---
    REDGUY: Podivej, podobny synteticky nanobenchmarky maji jen mizivou hodnotu....

    S tim zasadne nesouhlasim. Ty benchmarky maji zasadni vyznam a nedelat je velka chyba, byt delat zavery ktery system je lepsi je trosku na hlavu (ale to je na hlavu na zaklade jakychkoliv "dat") Garantuji Ti, ze vetsina vyvojari runtimu tehle syntetickych nanobenchmarku pisou, pousti a ladi mraky. Minimalne Oracle, Google a ja :-)

    Je to jak rika XCHAOS - trik je v tom, ze tyhle "stupidni" operace se provadeji casto. Sam jsem meril dva systemy, dost podobne a jeden byl v rade bechmarku o pulky rychlejsi. GC velmi podobny, JIT velmiu podobny, rozdil byl v knihovne. Takove blbost jako inteligentni implementace String.indexOf() a podobnych veci muze udelat 30% celkem v klidu...

    cim dal tim min podstatny meritko
    No ja citim celkem presne opak. Jak v oblasti "velkych" pocitacu kdy SW je stale komplexnejsi a je nutne ho delat za kratsi dobu. Kodu co musi bezet je hodne. Naklady na datova centra a elektrinu jsou vysoke, efektivnejsi system snizuje naklady nebot umozni vetsi hustotu aplikaci.
    Na strane druhe, v oblastim "malych"pocitacu je to podobne, but z jinych duvodu. S penetraci pocitacu temer do vseho a nastupem IOT bude cim dal vic SW bezet na chrastitkach co nemaji moc vykonu (ruzna Arduina, RPi, male ARMy). Ne kazda lednicka pobezi na T7.
    KILLUA
    KILLUA --- ---
    Jan, pokud něco jde 30x rychlejc můžeš udělat xkrát víc chyb použít xkrát pomalejší framework a stejně bude výsledné řešení 10x rychlejší a udělané za stejnou dobu.
    Kliknutím sem můžete změnit nastavení reklam