abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    včera 23:55 | Komunita

    Ubuntu 26.04 LTS bude (𝕏) Resolute Raccoon (rezolutní mýval).

    Ladislav Hagara | Komentářů: 0
    včera 21:00 | Nová verze

    Netwide Assembler (NASM) byl vydán v nové major verzi 3.00. Přehled novinek v poznámkách k vydání v aktualizované dokumentaci.

    Ladislav Hagara | Komentářů: 0
    včera 20:11 | Komunita

    Linuxová distribuce Frugalware (Wikipedie) ke konci roku 2025 oficiálně končí.

    Ladislav Hagara | Komentářů: 0
    včera 17:22 | Nová verze

    Byla vydána nová verze 3.0.6 svobodné aplikace pro úpravu a vytváření rastrové grafiky GIMP (GNU Image Manipulation Program). Přehled novinek v oznámení o vydání a v souboru NEWS na GitLabu. Nový GIMP bude brzy k dispozici také na Flathubu.

    Ladislav Hagara | Komentářů: 0
    včera 16:11 | IT novinky

    Americký výrobce čipů AMD uzavřel s americkou společností OpenAI smlouvu na několikaleté dodávky vyspělých mikročipů pro umělou inteligenci (AI). Součástí dohody je i předkupní právo OpenAI na přibližně desetiprocentní podíl v AMD.

    Ladislav Hagara | Komentářů: 1
    včera 12:22 | Nová verze Ladislav Hagara | Komentářů: 0
    5.10. 20:00 | Komunita

    Byly zpracovány a na YouTube zveřejněny videozáznamy z konference LinuxDays 2025.

    Ladislav Hagara | Komentářů: 0
    4.10. 15:22 | IT novinky

    Na konferenci LinuxDays 2025 byl oficiálně představen nový router Turris Omnia NG.

    Ladislav Hagara | Komentářů: 34
    4.10. 05:22 | Komunita

    Přímý přenos (YouTube) z konference LinuxDays 2025, jež probíhá tento víkend v Praze v prostorách FIT ČVUT. Na programu je spousta zajímavých přednášek.

    Ladislav Hagara | Komentářů: 16
    3.10. 22:44 | IT novinky

    V únoru loňského roku Úřad pro ochranu osobních údajů pravomocně uložil společnosti Avast Software pokutu 351 mil. Kč za porušení GDPR. Městský soud v Praze tuto pokutu na úterním jednání zrušil. Potvrdil ale, že společnost Avast porušila zákon, když skrze svůj zdarma dostupný antivirový program sledovala, které weby jeho uživatelé navštěvují, a tyto informace předávala dceřiné společnosti Jumpshot. Úřad pro ochranu osobních údajů

    … více »
    Ladislav Hagara | Komentářů: 10
    Jaké řešení používáte k vývoji / práci?
     (38%)
     (45%)
     (15%)
     (17%)
     (22%)
     (15%)
     (18%)
     (16%)
     (15%)
    Celkem 181 hlasů
     Komentářů: 12, poslední 4.10. 20:35
    Rozcestník
    Štítky: není přiřazen žádný štítek

    Dotaz: Existuje nejake presnejsie casovanie v C?

    1.2.2009 15:56 xsustek | skóre: 6
    Existuje nejake presnejsie casovanie v C?
    Přečteno: 712×

    Potreboval by som nejaku kniznicu, kde si mozem zistovat cas. Nieco podobne ako time.h ale aby to bolo presnejsie. Je nieco tak v C-ecku?

    Odpovědi

    1.2.2009 19:07 Michal
    Rozbalit Rozbalit vše Re: Existuje nejake presnejsie casovanie v C?
    Jaké konkrétní akce potřebujete s časem provádět? Pokud vám jde jen o zjištění času v milisekundách (a ne v sekundách, jak je tomu u time()), nestačila by fce ftime() ze sys/timeb.h?
    1.2.2009 19:12 xsustek | skóre: 6
    Rozbalit Rozbalit vše Re: Existuje nejake presnejsie casovanie v C?

    Potrebujem len zitovat aktualny cas , tak aby som ho mohol odcitac a dostat nejaky casovu hodnotu mezdi dvoma akciami. A este potom uspat program na nejaky cas.

    1.2.2009 19:31 Michal
    Rozbalit Rozbalit vše Re: Existuje nejake presnejsie casovanie v C?
    Špatně jsem se vyjádřil. Jde spíš o to, v jakých jednotkách ten čas potřebujete.

    Pokud v sekundách, stačí vám funkce time() z time.h na zjištění aktuálního času od 1.1.1970 a funkce sleep() z unistd.h, která uspí proces na určitý počet sekund.

    Pokud v milisekundách, budete potřebovat funkci ftime() ze sys/timeb.h, která vám umožní zjistit počet milisekund od 1.1.1970 a funkci usleep z unistd.h, která uspí proces na určitý počet mikrosekund (pozor mikrosekund a ne milisekund)...použijte "man usleep" a "man ftime".
    1.2.2009 19:36 xsustek | skóre: 6
    Rozbalit Rozbalit vše Re: Existuje nejake presnejsie casovanie v C?

    Presnost staci na milisekundy. Takze skusim ftime a usleep. A este sa chcem opytat, ci je tu nejaka odcitavacia funkcia, ktora vrati rozdiel dvoch casov. Nieco ako difftime. Alebo si to musim rucne odpocitat?

    4.2.2009 15:18 cronin | skóre: 49
    Rozbalit Rozbalit vše Re: Existuje nejake presnejsie casovanie v C?
    Nevyhovuje klasicke odcitanie?
    1.2.2009 19:46 xsustek | skóre: 6
    Rozbalit Rozbalit vše Re: Existuje nejake presnejsie casovanie v C?

    Este jeden problem, ze funkcia usleep. Uspava program max na 1 s. Ja by som potreboval funkciu, ktora uspi progmram na dlhsie, ale ma presnost aspon na milisekundy. Videl by som to na

    struct timeval

    gettimeofday

    ale opat tu asi nieje nejaka odcitacia funkcia, co by nebol az taky problem. Ale uspavacia funkcia, ktora by vyhovovala poziadavkam je nanosleep. Ibaze ta pouziva sturkturu timespec. Chcel by som sa vyhnut zakazdim preratavat z mikrosekund na nanasekundy.

    1.2.2009 20:29 Michal
    Rozbalit Rozbalit vše Re: Existuje nejake presnejsie casovanie v C?
    no vygooglil jsem, že v time.h je fce clock_gettime(). Ta pracuje se struct timespec. Pak můžes použít nanosleep() - zkoušel jsem, jde to. Tady dávám odkaz na článek, který jsem vygooglil, je tam i sepsaná fce na rozdíl dvou timespeců. Jinak nezapomeň přidat -lrt až budeš kompilovat, ta fce clock_gettime() potřebuje librt. Mimochodem na uspání je taky funkce clock_nanosleep(), ale tu jsem nezkoušel.
    1.2.2009 20:47 xsustek | skóre: 6
    Rozbalit Rozbalit vše Re: Existuje nejake presnejsie casovanie v C?

    Hej, toto vyzera rozumne. Diky

    4.2.2009 18:56 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: Existuje nejake presnejsie casovanie v C?
    Ješte jde spát pomocí selectu. Záleží jak moc to chcete přenositelné. Pod windows gettimeofday není, je potřeba použít něco jiného. Některé knihovny (např. MPI) to umí zaobalit.
    In Ada the typical infinite loop would normally be terminated by detonation.
    4.2.2009 08:55 trekker.dk | skóre: 72
    Rozbalit Rozbalit vše Re: Existuje nejake presnejsie casovanie v C?
    Uspava program max na 1 s. Ja by som potreboval funkciu, ktora uspi progmram na dlhsie, ale ma presnost aspon na milisekundy.
    1) Můžeš zavolat sleep na sekundy a následně usleep na milisekundy.

    2) Přesnost uspání na milisekundy je hezká věc, ale nic ti nezaručuje, že ti jádro ten proces probudí opravdu za daný čas a ne třeba o chvíli později.
    Quando omni flunkus moritati
    4.2.2009 18:57 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: Existuje nejake presnejsie casovanie v C?
    Ad 2 je to tak, ale pokud chci spát např. 100 ms +- autobus, tak se to použít dá.
    In Ada the typical infinite loop would normally be terminated by detonation.
    4.2.2009 21:21 trekker.dk | skóre: 72
    Rozbalit Rozbalit vše Re: Existuje nejake presnejsie casovanie v C?
    Jenže 100ms +/- autobus není přesnost na milisekundy - #5
    Quando omni flunkus moritati
    5.2.2009 06:45 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: Existuje nejake presnejsie casovanie v C?
    No, to je taky pravda.
    In Ada the typical infinite loop would normally be terminated by detonation.
    4.2.2009 15:27 cronin | skóre: 49
    Rozbalit Rozbalit vše Re: Existuje nejake presnejsie casovanie v C?
    Uspavanie s presnostou na milisekundy resp. nanosekundy je teoria. Pozri napr. Tabulku 1 v clanku na IBM Developer works:
    Note that while the unit of time of the return value is a millisecond, the granularity of the value depends on the underlying operating system and may be larger. For example, many operating systems measure time in units of tens of milliseconds.
    Inak povedane, to, ze nejaka metoda wait/sleep akceptuje casovy udaj s vysokou granularitou este neznamena ze bude s takouto granularitou aj cakat/spat. Tu na abicku sme to uz riesili.

    4.2.2009 18:58 Jan Martinek | skóre: 43 | blog: johny | Brno
    Rozbalit Rozbalit vše Re: Existuje nejake presnejsie casovanie v C?

    Doba spánku zaručena není. Ale je celkem zajímavé vyzkoušet, jak se to chová ve většině případů. Tak třeba tenhle prográmek

    #!/usr/bin/python
    import time
    
    def spi(delay):
        start = time.time()
        time.sleep(delay)
        stop = time.time()
        print delay, stop - start - delay
    
    for i in range(-10, 0):
        delay = 2**i
        spi(delay)
    

    usíná na různě dlouhé intervaly a pak zjišťuje, jak dlouho doopravdy spal. Jsem docela překvapený, jak často se daří zvládnout přesnost lepší než milisekundu.

    4.2.2009 21:22 trekker.dk | skóre: 72
    Rozbalit Rozbalit vše Re: Existuje nejake presnejsie casovanie v C?
    ZKoušel jsi to i na vytíženém systému? (Tj. všechna jádra mají nějakou další práci)
    Quando omni flunkus moritati
    4.2.2009 22:05 Jan Martinek | skóre: 43 | blog: johny | Brno
    Rozbalit Rozbalit vše Re: Existuje nejake presnejsie casovanie v C?

    No, nechci udávat nějaká univerzální čísla, raději ať si to každý vyzkouší v konkrétní situaci. Ale program jsem pozměnil na

    #!/usr/bin/python
    import time, random
    
    def spi(delay):
        start = time.time()
        time.sleep(delay)
        stop = time.time()
        diff = stop - start - delay
        if diff > 0.001: print delay, diff
    
    while True:
        delay = random.random()
        spi(delay)
    

    takže vypíše jen zpoždění delší než milisekundu. Pak podtaktoval procesor na 1GHz. Pak pustil současně mplayer, audacious, find /, gtkperf (dvakrát), jakousi nekonečnou smyčku a bláznivě přeblikával mezi plochama.

    Nejdelší zpoždění bylo 7 milisekund. S prioritama jsem si nehrál.

    4.2.2009 23:53 trekker.dk | skóre: 72
    Rozbalit Rozbalit vše Re: Existuje nejake presnejsie casovanie v C?
    To docela jde...
    Quando omni flunkus moritati
    5.2.2009 06:46 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: Existuje nejake presnejsie casovanie v C?
    A teď to zkuste s clocksource=jiffies :)
    In Ada the typical infinite loop would normally be terminated by detonation.

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.