views:

234

answers:

2

I'm testing boost::thread on a system. It happens that I needed to act as a fork(), because one thread modifies the other variables, even member variables of class

I do the project using fork() or is there some alternative still using boost::thread?

Basically I run this program in Linux and maybe FreeBSD.

It is an http proxy,accept() in main thread, and a function that accepts a class (where there is the file descriptor socket) in a secondary thread that makes the service.

Is there a better way to implement a proxy?

+3  A: 

fork() spawns a process which have independent memory regions. Changed must be mediate through IPC.

boost::thread create a thread which can share memory.

They are not comparable.


To create thread-local storage, use boost::thread_specific_ptr.

See http://www.boost.org/doc/libs/1_42_0/doc/html/thread/thread_local_storage.html.

(You may also decorate a global variable as __thread int xyz; to make it thread-local, if the compiler and architecture can support it.)

KennyTM
I'm using boost::thread just to not fall into pthread_*()
osmano807
@osmano807: Do you mean you want to create *thread-local variables* (which is unique for each thread)?
KennyTM
@KennyTM: Yes, basically it. There are variables of the class being modified, I think this would be the solution.
osmano807
@osmano: See update.
KennyTM
"__thread" presented the following error:error: storage class specified for `TOBROWSER `Any tips on how to make a proxy server to accept multiple connections simultaneously without using fork()?
osmano807
@osmano: Next time, ask the real question in the very beginning.
KennyTM
A: 

It sounds like you are trying to allow multiple threads to alter global variables without each others' changes affecting any of the other threads. By forking, the entire memory space of your application is basically copied and each branch of the fork has its own variables and the two branches cannot communicate except through IPC.

If you want to use boost::thread, you'll have to do this copying yourself if you don't want threads to affect each other since the same memory space is common among all threads. You could just create the variables local to each thread function.

Using threads instead of forking will be much more flexible especially when you want to start letting the threads share data. If you want to have variables that all of the threads can change, they should be protected by mutex locks when being changed so that only one thread can change a variable at one time.

Jason