将进程加入一个作业中所涉及的几个函数(C++)

HANDLE CreateJobObject(                

  LPSECURITY_ATTRIBUTES lpJobAttributes,  // SD
  LPCTSTR lpName                                           // job name

);     //创建一个作业对象

BOOL SetInformationJobObject(
  HANDLE hJob,                                                    // handle to job
  JOBOBJECTINFOCLASS JobObjectInfoClass, // information class
  LPVOID lpJobObjectInfo,                                   // limit information
  DWORD cbJobObjectInfoLength                       // size of limit information
);     //设置作业信息,包括对作业设置一些限制,如时间限制、UI限制,作业中的进程都要遵守这些限制

BOOL AssignProcessToJobObject(

  HANDLE hJob,                        // handle to job
  HANDLE hProcess            

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
生产者-消费者问题是一种典型的多线程同步问题,可以用互斥锁、条件变量等方式解决。下面是使用C++11的互斥锁和条件变量实现的生产者-消费者问题代码: ```c++ #include <iostream> #include <thread> #include <mutex> #include <condition_variable> #include <queue> using namespace std; const int kMaxSize = 10; // 缓冲区最大容量 queue<int> buffer; // 缓冲区 mutex buffer_mutex; // 互斥锁 condition_variable buffer_not_full; // 缓冲区未满条件变量 condition_variable buffer_not_empty; // 缓冲区非空条件变量 // 生产者线程函数 void producer(int id) { for (int i = 0; i < 20; ++i) { unique_lock<mutex> lock(buffer_mutex); buffer_not_full.wait(lock, []{ return buffer.size() < kMaxSize; }); // 等待缓冲区未满 buffer.push(i); cout << "Producer " << id << " produced " << i << endl; buffer_not_empty.notify_all(); // 通知消费者线程缓冲区非空 } } // 消费者线程函数 void consumer(int id) { int data; for (int i = 0; i < 20; ++i) { unique_lock<mutex> lock(buffer_mutex); buffer_not_empty.wait(lock, []{ return buffer.size() > 0; }); // 等待缓冲区非空 data = buffer.front(); buffer.pop(); cout << "Consumer " << id << " consumed " << data << endl; buffer_not_full.notify_all(); // 通知生产者线程缓冲区未满 } } int main() { thread p1(producer, 1); thread p2(producer, 2); thread c1(consumer, 1); thread c2(consumer, 2); p1.join(); p2.join(); c1.join(); c2.join(); return 0; } ``` 上述代码中,生产者线程和消费者线程都需要获取互斥锁来访问缓冲区,以确保线程安全。当缓冲区已满时,生产者线程需要等待缓冲区未满的条件变量,而消费者线程需要等待缓冲区非空的条件变量。当生产者生产一个数据后,需要通知消费者线程缓冲区非空;当消费者消费一个数据后,需要通知生产者线程缓冲区未满。这里使用了C++11提供的`condition_variable`来实现条件变量的功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值