?
Solved

Unix threads and Sleep as a block process

Posted on 2003-11-18
11
Medium Priority
?
835 Views
Last Modified: 2010-04-21
Hi everyone ... thanks for taking your time to look at this ...

I am trying to create a process that creates a needed number of threads per single proces. Also, within this main process I have a 2 global vars that are accessed within threads as well as main process. Those 2 vars I am controling using the POSIX semaphores. I am shure that those semaphores are working and positioned right.

My problem is that I have to use the sleep within my main process to let those threads kick in to read / change the global vars. Since sleep blocks the entire process my program kind of run VERY slow.

My main loop looks like

while(time)
{
   sem_wait(&currentime)
   currenttime++
   sem_post(&currentime)
   while(true)
  {
     create my thread etc etc
     sleep(1)
  }

}

I was wondering if anyone is out there that is aware of any system call that would not block the entire process that I could use instead of sleep ....

Again ... thanks a loot for looking at this.
L.
0
Comment
Question by:ledeni
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 3
  • 3
  • 2
  • +2
11 Comments
 
LVL 38

Expert Comment

by:yuzh
ID: 9776486
I think you can create a milisecond timer to WAST miliseconds, and let the threads to kick off.

have a look at the following page, to see if it make sense:
http://oldlook.experts-exchange.com/Programming/Programming_Platforms/Linux_Programming/Q_20577083.html
0
 
LVL 38

Expert Comment

by:yuzh
ID: 9776531
Hi ledeni,

    I think if you put (move/link) this question to UNIX programming, you might get better
response.
    http://oldlook.experts-exchange.com/Programming/Programming_Platforms/Unix_Programming/

    You can ask the CS (post a 0 point question in CS TA), and the Mods will do it for you:
    http://oldlook.experts-exchange.com/Community_Support/
   
0
 
LVL 45

Assisted Solution

by:sunnycoder
sunnycoder earned 400 total points
ID: 9776879
try pthread_yield()

man pthread_yield

I assumed that you are using the pthreads library
0
VIDEO: THE CONCERTO CLOUD FOR HEALTHCARE

Modern healthcare requires a modern cloud. View this brief video to understand how the Concerto Cloud for Healthcare can help your organization.

 
LVL 1

Accepted Solution

by:
ChiefEngineer earned 400 total points
ID: 9877883
I guess you need the threads to initialize in a certain order to set the global variables correctly and that a random order initialization is what you want to avoid.

If that's the case I suggest you to use another semaphore or mutex to synchronize the threads creation within the main loop (because in fact you have a kind of resource access coordination issue here) so you block your main loop until the new thread releas the lock and then you have no timer waste.

Just modify your code so it looks like this:


my thread ( )
{
   // Initialization part of the thread
    ...
    release mutex for initializing thread

    // Rest of the thread code
    ...
}

...

while(time)
{
   sem_wait(&currentime)
   currenttime++
   sem_post(&currentime)
 
  while(true)
  {
     lock mutex for initializing thread
     create my thread etc etc
     // I suggest to add a timer for this operation so you don't hang in case of problems
     // with thread's initialization
     wait mutex for initializing thread
  }
}

Hope it helps.
0
 

Author Comment

by:ledeni
ID: 9878203
Sorry I should have posted earlier ... but I got that solved with thr_yield() ... but certanly your effort will be awarded !!

Thanks for looking at this anyhow
0
 
LVL 45

Expert Comment

by:sunnycoder
ID: 9881259
ledeni,

I had suggested using pthread_yield more than 2 weeks ago !!! I assumed that you were using pthreads which was wrong ... so you had to use thr_yield in place of pthread_yield ... I feel that you awarded the question wrongly
0
 

Author Comment

by:ledeni
ID: 9898775
Hey Pasha

fare is fare ... you can move or split those points between the both guys .. I appreciate the sunny's response though that it was not quite the right reposnse .. since I used the thr_yield() and I also appreciate the other guy response for giving in his time .. .I will leave it to you to distribute those points ...

thx
L .
0
 

Author Comment

by:ledeni
ID: 9898785
for a future reference ,let me know if there is anyhow possible for me to reasign points or split them my self bw different people .
thanks
L.
0
 
LVL 45

Expert Comment

by:sunnycoder
ID: 9902983
>I appreciate the sunny's response though that it was not quite the right reposnse
My idea was correct .... making the threads yield
I had clearly mentioned in my post

>>try pthread_yield()

>>man pthread_yield

>>I assumed that you are using the pthreads library

you never returned clarifying that you were not using pthreads nor was any such thing specified in your original question !! All that was needed was using the corresponding thread yielding function of the library/pltform that you  were using.

>for a future reference ,let me know if there is anyhow possible for me to reasign points or split them my self bw different
>people .
you cannot reassign points ... for help with splitting,
http://www.experts-exchange.com/help/closing.jsp
0
 

Expert Comment

by:YensidMod
ID: 9923744
I split the points per asker request.

Yensidmod
EE Moderator
0

Featured Post

Technology Partners: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Installing FreeBSD… FreeBSD is a darling of an operating system. The stability and usability make it a clear choice for servers and desktops (for the cunning). Savvy?  The Ports collection makes available every popular FOSS application and packag…
Why Shell Scripting? Shell scripting is a powerful method of accessing UNIX systems and it is very flexible. Shell scripts are required when we want to execute a sequence of commands in Unix flavored operating systems. “Shell” is the command line i…
Learn how to find files with the shell using the find and locate commands. Use locate to find a needle in a haystack.: With locate, check if the file still exists.: Use find to get the actual location of the file.:
In a previous video, we went over how to export a DynamoDB table into Amazon S3.  In this video, we show how to load the export from S3 into a DynamoDB table.
Suggested Courses
Course of the Month9 days, 2 hours left to enroll

765 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question