并行执行不同处理器中的两个程序

时间:2011-12-15 06:10:21

标签: parallel-processing processors

我使用这个c / c ++代码来安排2个处理器并行运行2个不同的程序。请问如何确认2个处理器并行运行2个程序?

#include <stdlib.h>
#include <sys/types.h>
#include <sys/wait.h>
#include <unistd.h>
#include <iostream>
#include <sched.h>
#include <stdio.h>
#include <cstdlib>

int main(int argc, char *argv[])
{
cpu_set_t  mask;
CPU_ZERO(&mask);
int pid;
pid=fork();
  if (pid == 0) { /* second child */
        CPU_SET(0, &mask);
     sched_setaffinity(0, sizeof(mask), &mask);
     system("/home/ifeanyi/Process/PID/Debug/PID");
  }
  else if (pid > 0) { // Parent ends
      CPU_SET(1, &mask);
      sched_setaffinity(getpid(), sizeof(mask), &mask);
      cout << getpid() << endl;
      system("/home/ifeanyi/Process/checkpointing/Debug/checkpointing"); // Last leaf
      }
       cout << endl;
  }

1 个答案:

答案 0 :(得分:0)

使用taskset从命令行执行此操作通常更容易,更灵活,而不是在程序中对这些细节进行硬编码,例如

$ taskset -c 0 ./my_program &
$ taskset -c 1 ./my_program &