Introduction To Threads (pthreads) | C Programming Tutorial

Поделиться
HTML-код
  • Опубликовано: 31 май 2024
  • An introduction on how to use threads in C with the pthread.h library (POSIX thread library). Source code: github.com/portfoliocourses/c.... Check out www.portfoliocourses.com to build a portfolio that will impress employers!
  • ХоббиХобби

Комментарии • 119

  • @Shadowll101
    @Shadowll101 Год назад +96

    I just learned about threads about 4 days ago. You can’t believe how much better a 13+ min video is than my 1 hour lecture in explaining threads.

    • @PortfolioCourses
      @PortfolioCourses  Год назад +4

      That's awesome feedback thank you, I'm glad you enjoyed the video Leo! :-)

    • @waynec369
      @waynec369 Год назад +3

      Yes... yes I can...

    • @happygofishing
      @happygofishing 9 месяцев назад +3

      university lectures are always overenginneered.

    • @wizardatmath
      @wizardatmath 3 месяца назад

      I believe it.

    • @pranitp.1622
      @pranitp.1622 6 дней назад

      ​@@happygofishingunderengineered too as one might say.

  • @dianafarhat9479
    @dianafarhat9479 Год назад +31

    There are very few tutorials on this topic. Thank you for your work!

  • @user-cp3tm2nx5l
    @user-cp3tm2nx5l 3 месяца назад

    You Sir are an angel, I've been stuck trying to understand how to use threads in C for SOOOO LONG and this tutorial makes so much sense, i was actually able to code along and it works and i get it ! AAAAH I'm so relieved, it finally makes sense, THANK YOU SO MUCH !

  • @alvarobarboza5730
    @alvarobarboza5730 Год назад

    something that I particularly liked is .. the comparison you do at the end, this shows how useful multi-threading is

  • @mansbjork5721
    @mansbjork5721 5 месяцев назад +1

    We're studying this at university right now and I have to say this is very much useful. It's almost clear after the first watch only.

  • @yehya7537
    @yehya7537 3 месяца назад

    I am listing this channel as a reference in my school project because I have learned a ton of c from here. Thank you!

  • @safarmaihoon4585
    @safarmaihoon4585 Год назад +5

    You know what!! This is better than hours of lectures. So crisp and to the damn point! 👏👏👏👏
    Now I can start reading other references.
    Thanks for the video.

    • @PortfolioCourses
      @PortfolioCourses  Год назад

      You're welcome Safar, I'm glad you enjoyed the video! :-)

  • @ButteryCowEgg
    @ButteryCowEgg 2 года назад +9

    Just wanted to say that I found your channel today and you have done some amazing work on your channel

    • @PortfolioCourses
      @PortfolioCourses  2 года назад +1

      Thank you very much Jack! I'm glad you enjoy the content. :-D

  • @hengyili4662
    @hengyili4662 Месяц назад

    You are better than my professor in terms of explaining things. Thank you !!!

  • @GeneTechAgency
    @GeneTechAgency Год назад +2

    They way you explains with examples...Marvelous sir

    • @PortfolioCourses
      @PortfolioCourses  Год назад

      Thanks for the kind words Junaid! I'm glad you enjoyed the video. 🙂

  • @M3t4lik
    @M3t4lik Год назад +2

    I've been playing around with OpenMP in VS and it works great for optimizing loops for parallel execution, where the threads seem to execute in random order each time the program is run. However, after looking at the documentation a little more attentively, there are a number of command parameters associated with the pragmas that would make life easier rather than trying to play around delay loops, ordering and placements. Great intro to threading.

    • @PortfolioCourses
      @PortfolioCourses  Год назад +1

      Cool, thanks for sharing that, I'm glad you enjoyed it! :-) I think I'm due to cover threading some more but there are so many topics I want to cover haha...

  • @AibekDandaev
    @AibekDandaev Год назад +1

    wanted to say that you've done some amazing work on your channel

  • @emmadhamid6578
    @emmadhamid6578 Год назад +1

    Defined greatly n precisely ✨ best single shortest video to learn whole fkn threads topic …

    • @PortfolioCourses
      @PortfolioCourses  Год назад

      Thank you very much for the kind positive feedback Emmad! I'm glad you enjoyed the video. :-)

  • @p_molnar
    @p_molnar 2 года назад

    best ASCII presentation I've seen so far.

  • @raffayylsamuill9164
    @raffayylsamuill9164 2 месяца назад

    Really thank you for this great explanation

  • @adityak7877
    @adityak7877 Год назад

    I think i have clear understanding about pthreads post watching this video....thanks for the free tuts.

    • @PortfolioCourses
      @PortfolioCourses  Год назад

      You're welcome Aditya, I'm glad the video was helpful for you! :-)

  • @paulalucena2170
    @paulalucena2170 8 месяцев назад

    great explanation! Thanks

  • @heitorheitorheitor8158
    @heitorheitorheitor8158 2 года назад +2

    you teach so well man, great job! :p

  • @gabrielepasqualini4567
    @gabrielepasqualini4567 10 дней назад

    great example, very usefull ty

  • @depsylon4235
    @depsylon4235 Год назад

    great and easy to follow explanation

  • @fridaaa0
    @fridaaa0 5 месяцев назад

    Thank you, super digestible!

  • @pietrocallandrone6012
    @pietrocallandrone6012 Год назад

    This video is a gem, thanks man!

    • @PortfolioCourses
      @PortfolioCourses  Год назад

      You’re welcome Pietro, I’m glad you enjoyed it! :-)

  • @MSDelhi2
    @MSDelhi2 Год назад

    nice explanation with easy example🙂

  • @juliannafotheringham7101
    @juliannafotheringham7101 Год назад +1

    great video, so clear!

  • @zaxiazer
    @zaxiazer Год назад

    Very well explained!

  • @therealajmelmuadz
    @therealajmelmuadz 29 дней назад

    Amazing video mate

  • @audunoklevik4435
    @audunoklevik4435 Год назад

    Good introduction! Thanks :)

  • @djoykeabyah5904
    @djoykeabyah5904 6 месяцев назад

    thank you for the explanation I was only wondering why my single thread execution is faster in the example?

  • @anthony6841
    @anthony6841 5 месяцев назад

    Very helpful, thank you

  • @lowground9345
    @lowground9345 Год назад

    man i love you thanks so much for this vid helped A LOT

    • @PortfolioCourses
      @PortfolioCourses  Год назад

      You're very welcome, I'm so glad to hear the video helped you out! :-)

  • @HuntingKingYT
    @HuntingKingYT 7 месяцев назад +1

    You can also get the return value, you just have to pass a pointer to the place where the return value of the function will be put at (the result is also statically a void pointer!) as the second parameter to pthread_join():
    void* add(void* param) {
    long* result = (long*)malloc(sizeof(long));
    *result = *(long*)param + 1;
    return result;
    }
    int main() {
    pthread_t thread1;
    long value = 10;
    pthread_create(&thread1, NULL, &add, &value);
    long* result;
    pthread_join(thread1, (void**)&result); // output pointer to a `long` pointer!
    printf("result: %ld
    ", *result); // 11
    free(result);
    return 0;
    }

  • @pral4206
    @pral4206 3 месяца назад

    Did you make a video about semaphores also? My teacher is covering that right now and it might be helpful if there was a video about that also.

  • @OdinRu1es
    @OdinRu1es 3 месяца назад

    Multithreading it’s not about executing multiple instructions at the same time. It’s about sharing resource beetween them.

  • @tecoberg
    @tecoberg 2 месяца назад

    It is not clear to me why when pthread_join commands were together the program didn't stop in the first one until the computarion is finished and after that it went to the second pthread_join like shown if you put them immediately after the pthread_creates

  • @vinushan24
    @vinushan24 7 месяцев назад

    Thank you man.

  • @pareus7251
    @pareus7251 6 месяцев назад

    Sir I respect you so much

    • @PortfolioCourses
      @PortfolioCourses  6 месяцев назад

      Thank you for leaving this kind feedback! :-)

  • @alvarobarboza5730
    @alvarobarboza5730 Год назад +2

    Hi. Just watched this video. Very very cool and interesting. I started learning C due to my interest in numerical methods.
    In the video you mention that certain hardware and software specs must be met, in order to run threads in C?
    can you elaborate on this please?
    it seems a regular PC won't be able to run multi-threads
    thank you !!

    • @abanoub7002
      @abanoub7002 5 месяцев назад

      A regular PC would most likely be able to run multiple threads, as the 'pthread_t' type doesn't reference the actual CPU thread directly, but instead references OS threads, which are created on demand by the OS itself depending on things such as available execution resources such as RAM and CPU among other things. Most modern OS's can make up to tens of thousands of threads (depending on the hardware itself of course, on average hardware you would be having around 12), so not meeting hardware requirements shouldn't be a problem.
      But yeah, as long as the amount of OS threads created is less than or equal to the amount of physical threads you have, you should be able to run anything you want in parallel.

  • @berktopbas1496
    @berktopbas1496 2 года назад +2

    Hello, great tutorial! I just wanted to ask that as you explained difference between the concepts of concurrent and parallel execution at the beginning in the video, i suppose, to that explanation, at 12:12, you should have said that "running parallel" instead of "running concurrently". In my opninon, if they were to run concurrently, it could even take more than 4.5-5sec(run-time for single thread) because of context switch. Of course, i assume that your machine has multiple CPUs and multithreading-supporting software, as most modern PCs have today.

    • @PortfolioCourses
      @PortfolioCourses  2 года назад +6

      No, the description is accurate as it is, I said that they were running concurrently and added it looks like they were running in parallel too (i.e. due to the execution time): "We can see that the multithreaded program is running roughly twice as fast as the single threaded program, and that makes sense because we have two threads now running concurrently, and in this case it looks like they're running in parallel as well". All threads run concurrently, and in this case, on my machine, they are also running in parallel based on the execution time. Parallelism implies concurrency, it's a "subset" of concurrency, but concurrency does not imply parallelism. Maybe I'll make a video on concurrency vs parallelism though, it's an interesting topic. Concurrency won't help in a situation like this with a computation occurring in each threads, it could even be worse due to the context switch that you mention. But it can improve performance drastically if the threads are working on I/O bound operations for example, which is something I think a lot of people don't realize.

    • @friendsclub4887
      @friendsclub4887 8 месяцев назад

      Mm 🎂🎂 mm mmm 🎂🎂🎂🎂 mm🎂mm9

    • @friendsclub4887
      @friendsclub4887 8 месяцев назад

      🔥🔥🔥m9 🔥🔥🔥 mm 🔥m 🔥mm 🔥 okk 🔥🔥🔥🔥

    • @friendsclub4887
      @friendsclub4887 8 месяцев назад

      99 😍 mom 😍 mm 😍 mm 😍mm 😍😍m 😍😍 mm 😍😍 mm. 9

    • @friendsclub4887
      @friendsclub4887 8 месяцев назад

      🎉🎉 mo 🎉 mmmm 🎉m9 🎉🎉🎉 mmmm 🎉mm 🎉

  • @lawniczakjohn
    @lawniczakjohn Год назад

    Another awesome video! I'm getting into threads now. Is multi-threading much different in C++? I'm sure they are very similar...

    • @PortfolioCourses
      @PortfolioCourses  Год назад +1

      I'm glad you enjoyed it John! :-) So prior to C++11 we just used the pthreads library in C++, but now there is the thread library we can use instead: www.geeksforgeeks.org/multithreading-in-cpp/.

    • @lawniczakjohn
      @lawniczakjohn Год назад

      @@PortfolioCourses That's great info thanks!

    • @PortfolioCourses
      @PortfolioCourses  Год назад

      @@lawniczakjohn you're welcome! 🙂

  • @nabanitabanerjee6570
    @nabanitabanerjee6570 Год назад

    Very useful.

  • @tracetv8115
    @tracetv8115 Год назад

    I am a little bit confused now. Ur example runs concurrently and not parallel right? If yes, how I have to code that it runs parallel then or the os decides what to do and I can not control that?
    Great video anyways!

    • @PortfolioCourses
      @PortfolioCourses  Год назад

      Yes it runs concurrently but not in parallel. To get parallel execution you would use another solution, for example: curc.readthedocs.io/en/latest/programming/OpenMP-C.html. :-)

  • @fathimamiznathajuddeen9175
    @fathimamiznathajuddeen9175 9 месяцев назад

    Thank you sir

  • @spurthidantu6890
    @spurthidantu6890 Год назад

    How do i prevent memory leaks in Pthreads? The first time i execute the program, answer is right but if i add a while loop, it is providing incorrect values.Even after adding pthread_join, same thing is happening.

    • @PortfolioCourses
      @PortfolioCourses  Год назад

      If we dynamically allocate memory using a pthread, either as part of creating the thread or in the function called by the thread, we need to use free() to free the dynamically allocated memory the same as usual. 🙂 In this example, we don't use any dynamically allocated memory. A while loop could produce incorrect results for a number of reasons, such as variables being re-used, etc.

  • @bofa-zi4fj
    @bofa-zi4fj 11 месяцев назад

    What are the main differences between threads and the fork() system call? And why would you choose one over the other?

    • @PortfolioCourses
      @PortfolioCourses  11 месяцев назад +1

      This is a really good question. :-) It's a big topic though, I definitely want to do a video on exactly this topic one day. For now though I can just point to some resources online such as these ones to explain things:
      stackoverflow.com/a/8514943
      stackoverflow.com/questions/11662781/when-is-clone-and-fork-better-than-pthreads

    • @zoquevil4792
      @zoquevil4792 9 месяцев назад

      Hi ! I just started this subject when I was reading about the "Dining philosophers problem" and how to avoid the deadlock , starvation in this case .... you'll learn about mutex, semaphore/signal , the synchronization process, a huge among of information to learn...the call system fonctions are very tricky when you think about them and at the same time it's a very exiting subject to be familiar with because it's full of suspense!!! .. Thanks Kevin and as always your videos are very amazing!!! @@PortfolioCourses​

  • @bharadwajm7950
    @bharadwajm7950 Год назад +1

    Why are you passing address as argument while calling function in pthread_create ? Why can't you directly pass the value ?
    Why (void*) & value1 ? Why not (void*) value1 ? Near 7:17

    • @PortfolioCourses
      @PortfolioCourses  Год назад +1

      Good question Bharadwaj! Ultimately, we do that because it's the way that the pthread library was created. :-) One thing to keep in mind is that we don't call the function in pthread_create. What we're doing is calling pthread_create, and we give it as arguments the function to call, and a pointer to the value we want to use as an argument. pthread_create() will at some point later "call our function in a new thread", and at that time the function is supplied with that pointer value as an argument. Because the pointer is a void pointer, we can use it to essentially "pass anything we want" to the function.... e.g. a pointer to something like a struct or array that contains all the data needed by the function. Hopefully this helps! :-)

  • @moadelhaddad4376
    @moadelhaddad4376 Год назад

    Hello , Thanks for the video. It is possible to pass 2 arguments to a thread?

    • @PortfolioCourses
      @PortfolioCourses  Год назад +2

      Great question Moad! :-) We can if we use a struct as a way to pass both arguments: www.cse.cuhk.edu.hk/~ericlo/teaching/os/lab/9-PThread/Pass.html.

    • @moadelhaddad4376
      @moadelhaddad4376 Год назад

      @@PortfolioCourses thanks for answering :)

  • @ShopperPlug
    @ShopperPlug 2 года назад

    12:15 - I wonder how is it possible for the program to run faster when it is executing code concurrently with only one core, the physics behind it doesn't make sense... Does code do indeed run faster simply due to concurrency with one core?

    • @PortfolioCourses
      @PortfolioCourses  2 года назад +1

      The code in the video is running in parallel in addition to running concurrently, that’s why it’s faster. :-)

  • @baruchben-david4196
    @baruchben-david4196 10 месяцев назад

    For some of us, we also have to add a flag to the linker: -lpthread.

  • @user-xn3ym4cr6h
    @user-xn3ym4cr6h Год назад

    in fact , its gonna take more time compared to the single threaded version , create pthread is big overhead for this single program , user time and sys time has actually increased

    • @PortfolioCourses
      @PortfolioCourses  Год назад

      The way user and sys time works in multithreaded programs isn't straightforward: stackoverflow.com/a/556411. In particular: "On a multi-processor machine, a multi-threaded process or a process forking children could have an elapsed time smaller than the total CPU time - as different threads or processes may run in parallel. ". So yes user time can go up, but the elapsed time can go down.

  • @undeadpresident
    @undeadpresident Год назад

    Anyone know how to use a C file that uses pthreads to work with Python's ctypes library? Anything that has the line "pthread_create" Python says it can't find it. Something to do with dependency...I don't get it.

    • @PortfolioCourses
      @PortfolioCourses  Год назад

      Unfortunately I don't have a video on this topic. Hopefully someone else is able to help you out. Eventually I'd love to cover ctypes in Python. Sometimes putting the error message into Google along with the text "stackoverflow" or "reddit" can lead to helpful conversations online that help to resolve the issue.

    • @undeadpresident
      @undeadpresident Год назад

      @@PortfolioCourses that was a good idea to go to stack overflow, they pointed me in the right direction and I got it solved. I had to specify a path in Python to the dependencies in mingw. First time I had to do that, I had thought I was doing something wrong with gcc.
      I've used ctypes a fair bit as a way to speed up my python code and learn C at the same time. I've just passed arrays to it but haven't got into any of the more hairy stuff like making python objects into ctypes structs or w/e though.
      On stack overflow I came across a library I hadn't heard of called omp which does multiprocessing in C also. I've only been programming less than a year so I'd be interested in hearing from more experienced people the pros/cons between pthreads and omp.

    • @PortfolioCourses
      @PortfolioCourses  Год назад

      @@undeadpresident I'm glad you got that figured out. 🙂 Maybe someone else viewing the video can address your other question.

    • @undeadpresident
      @undeadpresident Год назад

      @@PortfolioCourses I was playing with omp a little bit and it looks like instead of passing arguments in, you use the thread ID to differentiate what the threads do, and that in pthreads the ID just continues to count up and up each time you loop through the code that splits the program, but in omp it restarts the count each time.
      Not trying to talk you to death, just thought it might be interesting if you haven't messed with it.

    • @PortfolioCourses
      @PortfolioCourses  Год назад

      @@undeadpresident Cool, thanks for sharing, I want to play around with more myself next month sometime.

  • @subtainmushtaq3237
    @subtainmushtaq3237 2 года назад

    What if we have to pass multiple parameters in a function?

    • @PortfolioCourses
      @PortfolioCourses  2 года назад +1

      That's a great question Subtain, I think I'm going to make a video on exactly this question. :-) We can use a struct to pass multiple parameters by using multiple members of the struct, like this example: www.cse.cuhk.edu.hk/~ericlo/teaching/os/lab/9-PThread/Pass.html.

    • @subtainmushtaq3237
      @subtainmushtaq3237 2 года назад

      @@PortfolioCourses thank you sir !

    • @PortfolioCourses
      @PortfolioCourses  2 года назад

      @@subtainmushtaq3237 You're welcome! :-D

  • @mastermax7777
    @mastermax7777 7 месяцев назад

    why dont you show how to get a return value from the thread function?

    • @PortfolioCourses
      @PortfolioCourses  7 месяцев назад

      I think I may make more videos covering more aspects of pthreads as these videos have become popular. :-)

  • @thomaslindell5448
    @thomaslindell5448 3 месяца назад

    Hahn great material but I’m blind. How bout dark mode

  • @aaronderby2581
    @aaronderby2581 5 месяцев назад

    Is it necessary to always "join the threads" or is it just for when you need to be sure a thread has finished before moving on?
    For instance, if i want s thread to continuously run until the program dies, would I ever really need to join it?

  • @FatimazahraeBazaz
    @FatimazahraeBazaz 16 дней назад

    please use dark mode !!! my eyes screaming haha

  • @jayantvarma7052
    @jayantvarma7052 Год назад

    there are so many ads in a 13 min video :(

  • @therealanonymousay
    @therealanonymousay 20 дней назад

    wwwwwww

  • @Awwe12675
    @Awwe12675 Год назад

    I hate it 😂 I need focus in library to understand how it implemented

    • @PortfolioCourses
      @PortfolioCourses  Год назад +1

      Oh you need to know how to implement pthreads, from scratch? I don't know how to do that sorry, that's getting into some lower level programming that I don't really know enough about to talk about off the top of my head. :-)

    • @Awwe12675
      @Awwe12675 Год назад

      @@PortfolioCourses yeah I believe it is system call so I downloaded the gun c library reference manual to figure out

    • @PortfolioCourses
      @PortfolioCourses  Год назад +1

      Good luck! :-)

  • @NarongTantayanon
    @NarongTantayanon 20 дней назад

    why my result turn to be single thread is faster than multi thread? running in WSL ubuntu
    ❯ gcc -o s main.c
    ❯ time ./s
    Add: 1
    Add: 2
    Add: 3
    Add: 4
    Add: 5
    Add: 6
    ./s 55.02s user 0.01s system 99% cpu 55.032 total
    ❯ gcc -o m main.c
    ❯ time ./m
    Add: 5
    Add: 4
    Add: 3
    Add: 6
    Add: 2
    Add: 1
    ./m 68.42s user 0.01s system 596% cpu 11.464 total

  • @chaitanyapawar5483
    @chaitanyapawar5483 Год назад

    Thank you sir