Home Backend Development C++ C++ concurrent programming: how to perform task scheduling and thread pool management?

C++ concurrent programming: how to perform task scheduling and thread pool management?

May 06, 2024 am 10:15 AM
c++ Concurrent programming

Task scheduling and thread pool management are the keys to improving efficiency and scalability in C concurrent programming. Task scheduling: Use std::thread to create new threads. Use the join() method to join a thread. Thread pool management: Create a ThreadPool object and specify the number of threads. Add tasks using the add_task() method. Call the join() or stop() method to shut down the thread pool.

C++ concurrent programming: how to perform task scheduling and thread pool management?

C Concurrent Programming: Task Scheduling and Thread Pool Management

Introduction

In concurrent programming, task scheduling and thread pool management are crucial to improve the efficiency and scalability of applications. This article walks you through the concepts of task scheduling in C and shows how to manage thread pools using std::thread and std::mutex from the C 11 standard.

Task Scheduling

Task scheduling involves allocating and executing asynchronous tasks. In C, you can use std::thread to create a new thread:

1

2

3

std::thread t([]() {

  // 执行异步任务

});

Copy after login

To join a thread, use the join() method:

1

t.join();

Copy after login

Thread pool management

The thread pool is a pre-created and managed collection of threads that can be used to process tasks. Using a thread pool avoids the overhead of repeatedly creating and destroying threads.

Here's how to create and manage a thread pool in C:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

class ThreadPool {

public:

  ThreadPool(int num_threads) {

    for (int i = 0; i < num_threads; i++) {

      threads_.emplace_back(std::thread([this]() { this->thread_loop(); }));

    }

  }

 

  void thread_loop() {

    while (true) {

      std::function<void()> task;

 

      {

        std::lock_guard<std::mutex> lock(mtx_);

        if (tasks_.empty()) {

          continue;

        }

 

        task = tasks_.front();

        tasks_.pop();

      }

 

      task();

    }

  }

 

  void add_task(std::function<void()> task) {

    std::lock_guard<std::mutex> lock(mtx_);

    tasks_.push(task);

  }

 

  void stop() {

    std::unique_lock<std::mutex> lock(mtx_);

    stop_ = true;

  }

 

  ~ThreadPool() {

    stop();

 

    for (auto& t : threads_) {

      t.join();

    }

  }

 

private:

  std::vector<std::thread> threads_;

  std::queue<std::function<void()>> tasks_;

  std::mutex mtx_;

  bool stop_ = false;

};

Copy after login

To use a thread pool, you can perform the following steps:

  1. Create a thread pool object, Specify the number of threads to create.
  2. Use the add_task() method to add tasks to the thread pool.
  3. Call the join() or stop() method to close the thread pool and wait for all tasks to complete.

Practical case

The following is an example of using a thread pool to perform concurrent tasks on a multi-core system:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

#include <iostream>

#include <vector>

#include "thread_pool.h"

 

int main() {

  ThreadPool pool(4);

 

  std::vector<std::future<int>> futures;

  for (int i = 0; i < 10000; i++) {

    futures.push_back(pool.add_task([i]() { return i * i; }));

  }

 

  for (auto& f : futures) {

    std::cout << f.get() << std::endl;

  }

 

  return 0;

}

Copy after login

Conclusion

Concurrent tasks in C can be effectively managed by using std::thread and thread pools. Whether it's scientific computing on multi-core systems or web services that need to handle a large number of requests, thread scheduling and thread pool management are key to improving code efficiency and scalability.

The above is the detailed content of C++ concurrent programming: how to perform task scheduling and thread pool management?. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot Article Tags

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Concurrency-safe design of data structures in C++ concurrent programming? Concurrency-safe design of data structures in C++ concurrent programming? Jun 05, 2024 am 11:00 AM

Concurrency-safe design of data structures in C++ concurrent programming?

C++ object layout is aligned with memory to optimize memory usage efficiency C++ object layout is aligned with memory to optimize memory usage efficiency Jun 05, 2024 pm 01:02 PM

C++ object layout is aligned with memory to optimize memory usage efficiency

How to implement a custom comparator in C++ STL? How to implement a custom comparator in C++ STL? Jun 05, 2024 am 11:50 AM

How to implement a custom comparator in C++ STL?

Similarities and Differences between Golang and C++ Similarities and Differences between Golang and C++ Jun 05, 2024 pm 06:12 PM

Similarities and Differences between Golang and C++

How to implement the Strategy Design Pattern in C++? How to implement the Strategy Design Pattern in C++? Jun 06, 2024 pm 04:16 PM

How to implement the Strategy Design Pattern in C++?

How to copy a C++ STL container? How to copy a C++ STL container? Jun 05, 2024 am 11:51 AM

How to copy a C++ STL container?

What are the underlying implementation principles of C++ smart pointers? What are the underlying implementation principles of C++ smart pointers? Jun 05, 2024 pm 01:17 PM

What are the underlying implementation principles of C++ smart pointers?

How to implement C++ multi-thread programming based on the Actor model? How to implement C++ multi-thread programming based on the Actor model? Jun 05, 2024 am 11:49 AM

How to implement C++ multi-thread programming based on the Actor model?

See all articles