Question

Linux/pthreads equivalents for Windows API functions

Asked by: ShawnCurry

I am developing a cross-platform thread library for use with a card game server that I am designing.  I am familar with programming threads in Java and Windows API.  I would like to implement a synchronization construct similar to Windows event handles (HANDLE CreateEvent(...) in Windows API or Object.wait() / Object.notify()  in Java).  However, the examples I have seen for "condition variables" (if that is the equivalent) are confusing to me.  I do not understand the need to associate the additional mutex with the condition variable.

Once the condition is signaled, when does it get reset?  Is there any way to affect when they get reset?

Also, is there any pthreads equivalent for ::WaitForMultipleObjects(...) ?  If not, any ideas on implementing something similar?

Thanks,

Shawn

This Question has been solved and asker verified All Experts Exchange premium technology solutions are available to subscription members.

Subscribe now for full access to Experts Exchange and get

Instant Access to this Solution

  • Plus...
  • 30 Day FREE access, no risk, no obligation
  • Collaborate with the world's top tech experts
  • Unlimited access to our exclusive solution database
  • Never be left without tech help again

Subscribe Now

Asked On
2005-04-10 at 22:45:23ID21383654
Tags

linux

,

pthread

,

windows

Topic

C++ Programming Language

Participating Experts
2
Points
125
Comments
6

Trusted by hundreds of thousands everyday for fast, accurate and reliable tech support.

  • "The time we save is the biggest benefit of Experts Exchange to Warner Bros. What could take multiple guys 2 hours or more each to find is accessed in around 15 minutes on Experts Exchange." Mike Kapnisakis, Warner Bros.
  • "Our team likes having a resource that is more secure than just using Google and most experts using this service really know their stuff. It's nice to look here first versus using Google." Dayna Sellner, Lockheed Martin
  • "Anytime that I've been stumped with a problem, 9 out of 10 times Experts Exchange has either the accepted solution or an open discussion of the potential solution to the problem." Kenny Red, eBay Inc.

See what Experts Exchange can do for you.

Got a question?

We've got the answer.

Experts Exchange has been collecting answers to technology questions since 1996…3 million and counting! If you have a question, chances are we already have your answer.

Screenshot of Experts Exchange Knowledgebase

Need individual assistance?

Our experts are ready to help.

If you can't find the exact answer you're looking for, ask our exclusive community of 50,000 experts. You’ll get a personalized answer from a trusted professional.

Screenshot of Experts Exchange Knowledgebase

Want to learn from the best?

Read articles from industry experts.

Thousands of free tech tips, tricks, how-to’s and tutorials are available in our peer reviewed articles section. See for yourself how smart our experts are, no login required.

Screenshot of an Article

Working on a long term project?

Store your work and research.

Save solutions to your questions, answers you’ve discovered through searching plus helpful articles in your personal knowledgebase for easy future access.

Screenshot of Experts Exchange Knowledgebase

Access the answers to your technology questions today.

Subscribe Now

30-day free trial. Register in 60 seconds.

What Makes Experts Exchange Unique?

Members of the expert community talk about why the experience at Experts Exchange is different than what you will find anywhere else.

Trusted by the world's most respected brands.

image of each brand's logo

Faithfully serving IT professionals since 1996.

Experts Exchange Logo

Try it out and discover for yourself.

Subscribe Now

30-day free trial. Register in 60 seconds.

Related Solutions

  1. Pthreads
    I need a barrier class implementation. I have found hundreds of C struct barriers all over the net but none in a C++ class. I need it to implement the barrier primitive using the pthread_mutex_t and pthread_cond_t. I have tried to convert the struct barrier to a class but it ...
  2. pthreads
    i was trying to use a function pthreads_setconcurrency() defined in pthread.h it says undefined function the other functions work fine (pthread_create etc) I wanted to start more than one thread simultaneously any help ??
  3. Waiting on pthread_cancel
    Is there a Solaris API call that will signal when the cleanup handlers are finished with a pthread deferred-cancelation. //Inside of main //This function calls pthread_cancel() thread_obj_ptr->Terminate(); //Need to know when the cleanup of pthread_cancel() //is finish...
  4. Questions for pthread
    My main program created three pthreads. In the application, I have signal handlers to trigger the pthread to run. This is what I want: Whenever the pthread has been triggered by signal handler, I really want the pthread to run immediately. After the pthread has done that, the...
  5. PTHREAD_MUTEX_INITIALIZER
    Hi all I read about this macro but still not sure what the proper use for it?? is it pthread_mutex_init(&somemutex,NULL) == somemutex=PTHREAD_MUTEX_INITIALIZER ???
  6. libipq and pthreads
    Hi, Here is a sample code where I try to delay every packet by some time (in the code I posted here it is fixed to 100 msec.). Inorder to do so, I start a pthread for every packet that is received by libipq . I have iptables rules that queues tcp packets that are coming and ...

Free Tech Articles

  1. WARNING: 5 Reasons why you should NEVER fix a computer for free.
    It is in our nature to love the puzzle. We are obsessed. The lot of us. We love puzzles. We love the challenge. We thrive on finding the answer. We hate disarray. It bothers us deep in our soul. W...
  2. SCCM OSD Basic troubleshooting
    SCCM 2007 OSD is a fantastic way to deploy operating systems, however, like most things SCCM issues can sometimes be difficult to resolve due to the sheer volume of logs to sift through and the dispe...
  3. Migrate Small Business Server 2003 to Exchange 2010 and Windows 2008 R2
    This guide is intended to provide step by step instructions on how to migrate from Small Business Server 2003 to Windows 2008 R2 with Exchange 2010. For this migration to work you will need the fo...
  4. Create a Win7 Gadget
    This article shows you how to create a simple "Gadget" -- a sort of mini-application supported by Windows 7 and Vista. Gadgets can be dropped anywhere on the desktop to provide instant information, ...
  5. Outlook continually prompting for username and password
    There have been a lot of questions recently regarding Outlook prompting for a username and password whilst using Exchange 2007. There are a few reasons why this would happen and I will try to cover t...
  6. Backup Exchange 2010 Information Store using Windows Backup
    There seems to be quite a lot of confusion around the ability to backup Exchange 2010 using the built in Windows Backup feature. This stems from the omission of this feature prior to Exchange 2007 s...

Cloud Class Webinars

  1. Avoiding Bugs in Microsoft Access
    Alison Balter takes and in-depth look at avoiding bugs in Access. In this webinar you will learn about using the immediate window to debug your applications, invoking the debugger, using breakpoints to troubleshoot, stepping through code, setting the next statement to execute, ...
  2. Top 10 Best New Features in Visio 2010
    Scott Helmers gives live demonstrations of the top 10 new features in Visio 2010. This webinar will teach you how to create compelling diagrams by adding shapes to the page with a single click, linking the shapes in a diagram to data in Excel (or SQL Server, or SharePoint), ...
  3. IT Consultant Business Secrets Revealed
    Michael Munger, Experts Exchange tech pro and IT consultant, pulls back the curtain on his very successful businesses and answers question on every IT consultant and business owner should know about. He shares secrets on what he did to solve the 5 most common problems in IT, ...
  4. Disaster Recovery and Business Continuity
    Quest CTO, Mike Billon, gives an overview of the steps involved in building a dunamic disaster recovery plan. Through case studies and an examination of software/hardware tooles for monitoring and testing, you'll gain a better understandin of where you are, where you want ...
  5. Organize Your Visio Diagrams with Containers and Lists
    Scott Helmers uses cross functional flowcharts, wireframe diagrams, data graphic legends and seating charts to teach you: how to ustilize all three new structured diagram components in Visio 2010, the best practices for organizeing shapes in previous version of Visio, how to organize ...
  6. How to Us Objects, Properties, Events and Methods in Microsoft Access
    Alison Dalter gives an in-depbth look at objects, properties, events and methods in Microsoft Access. In this webinar you will learn about using the object browser, referring to objects, working with properties and methods, working with object variables, understanding the ...

Join the Community

Give a Little. Get a Lot.

Join the community of experts here and help other tech pros by answering question in your area of expertise. You can earn FREE access to all Experts Exchange's premium features and resources.

Join the Community

Answers

 

by: AxterPosted on 2005-04-10 at 23:00:14ID: 13750599

Can you show an example as to how you're using WaitForMultipleObjects?

I'm sure there's a way to duplicate the logic requirements using POSIX functions.

 

by: itsmeandnobodyelsePosted on 2005-04-11 at 03:38:25ID: 13751526

The equivalent to pthread_mutex_t in Windows is a CriticalSection (fast mutex, not nestable, one process only) or a Mutex (processes and threads, nestable).

With both you could control an arbitrary resource, so that only one thread has exclusive access and all others that try to access while the resource is exclusively locked have to wait til unlock:

#ifdef PTHREAD
#   include <pthread.h>
    /*
     *  thread and mutex types
     */
    typedef pthread_t            Thread;
    typedef pthread_mutex_t  ThreadMutex;
#elif defined (WIN32)
    typedef unsigned long             Thread;
    typedef CRITICAL_SECTION    ThreadMutex;
#endif


/* one time initialization of a 'fast' mutex (not reversible) */
void initMutex(void* pMutex)
{
#if defined (PTHREAD)
     pthread_mutex_init((pthread_mutex_t*)pMutex, pthread_mutexattr_default);
#elif defined (WIN32)
     InitializeCriticalSection((PCRITICAL_SECTION)pMutex);
#endif
}

/* enter critical section and block others threads or wait                              */
void enterMutex(void* pMutex)
{
#if defined (PTHREAD)
     pthread_mutex_lock((pthread_mutex_t*)pMutex);
#elif defined (WIN32)
     EnterCriticalSection((PCRITICAL_SECTION)pMutex);
#endif
}
     
/* leave critical section and release any other thread blocked                         */
void leaveMutex(void* pMutex)
{
#if defined (PTHREAD)
     pthread_mutex_unlock((pthread_mutex_t*)pMutex);
#elif defined (WIN32)
     LeaveCriticalSection((PCRITICAL_SECTION)pMutex);
#endif
}


You would use this like:


ThreadMutex mutex;   // create global mutex

int main()
{
        initMutex(&mutex);

       // start some threads ...

       while (true)
       {
              doSomething();
              if (needToWriteToLogFile())
              {
                    // either we get the resource (logfile) exclusively or we have to wait
                    enterMutex(&mutex);
                   
                    ofstream oflog("logfile.log", ios::append | ios::out);
                    writeLog(oflog, "Any message");
                    oflog.close();
         
                    leaveMutex(&mutex);
              }
       }
 }
   

// thread.cpp

void threadFunction(void* pParam)
{
       while (true)
       {
              doSomeThreadThings();
              if (needToWriteToLogFile())
              {
                    // either we get the resource (logfile) exclusively or we have to wait
                    enterMutex(&mutex);
                   
                    ofstream oflog("logfile.log", ios::append | ios::out);
                    writeLog(oflog, "Any message");
                    oflog.close();
         
                    leaveMutex(&mutex);
              }
       }
}


Regards, Alex

 

by: ShawnCurryPosted on 2005-04-11 at 07:53:02ID: 13753418

Thanks for the quick reply.  I quickly found the relationship between CRITICAL_SECTION's and pthread_mutex_t's on my own (in fact, my code is much simpler ;) .  It is pthread_cond_t's which are confusing to me.  I would like to see a similar example implementing the producer/consumer paradigm with a boundless queue, or perhaps an explanation about when the condition gets reset.  Here is some pseudo-code for what I would like to achieve:

Main thread:

Create auto-reset (read) event
Create manual-reset (write) event
Create one producer
Create serveral consumers

Producer thread:

if ( wants to add )
{
    reset manual (write) event (set to unsignalled)
    wait for auto-reset (read) event
    add item
    signal both events
}

Consumer thread:

if( wants to remove )
{
    wait for both events   // This is where I would use WaitForMultipleObjects() in Windows API
    remove item
    signal auto-reset (read) event
}

In Windows, this pattern creates sort of a "priority flag" for the producer thread - once the 'write' event is unsignalled, the producer thread is guaranteed to be the next to run, because consumer threads will wait until the 'write' event is signalled.

WaitForMultipleObjects() in Windows may be used to wait for an entire array of events to become signalled or threads to complete, or to wait for just one in the set, much the same way as the select() sockets function works.  I would like to use it both ways.  It has occurred to me that perhaps the select() function itself might be used, but I have not had a chance to test my theory yet.

Thanks,
Shawn

 

by: itsmeandnobodyelsePosted on 2005-04-11 at 08:22:38ID: 13753739

>>>> in fact, my code is much simpler ;)

Portable code as well?

>>>> Here is some pseudo-code for what I would like to achieve

The pseudo code most likely would dead-lock as the main thread (Producer) doesn't wait on auto-reset (read) event all the time *but* only if "wants to add".

Actually, it seems to me that events isn't optimal to meet the requirements. Events normally are used for performance reasons: to be able to signal an event where one or more threads are waiting on *not* having to poll in an infinite loop. Of course you could use events to protect a shared resource, but a critical section is much cheaper (and more robust). Note, you could make a critical section object a class member of a container class - say a queue class. Then you could use it to make all remove and insert (query, iterators, ...) functions of that queue thread-safe, simply by adding an 'enter' at the beginning and a 'leave' at the end of these member functions. Thus, your threads could arbitrarily use that container and if some of them try to access nearly same time, they automatically wait til the resource gets free again. And you have to add *nothing* in the thread code to get thread-safety.

Regards, Alex

 

by: ShawnCurryPosted on 2005-04-11 at 20:38:20ID: 13759022

>> Portable code as well?

I apologize, I did not mean sound critical of your code.  In fact, it's really the same code, I just like to define macros up front instead of mixing #ifdefs into my functions, if possible (and it was).

>> Actually, it seems to me that events isn't optimal to meet the requirements.

I do understand the uses for events.  I agree that a mutex would probably be a better fit for my example.  Truly, the point of the discussion is that I do not completely understand how pthread_cond_t's work.  I would like to have a synchronization construct in my library which implements the wait() / notify() paradigm.  In Windows, I use an event handle.  The functions which operate on pthread_cond_t's seem like they could be used, but I just don't see how it actually works.  I suppose I'll just have to get used to it.

I've found an interesting article on implementing windows style event handles and WaitForMultipleObjects() using POSIX threads:

http://developers.sun.com/solaris/articles/waitfor_api.pdf

Thanks for your help so far, I'll leave the topic open for discussion for a few days.

Shawn

 

by: ShawnCurryPosted on 2005-04-27 at 19:10:54ID: 13882171

Sorry for the long wait.  I picked up a few very useful books: "Programming with POSIX Threads", D. Butenhof; and "UNIX Network Programming", W. Stevens.  These books were recommended to me as "The Bible"; and indeed they are.

Thanks anyway,

Shawn

20120131-EE-VQP-002

3 Ways to Join

30-Day Free Trial

The Experts

98% positive feedback on 31,087 answers since March 2000. angeliii is a Microsoft Most Valuable Professional for his work with MS SQL Server & Develoment.

He has also proven his knowledge of Visual Basic Programming, PHP Scripting and Oracle Databases.

The Experts

97% positive feedback on 10,752 answers since July 2000. lrmoore has more than 18 years experience in the networking industry.

The six-time Mircosoft MVPs specialties include firewalls, virtual private networking, and network management.

Testimonials

"...and excellent source for support... Kind of like having your very own IT dept." Electriciansnet

Testimonials

"I was apprehensive at signing up at first. However... it has already made my life as an IT administrator much easier." JaCrews

Testimonials

"WOW! You guys have great, active, and knowledgeable people on here." moore50

Business Clients

Business Clients

In the Press

"If you’ve got a question... Experts Exchange can supply an answer.”

In the Press

"...an invaluable aid for both IT professionals and those who require tech support."

In the Press

"where IT professionals provide quick answers on just about any topic"

Business Account Plans

Loading Advertisement...