Re: [Boost-users] [Threads] How to keep number of running thread constant, performing different operations
data:image/s3,"s3://crabby-images/a16ff/a16ff3f8cf938b568576243b46ae496ec412ddf8" alt=""
I've tryed implementing your suggestions with the following code:
#include <iostream>
#include
#include
#include
#include
#include
void handler1()
{
unsigned short int i;
std::cout << "O--> Handler 1 <--O" << std::endl;
for(i=0; i<65000; i++);
std::cout << "X--> Handler 1 <--X" << std::endl;
}
void handler2()
{
unsigned short int i;
std::cout << "O--> Handler 2 <--O" << std::endl;
for(i=0; i<1000; i++);
std::cout << "X--> Handler 2 <--X" << std::endl;
}
int main()
{
unsigned short nProc,
i;
boost::asio::io_service io;
boost::scoped_ptrboost::asio::io_service::work work(new
boost::asio::io_service::work(io));
boost::thread_group tg;
nProc = boost::thread::hardware_concurrency();
for(i=0; i
data:image/s3,"s3://crabby-images/588e6/588e6a139fcfd8a626054d2512e68211261d5c8a" alt=""
"unsigned short int i;" - is 16bit variable.
see here: http://liveworkspace.org/code/b88123920e184955e61aee9cc0c217c6
i.e. in your code variable "i" is overflowed.
2011/9/1 Alessandro Candini
I've tryed implementing your suggestions with the following code:
#include <iostream> #include #include #include #include #include
void handler1() { unsigned short int i;
std::cout << "O--> Handler 1 <--O" << std::endl; for(i=0; i<65000; i++); std::cout << "X--> Handler 1 <--X" << std::endl; }
void handler2() { unsigned short int i;
std::cout << "O--> Handler 2 <--O" << std::endl; for(i=0; i<1000; i++); std::cout << "X--> Handler 2 <--X" << std::endl; } int main() { unsigned short nProc, i; boost::asio::io_service io; boost::scoped_ptrboost::asio::io_service::work work(new boost::asio::io_service::work(io));
boost::thread_group tg; nProc = boost::thread::hardware_concurrency();
for(i=0; i
io.post(handler2); io.post(handler1); io.post(handler2); io.post(handler2); io.post(handler2); io.post(handler2); io.post(handler2); io.post(handler2); io.post(handler2); io.post(handler1); io.post(handler2);
work.reset(); tg.join_all();
return 0; }
It seems to work, but it is correct, in your opinion? The only problem is that it seems to never stop if I increase the value of i in handler1 up to 70000. Have you any other suggestions?
-- Alessandro Candini
MEEO S.r.l. Via Saragat 9 I-44122 Ferrara, Italy Tel: +39 0532 1861501 Fax: +39 0532 1861637 http://www.meeo.it
======================================== "ATTENZIONE:le informazioni contenute in questo messaggio sono da considerarsi confidenziali ed il loro utilizzo è riservato unicamente al destinatario sopra indicato. Chi dovesse ricevere questo messaggio per errore è tenuto ad informare il mittente ed a rimuoverlo definitivamente da ogni supporto elettronico o cartaceo."
"WARNING:This message contains confidential and/or proprietary information which may be subject to privilege or immunity and which is intended for use of its addressee only. Should you receive this message in error, you are kindly requested to inform the sender and to definitively remove it from any paper or electronic format."
_______________________________________________ Boost-users mailing list Boost-users@lists.boost.org http://lists.boost.org/mailman/listinfo.cgi/boost-users
data:image/s3,"s3://crabby-images/5bef1/5bef166f92826327022dfc2a2aa1bb6149bdbf2f" alt=""
On Thu, Sep 01, 2011 at 04:33:12PM +0400, niXman wrote:
"unsigned short int i;" - is 16bit variable. see here: http://liveworkspace.org/code/b88123920e184955e61aee9cc0c217c6
i.e. in your code variable "i" is overflowed.
I object to this statement. unsigned short is not necessarily 16-bit.
It's inbetween char and int in size, possibly the same as either of
them.
Citing any implementation as a source of definitive sizes is flawed.
On his particular platform, it seems to be 16 bits in size, but it sure
doesn't hold in general.
If you want a 16-bit unsigned integral type, use uint16_t from <cstdint>
or
participants (3)
-
Alessandro Candini
-
Lars Viklund
-
niXman