• ú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 --- ---
    REDGUY: ono je to trochu jinak... ono v C to chybí poměrně málo, aby bylo slušně univerzálně použitelné i jako víceméně "vyšší jazyk".

    Popravdě, můj přístup k realitě je poněkud kreativnější, a nedělím život na fázi "vzdělání", ve které mi moudří guruové vysvětlí, jak se věci mají a jak nemohou být jinak, a já se smířím s tím co je určené k čemu a pak bude následovat "produkční fáze", kdy budu rutinně uplatn'ovat to, k čemu jsem byl vytrénován, abych pomocí těchto znalostí zrealizoval nápady vize a nápady někoho jiného.

    Takto bych byl ve středověku vychován třeba jako stavitel hradů a pak bych tedy navrhoval hrady "tak jak se to má dělat", a o pár set let později bych zase navrhoval továrny poháněné parními stroji, kde jsou všude rozvedené transmise ke strojům - a vždy by se našel někdo, kdo by mi vysvětlil, že takto se to prostě dělá správně, takto se to vždycky, že tenhle rohový šutr se vždycky otesával takhle a dával se do rohu hradní věže - a co že si vůbec myslím, že přece nestavím vilu v římském stylu, s fontánou v átriu a s mozaikovou podlahou, apod.

    Jenže čas od času pak přijde renesance nebo Nikola Tesla nebo něco takového.

    Já se pochopitelně snažím použít C k něčemu jinému, než k čemu bylo zamýšlené a nijak se tím netajím. Celá historie lidských technologií je plná převratných zlepšováků, kdy lidi použili něco jinak, než se do té doby pokládalo za možné.. ano, prozkoummá se tak i spousta slepých uliček, to je pravda...
    REDGUY
    REDGUY --- ---
    XCHAOS: co je to zase zase strawman fallacy, tohle? ale to zase nechapes co je to strawman fallacy. Rikam snad "Xchaos tvrdi ze..."? Ne. Rikam ze neco nechapes. To neni strawman fallacy, to je konstatovani zaveru ke kteremu jsem dosel. Nez se zase pokrytecky zacnes ohanet cizima slovama, nastuduj si co znamenaji.

    proč myslíš, že nechápu rozdíl mezi (dynamicky typovanými!) referencemi na objekty v Pythonu a primitivními datovými typy v C? - ale tohle pro zmenu strawman fallacy je, coz je dost legracni. Rikam jsem ze nechapes rozdil mezi datovym modelem Pythonu a C? Nerikal, tak mi prosim nic takoveho nepodsouvej. Napsal jsem, ze nechapes rozdil mezi _urcenim_ Pythonu a C.

    já jsem si dokonce prošel zdrojáky Python interpreteru - hahaha, jo, tu veselou scenku si moc dobre pamatuju, jak jsi machroval ze listy v pythonu jsou spojovy seznamy a ja ti rekl at se teda podivas do zdrojaku. Jo, jak jsi byl prekvapenej, to byla legrace 8))
    XCHAOS
    XCHAOS --- ---
    DAVIDOWITCH: tohle ale není soukromá pošta, to je diskuzní klub. tak nějak se očekává, že to je skupinová debata, a ne sada "veřejných dvoustranných konverzací"...
    XCHAOS
    XCHAOS --- ---
    REDGUY: zrovna věc, běžící v podstatě jako skript na pozadí, bych dnes asi přeci jen psal v Pythonu. ale zrovna třeba webové rozhraní se víc a víc víc blíží k tomu stát se real-time GUI (což tak rozhodně původně nebylo zamýšleno) a tedy na webové serverové aplikace jsou dnes kladeny naprosto jiné nároky, než v počátcích webu (jak co se týče množství requestů, tak i požadavků na rychlost jejich vyřízení)
    DAVIDOWITCH
    DAVIDOWITCH --- ---
    XCHAOS: Mne je celkem burta co dela REDGUY, s tim dialog nevedu.
    XCHAOS
    XCHAOS --- ---
    REDGUY: co je to zase zase strawman fallacy, tohle? proč myslíš, že nechápu rozdíl mezi (dynamicky typovanými!) referencemi na objekty v Pythonu a primitivními datovými typy v C? já jsem si dokonce prošel zdrojáky Python interpreteru (ten je samozřejmě implementovaný v C), protože mě zajímalo, jak jsou implementovaný Python pole :-)
    XCHAOS
    XCHAOS --- ---
    PIGSTER: no, v podstatě ano. v podstatě ale i ty struktury v C jsou jen syntaktickej cukr na pointerovou aritmetikou :-) každá členská proměnná struktury je vlastně jen offset přičítaný k pointeru na strukturu.

    (A přesně kvůli takovýmhle věcem C představuje past na programátory postižený analytickým myšlením :-) protože je to prostě strašně návykové, začít uvažovat takhle redukcionisticky :-)
    REDGUY
    REDGUY --- ---
    XCHAOS: Komplikuje, nekomplikuje... problem je, ze nechapes rozdil mezi pythonem a ceckem. Cecko je jednoduchej, low level nastroj, glorifikovanej assembler urcenej na low level praci, kdy potrebujes mit velmi presnou kontrolu nad tim co se deje. Podivovat se nad tim, ze neposkytuje podporu pro nejake high level konstrukce je proste pitomost a nepochopeni toho k cemu je urcene. Pro kazdou praci pouzivej takovy nastroj, ktery se pro ni hodi. Pises device driver? Napis ho v C. Pises generator konfiguracnich souboru pro iptables? Napis ho v pythonu/perlu/ruby/jinem high-level jazyce. Jestli to delas obracene, delas to blbe.

    A ano, vim ze se C siroce pouziva i pro jine veci nez lowlevel praci. Coz na veci nic nemeni, viz http://www.jwz.org/doc/worse-is-better.html .
    PIGSTER
    PIGSTER --- ---
    XCHAOS: tak muzeme to teoreticky brat tak, ze C podporu pro pole nema vubec a ten zapis, co pole pripomina je jenom syntaktickej cukr nad pointrovou aritmetikou (coz ma za nasledek i to, ze pokud mas prostredi bez ochrany pameti, tak destrukce muze byt pri chybe dost rozsahla)
    XCHAOS
    XCHAOS --- ---
    ADAMJ: opravdu přínosný příspěvek.... a v čem BTW myslíš, že se programovalo pod tím DOSem? :-))
    XCHAOS
    XCHAOS --- ---
    DAVIDOWITCH: ...a on se tu např. REDGUY někdy snažil sdělit něco jiného, než "i přesto mám pravdu"? :-)
    XCHAOS
    XCHAOS --- ---
    TENCOKACISTROMY: bavíš se o C? tak to chci fakt vidět, ten typedef na pole známé délky :-)

    (jasně.. jestli myslíš, že budu pracovat s něčím jako pole->val[n] a pole->len ... ale to je pak právě tak "nativní" jako ty polymorfní objekty... a navíc je to ještě ošklivé)
    XCHAOS
    XCHAOS --- ---
    REDGUY: tak to musíš uznat i ty, že třeba proti Pythonu apod. se tím situace dost komplikuje. A v podstatě to lze chápat tak, že "C nemá nativní podporu pro pole předem známé délky" (když budu fakt přísný :-)

    a mj. většina prog. jazyků, které se snaží dál rozvíjet C (C++, D, apod.) se snaží k tomutu problému nějak postavit....
    DAVIDOWITCH
    DAVIDOWITCH --- ---
    ISTEVE: Nejez to...
    ISTEVE
    ISTEVE --- ---
    TENCOKACISTROMY: A tuhle myslenku bych mozna rozvedl dal... co kdyz podobnej problem ma vic lidi? nebylo by uzasny, kdyz by treba existovala standardni technologie kterej tenhle problem resi pro vic nez jen pro jeden projekt?

    ...ale to asi jen snim...
    TENCOKACISTROMY
    TENCOKACISTROMY --- ---
    REDGUY: Jak by byl problem na to pouzit/si vytvorit patricny typ.
    REDGUY
    REDGUY --- ---
    ANT_39: XChaos ma zasadni problem s tim, ze u Cckoveho pole neni dostupna jeho delka, takze (napr.) kdyz si ho poruznu predavas po programu, musis ji predat jako extra parametr. A tim se vsechno strasne komplikuje, nebo tak neco.
    ANT_39
    ANT_39 --- ---
    XCHAOS: Co je to za druh pole, ze na nej for nestaci? Predstavuju si, ze nacpat do toho treba pruchod stromem by byla vyzva, ale pro pole a seznamy by to nemel byt problem, ne?
    DAVIDOWITCH
    DAVIDOWITCH --- ---
    XCHAOS: Ja sem naprosto nepochopil co se pokousis rict, krom obligatniho "i presto mam pravdu".
    ADAMJ
    ADAMJ --- ---
    REDGUY: Uz je to davno. V DOSu. On v nicem jinym neprogramoval. Az pak se naucil cecko.
    Kliknutím sem můžete změnit nastavení reklam