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 16:00 | Nová verze

Byl vydán Mozilla Firefox 51.0. Z novinek lze upozornit například na upozorňování na přihlašování přes nešifrované spojení (HTTP), podporu pro přehrávání bezeztrátového formátu FLAC nebo podporu WebGL 2. Podrobné informace v poznámkách k vydání a na stránce věnované vývojářům. Řešeny jsou také bezpečnostní chyby.

Ladislav Hagara | Komentářů: 1
23.1. 17:25 | IT novinky

Do prodeje (Farnell) se dostal jednodeskový počítač Tinker Board (unboxing). Jedná se o konkurenci Raspberry Pi 3 od společnosti Asus. Porovnání (jpg) těchto počítačů například na CNXSoft. Cena Tinker Boardu je 55 £.

Ladislav Hagara | Komentářů: 15
23.1. 14:44 | Zajímavý projekt

Byla zveřejněna pravidla hackerské soutěže Pwn2Own 2017, jež proběhne od 15. do 17. března v rámci bezpečnostní konference CanSecWes ve Vancouveru. Soutěžit se bude o více než milion dolarů v pěti kategoriích. Letos se bude útočit i na Ubuntu. Jedná se již o 10. ročník této soutěže.

Ladislav Hagara | Komentářů: 2
23.1. 13:33 | Nová verze

Po sedmi měsících vývoje od vydání verze 5.7 byla vydána verze 5.8 (YouTube) toolkitu Qt. Z novinek lze zmínit například Qt Lite pro vestavěná zařízení. Nově jsou plně podporovány moduly Qt Wayland Compositor (YouTube) a Qt SCXML (YouTube). Současně byla vydána verze 4.2.1 integrovaného vývojového prostředí (IDE) Qt Creator.

Ladislav Hagara | Komentářů: 1
23.1. 11:52 | Pozvánky

Lednový Prague Containers Meetup se koná ve čtvrtek 26. ledna 2017 od 18:00 v Apiary, Pernerova 49, Praha 8. Přijďte se podívat na přednášky o Enterprise Kubernetes a Jenkins as a code.

little-drunk-jesus | Komentářů: 0
23.1. 11:40 | Pozvánky

Program letošního ročníku konference Prague PostgreSQL Developer Days, která se koná již 15. a 16. února 2017 na ČVUT FIT, Thákurova 9, Praha 6, byl dnes zveřejněn. Najdete ho na stránkách konference včetně anotací přednášek a školení. Registrace na konferenci bude otevřena zítra (24. ledna) v brzkých odpoledních hodinách.

TomasVondra | Komentářů: 0
22.1. 02:20 | Zajímavý článek

David Revoy, autor open source webového komiksu Pepper&Carrot nebo portrétu GNU/Linuxu, upozorňuje na svém blogu, že nový Inkscape 0.92 rozbíjí dokumenty vytvořené v předchozích verzích Inkscape. Problém by měl být vyřešen v Inkscape 0.92.2 [reddit].

Ladislav Hagara | Komentářů: 0
22.1. 02:02 | Komunita

Øyvind Kolås, hlavní vývojář grafických knihoven GEGL a babl, které využívá grafický program GIMP, žádá o podporu na Patreonu. Díky ní bude moci pracovat na vývoji na plný úvazek. Milník 1000 $, který by stačil na holé přežití, se již téměř podařilo vybrat, dalším cílem je dosažení 2500 $, které mu umožní běžně fungovat ve společnosti.

xkomczax | Komentářů: 12
21.1. 23:54 | Pozvánky

DevConf.cz 2017, již devátý ročník jedné z největších akcí zaměřených na Linux a open source ve střední Evropě, proběhne od pátku 27. ledna do neděle 29. ledna v prostorách Fakulty informačních technologií Vysokého učení technického v Brně. Na programu je celá řada zajímavých přednášek a workshopů. Letos je povinná registrace.

Ladislav Hagara | Komentářů: 0
21.1. 22:11 | Nová verze

Byla vydána verze 1.0.0 emulátoru terminálu Terminology postaveného nad EFL (Enlightenment Foundation Libraries). Přehled novinek v poznámkách k vydání.

Ladislav Hagara | Komentářů: 0
Jak se stavíte k trendu ztenčování přenosných zařízení (smartphony, notebooky)?
 (12%)
 (2%)
 (72%)
 (3%)
 (11%)
Celkem 395 hlasů
 Komentářů: 39, poslední včera 19:30
Rozcestník
Reklama
Š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: 655×

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: 48
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: 71
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: 71
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: 48
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: 71
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: 71
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.