Portál AbcLinuxu, 16. dubna 2024 14:46


Dotaz: Zrychlená clock()

17.9.2007 17:11 pivo231 | skóre: 6
Zrychlená clock()
Přečteno: 414×
Odpovědět | Admin
Napsal jsem si daemona, který periodicky každou vteřinu čte jisté hodnoty ze sériové linky a přenáší je na jinou sériovou linku.

Daemon běží 24 hodin. Pokud ale přijdu k počítači po čase (hodina), smyčka nečeká vteřinu, ale běží stále dokola bez prodlevy. Po killnuti daemona a opětovného spuštění běží daemon v pohodě.
clock_t endwait;
int noWait = 0;
while(1){
  ...
  ... zadne break ani continue ...
  ...
  endwait = clock() + 1 * CLOCKS_PER_SEC;
  while( clock() < endwait && !noWait ){}
}
Čím to může být? Děkuji.
Nástroje: Začni sledovat (0) ?Zašle upozornění na váš email při vložení nového komentáře.

Odpovědi

17.9.2007 17:30 Ritchie | skóre: 27 | blog: Ritchie's | Berlin
Rozbalit Rozbalit vše Re: Zrychlená clock()
Odpovědět | | Sbalit | Link | Blokovat | Admin
Au, přečtěte si někde, jak zařídit, aby program čekal nějaký časový interval (man 3 sleep, man 3 usleep).

K vašemu dotazu – time_t je často 32b typ a funkce clock() vrací každou sekundu hodnotu o 1000000 vyšší. Kdy asi přeteče?
17.9.2007 17:37 Ritchie | skóre: 27 | blog: Ritchie's | Berlin
Rozbalit Rozbalit vše Re: Zrychlená clock()
Místo time_t má být clock_t. Mimochodem, četl jste vůbec man 3 clock, než jste položil tento dotaz?!
DESCRIPTION The clock() function returns an approximation of processor time used by the program.

NOTES Note that the time can wrap around. On a 32-bit system where CLOCKS_PER_SEC equals 1000000 this function will return the same value approximately every 72 minutes.
17.9.2007 18:31 pivo231 | skóre: 6
Rozbalit Rozbalit vše Re: Zrychlená clock()
Děkuji za pokárání, každopádně díky za rady.

Já ale potřebuju zařídit, aby program čekal 0.5 až 3 vteřiny, podle předaných parametrů a popřípadě aby přerušil čekání v půlce, jakmile mu druhé vlákno nastaví proměnnou noWait = 1. Kus kódu je jen ukázka.

Man jsem nečetl, neměl jsem ho poruce. Četl jsem toto, což byla chyba.

Pokud hodnoty funkce clock() rotují jednou za 72 hodin, nemělo by to dělat to co to dělá, ale buď jeden cyklus nečekat, nebo čekat 72 hodin.

Nevíte o nějaké funkci, která vrací počet milisekund současné vteřiny? Nebo jak se přeruší čekání fce. usleep()? Nejsem v tomto tématu tak zběhlý...
17.9.2007 18:44 edois
Rozbalit Rozbalit vše Re: Zrychlená clock()
ty usleepy delej kratounke a mezi nimi to kontroluj. pokud das ten usleep aspon milisekundu, tak to CPU skoro nezatizi
17.9.2007 18:56 pivo231 | skóre: 6
Rozbalit Rozbalit vše Re: Zrychlená clock()
To je pravda, dobrý nápad. Děkuji.
17.9.2007 19:13 Ritchie | skóre: 27 | blog: Ritchie's | Berlin
Rozbalit Rozbalit vše Re: Zrychlená clock()
72 minut
17.9.2007 19:15 pivo231 | skóre: 6
Rozbalit Rozbalit vše Re: Zrychlená clock()
Pardon, to byl překlep, nicméně na myšlence to nic nezmění.
17.9.2007 21:45 Michal Kubeček | skóre: 72 | Luštěnice
Rozbalit Rozbalit vše Re: Zrychlená clock()
Nechce se mi o tom teď moc přemýšlet, ale co použít pthread_cond_timedwait()?
17.9.2007 18:24 edois
Rozbalit Rozbalit vše Re: Zrychlená clock()
Odpovědět | | Sbalit | Link | Blokovat | Admin
hlavne nikdy necekat timhle zpusobem, protoze CPU pojede na 100%. bud se da vypocitat jak dlouho presne chci nechat proces spat a potom pouziju sleep nebo usleep primo s touto hodnotou, nebo to muzu delat tak, jako je v prikladu, ale do toho while cyklu hodim usleep s nejakou rozumnou hodnotou (treba 1000 us)
17.9.2007 18:34 pivo231 | skóre: 6
Rozbalit Rozbalit vše Re: Zrychlená clock()
Ano, vím že to vytíží procesor, ale to mi nevadí.

Popíšu co potřebuji...

Cyklus, který bude čekat 750ms ale např po 200ms bude přerušen druhým vláknem. Jak na to? Přes signály? Když o tom nic nevím, těžko se hledá...

Děkuji.
17.9.2007 18:43 edois
Rozbalit Rozbalit vše Re: Zrychlená clock()
vlaknem nebo procesem?
17.9.2007 18:51 pivo231 | skóre: 6
Rozbalit Rozbalit vše Re: Zrychlená clock()
Vláknem které vytvořím pomocí pthread_create.

Jakmile toto vlákno nastaví proměnnou, čekání se musí ukončit třeba v půlce.
17.9.2007 18:58 petris
Rozbalit Rozbalit vše Re: Zrychlená clock()
Přečtěte si man pthread_cond_init

Založit nové vláknoNahoru

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

ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.