Как мне завершить все процессы, а затем выполнить последовательную работу на C с использованием MPI?

Я написал многопоточную программу на C, используя MPI для поиска палидромов в массиве двумерных символов. Я запускаю 4 темы. Теперь, когда все потоки завершены, я хочу убить потоки и продолжить последовательную работу? Как мне этого добиться? Код выглядит примерно так:

int main(int argc, char *argv[]) {
    // define some varibles
    int foo;

    // Kick off parallel work
    MPI_Init (&argc, &argv);
    MPI_Comm_size(MPI_COMM_WORLD, &size); 
    MPI_Comm_rank(MPI_COMM_WORLD, &rank); 

    if (rank == 0) {
        // some work ...
    }
    if (rank == 1) {
        // some work ...
    }
    if (rank == 2) {
        // some work ...
    }
    if (rank == 3) {
        // some work ...
    }

    MPI_Finalize();

    // Here I want to print some results AFTER all threads are finished. E.g deallocate memory etc
    printf("Found: %d", foo);

    return 0;
}
3 метода стилизации элементов HTML
3 метода стилизации элементов HTML
Когда дело доходит до применения какого-либо стиля к нашему HTML, существует три подхода: встроенный, внутренний и внешний. Предпочтительным обычно...
Формы c голосовым вводом в React с помощью Speechly
Формы c голосовым вводом в React с помощью Speechly
Пытались ли вы когда-нибудь заполнить веб-форму в области электронной коммерции, которая требует много кликов и выбора? Вас попросят заполнить дату,...
Стилизация и валидация html-формы без использования JavaScript (только HTML/CSS)
Стилизация и валидация html-формы без использования JavaScript (только HTML/CSS)
Будучи разработчиком веб-приложений, легко впасть в заблуждение, считая, что приложение без JavaScript не имеет права на жизнь. Нам становится удобно...
Flatpickr: простой модуль календаря для вашего приложения на React
Flatpickr: простой модуль календаря для вашего приложения на React
Если вы ищете пакет для быстрой интеграции календаря с выбором даты в ваше приложения, то библиотека Flatpickr отлично справится с этой задачей....
В чем разница между Promise и Observable?
В чем разница между Promise и Observable?
Разберитесь в этом вопросе, и вы значительно повысите уровень своей компетенции.
Что такое cURL в PHP? Встроенные функции и пример GET запроса
Что такое cURL в PHP? Встроенные функции и пример GET запроса
Клиент для URL-адресов, cURL, позволяет взаимодействовать с множеством различных серверов по множеству различных протоколов с синтаксисом URL.
1
0
26
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Вы не понимаете, как работает MPI. MPI не использует потоки, он использует независимые процессы. Каждый процесс выполняет всю основную программу.* Поэтому, если вы хотите, чтобы работал только один процесс, вы поместите условие if (i_am_working_process) вокруг этого кода.

*сноска: стандарт фактически допускает разные модели, но на практике это так.

Другие вопросы по теме