• ú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
    ANT_39
    ANT_39 --- ---
    WILD_A: Prekvapuje me, ze pristup do hashe a do mapy nepovazujes za brikule. To je o rad horsi, z hlediska slozitosti kodu, nez prostej pristup do pole. Co se v tom pripade jako brikule kvalifikuje?
    DAVIDOWITCH
    DAVIDOWITCH --- ---
    XCHAOS: Jo, dela, precti si neco o SSA.

    Ale pokud mas vlevo treba prave tu indexaci, a prirazujes do toho z pameti a ne z aritmeticky jednotky, tak uz to nedas. Pokud jen mas nejakou matiku a do promennych ukladas mezivysledky, tak to je vesmes cely jen asignovani registru (ala to co dela procesor kvuli out-of-order exekuci, kde ma vyrazne vic fyzickejch nez logickejch registru a prejmenovava si je jak zrovna potrebuje)
    XCHAOS
    XCHAOS --- ---
    DAVIDOWITCH: no, pokud mu přiřazovaná hodnota zbyde v registru, tak podle mě dokáže. dokonce, pokud v rámci optimalizace je přiřazováno do proměnné uložené v registru (buď explicitně vyžádáno klíčovým slovem "register" nebo nějak zoptimalizováno) , tak výraz vpravo od rovnítka mohl compiler zpracovat tak, že následná operace přiřazení spotřebuje 0 instrukcí :-) (ale toto tvrdím bez jakékoliv záruky, že nějaký compiler skutečně takovou optimalizaci dělá, teda...)
    DAVIDOWITCH
    DAVIDOWITCH --- ---
    XCHAOS: Procesor vetsinou nedokaze prirazeni/indexovani jednou operaci na registrech ani v cistem C.

    XCHAOS: Na pole fixni velikosti zapomen :-D
    Jenak je to uplne burta, kdyz uz to mas na heapu (a na stack se to nevejde ani omylem), a druhak by to predpokladalo ze aplikace bezi v prave jednom rozliseni, coz nebezi.
    XCHAOS
    XCHAOS --- ---
    WILD_A: no, obávám se, že v éře, kdy myší už ani nemusíš klikat, aby nastal nějaký ten onMouseOver() event, budeme mít problém vysvětlil většině, proč se nám nelíbí, že věci jako přiřazení nebo indexování pole neměly dělat nic, co by procesor nedokázal provést jedinou instrukcí zpracovávající hodnoty v registrech...
    WILD_A
    WILD_A --- ---
    ANT_39: No pokud se tam dejou brikule, tak mi to na miste neprijde, jelikoz to budi dojem, ze to je jen index a ocekavam tam maximalne nejakej strom nebo hash a ono je to pak cely slozitejsi. Ja mam rad kdyz kod ukazuje co dela, takze pokud delam brikule tak dam kontejner.brikule(x) at je to videt.

    Ale je to jen muj postoj vzhledem ke zkusenostem, ktery jsem udelal, mluvim teda ted konkretne o C++.
    REDGUY
    REDGUY --- ---
    XCHAOS: Ne pro uspech, pro nesmysl, stejne jako minus na zprave na kterou ted odpovidam. To jsi moc nepochopil smysl minusu 8)
    XCHAOS
    XCHAOS --- ---
    (-1 od id REDGUY, pro velký úspěch...)

    ANT_39: ... to znamená, že má pocit, že se to děje magicky samo a nic to nestojí :-)
    ANT_39
    ANT_39 --- ---
    WILD_A: Zrovna pretezovani [] u kontejneru, * a -> u chytrejch ukazatelu, atp. dava taky dobrej smysl. Jestli se kvuli tomu musi delat brikule, tak holt musi. Stejne by se delaly, at to nazves at nebo operator[], akorat ted ma klient pristup do toho kontejneru pomoci intuitivni syntaxe.
    XCHAOS
    XCHAOS --- ---
    WILD_A: jenže ono nejde dát do jazyka nějakou feature jen k tomu, aby si matematici mohli definovat vektory a matice a doufat, že jí někdo nezneužije jinak...

    takže purismus a minimalismus C je svazující a omezující (pro mě je C ideální jazyk, kdybych zase někdy programoval panáčka, co běhá po místnostech se souřadnicemi x a y a sbírá konečný předem známý počet předmětů, apod. :-), jenže jakýkoliv jiný vyšší jazyk umožní, aby "cokoliv znamenalo cokoliv"

    + a += v Pythonu je lepší než drátem do oka. Sjednocení (řetězení) a aritmetické sčítání ale není to samé. stejně tak ale PHP/Perl tečka koliduje min. s desetinou tečkou a voláním metody objektu. konkatenace si zaslouží vlastní operátor, který matematici nemají

    (a jestli nebudu líný, tak vám předvedu brzo svoje řešení :-) sice trochu gcc only, ale elegantní :-)
    WILD_A
    WILD_A --- ---
    DAVIDOWITCH: No nekde mozna pretezovani dava smysl a je to peknej syntaktickej cukr, ale obecne je to spis k zlosti, sam uvadis priklad. Ja mam zase zkusenost s tim, ze kod co vypada super jednoduse a optimalne v realu dela za operatorem '=' a '[]' takovy brikule, ze jeden neveri ... takze mozna bych to za sebe shrnul, pretezovani u jednoznacnych matematickych operaci je ok, ale jinde bych se tomu vyhnul.
    XCHAOS
    XCHAOS --- ---
    DAVIDOWITCH: a tady jsme u otázky, jaká část programování dnes vlastně zahrnuje vyšší matematiku.

    spousta jsou jen "kupecké počty", nemluvě o rostoucím významu práce s textem (už SQL je plné textových operátorů, nejen LIKE, ale i MATCH AGAINST... a to pořád ještě nestačí pro specifika jazyků, které mísí diakritiku se zápisem bez diakritiky, apod.)

    programování 2D či 3D grafiky v nějakém konečném prostoru či rozlišení viewportu je přesně to, na co se hodí i pole fixní velikosti, apod... jenže tohle dneska není nejčastější abstrace, když člověk neprogramuje počítačové hry. dovedu si ale představit, že přetěžování je dobré pro tu matiku, problém je, že ne všichni programují jen matiku.

    při zpracování nějakých datových souborů je nejčastější operací iterování buď přes všechny prvky seznamu, nebo přes nějakou podmnožinu seznamu.

    pokud se +, += přetíží pro nějaké řetězení seznamů či přidávání prvků, tak mi prostě intuitivní nepřijde (i když je to elegantní C záznam)... (a podle mě to není intuitivní ani pro někoho, kdo tím chce sčítat ty vektory či matice)
    a=(1,)
    b=(2,)
    a+=b
    a
    (1, 2)
    DAVIDOWITCH
    DAVIDOWITCH --- ---
    Ja mam pretezovani operatoru rad, ted sem videl neco grafickyho psanyho v Jave, a to ze vektorovy operace (tj. secist bod a vektor) se musi delat po slozkach, nebo pres .Add() je hrozny.
    (Zato interne vedu mensi valku o tom ze pretezovat pro vektory 3 cisel < je spatnej napad, protoze neni jasny jestli to je "any lt" nebo "all lt" a melo by to bejt explicitne.. a clovek co zkusil udelat z ~ operator pro normalizaci vektoru to sel domu prepisovat)
    XCHAOS
    XCHAOS --- ---
    WILD_A: no hele, v tý debatě bylo, že C je vlastně subset asemblerů minipočítačů 60-tých let, na kterých pak vznikl Unix. většina původních C instrukcí se přepisovala přesně na jednu strojovou instrukci tehdejších procesorů (na pozdějším hardwaru se to taky implementovalo jednoduše, ale někdy už to vyšlo na víc strojových instrukcí)

    no a jde o to: nějaký subset základních abstrakcí, které jsou víc, než jen základní assembler, ale zase jsou k dispozici fakt všude a nevyžadují instalaci speciálních knihoven. a to je kámen úrazu: základní libc (téma tohohle klubu) v sobě neobsahuje nic zásadně použitelnýho. problém je, že základní kontejnerové typy jazyků jako javascript nebo python (nebo i to dementní PHP) se v C typicky rozepíší na 100 řádek kódu...
    WILD_A
    WILD_A --- ---
    XCHAOS: Je pravda ze C je v mnoha ohledech pracny, abstrakce nejsou out of box a tudiz jak rikas naberu furu knihoven, nicmene outsourcovat slozitosti je imo dobrej napad. Je pravda ze treba STL je na rychly sekani konceptu dobry, neresim pomerne komplexnejsi veci na druhou stranu je to code bloat jak cyp a kdyz to pak realne chci pouzivat tak na to kaslu a tyhle casti prepisu a tak mi pak prijde, ze uz kombinace C a neco vyssiho je lepsi.

    Ad Python - ja ho mam rad, ale pretezovani operatoru je problem vzdycky a v Pythonu jeste vic, vzhledem k dynamickymu typovani, to uz pak jeden nevi vubec nic a jen doufa ze tu runtimu chybu dostane rychle pokud tam je :)

    D jsem nijak nezkousel, ale koketuju a experimentuju s Go a musim rict, ze se mi dost libi, rozhodne lepsi nez C++
    XCHAOS
    XCHAOS --- ---
    WILD_A: tak v tomhle klubu se asi rok diskutovalo o realokacích polí v C: on to není triviální úkol, takže jakmile chceš pole dynamicky zvětšovat nebo do něj vsunovat nějaký prvek doprostřed, tak na limity omezené abstrakce v C narazíš dost rychle (já osobně to obcházím svými vlastními nástroji pro práci se spojovými seznamy, ale to má taky svoje pro a proti).

    takže rychle provést něco konkrétního, kdy už víš, kolik toho bude (typický příklad: grafická knihovna - ve chvíli, kdy už ví, jak velký v plxlech ten načítaný obrázek je), je v C určitě nejvýhodnější a i relativně jednoduché (protože třeba matematické operace se v C dají popsat velmi exaktně - např. proti takové Javě, kde třeba i malá celá čísla skončí jako jiný typ objektu, než velká celá čísla - "integer cache" - apod.)

    mě v té debatě pobavil diskutér, který podotknul, že výrok "C++ je daleko více, než jen C s objekty" mluví sám za sebe a přesně popisuje, co je hlavní problém :-) (a to říkám ve chvíli, kdy mi začíná docházet, že "něco jako templaty" by se mi dost možná hodilo...)

    Python samozřejmě propaguju (myšleno oproti věcem jako např. PHP, Java, apod.) ale ani tam se mi pár věcí moc nelíbí: např. přetěžování operátorů je u dynamicky typovaného jazyka ještě pochybnější, než u toho C++ ... proč proboha lidi mají pocit, že stringy je třeba "sčítat" pomocí + ... dtto seznamy, prostě operace s množinami jsou jiný typ operací, než aritmetika (kupecké počty) a pokud člověk nezná přesně typ objektu, tak pohled na kód naprosto neprozradí, co kód dělá (a to u dynamicky typovaného jazyka platí dvojnásob).

    zvlášť pro open source je podle mě dost důležité, aby člověk který dělá review kódu na první pohled chápal, co a proč se tam děje - i to je podle mě důvod přetrvávající popularity C v open source komunitě, resp. důvod sporů mezi celými projekty zaměřenými na C a C++ ... no ale chybějící abstrakce v C pak vede ke komplexitě systému, kdy vývojář jakoukoliv abstrakci radši outsourcuje externí knihovně či dokonce aplikaci (databáze)

    docela by mi zajímalo narazit na někoho, kdo fakt seriózně používá D a umí v tom něco napsat... vše, co jsem viděl, bylo zatím jen pár elegantních příkladů..
    WILD_A
    WILD_A --- ---
    XCHAOS: Celkem zajimava diskuze, ja osobne to vidim tak, ze C dava smysl jako doplnek k necemu vic high-level, ja osobne preferuju podle mne ultimatni kombo Python a C. Napisu v pythonu a pripadny uzky hrdla prepisu v C.
    No a pokud chci poradnou abstrakci tak nahodim Scheme/Lisp, tam muzu cokoli a neresim nic :)
    XCHAOS
    XCHAOS --- ---
    The Underhanded C Contest
    http://www.underhanded-c.org/
    XCHAOS
    XCHAOS --- ---
    já myslím, že systemd je tu ontopic... je to pěkný příklad, jak nenahradit shellové skripty jediným monolitickým molochem v C (mě to tuhne při startu notebook na baterie a občas i při vypnutí nebo po probuzení z uspání, apod.)
    Kliknutím sem můžete změnit nastavení reklam