0 / 0 / 0
Регистрация: 12.07.2020
Сообщений: 12
1

Простейший пример связи между процессами с использованием именованного канала на windows

15.05.2023, 01:16. Показов 3308. Ответов 0

Author24 — интернет-сервис помощи студентам
Помогите, пожалуйста, написать минимальный работающий проект из двух программ (сервер и клиент), которые с помощью именованного boost process async_pipe на ОС windows.
К сожалению, все найденные мною программы передают данные не между независимыми программами, а когда одна запускает другую через boost process child. Я пытался написать данный проект исходя из своего знания boost.asio
Данные в канал якобы уходят, но на другой стороне никогда не приходят.

Server.cpp
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
using namespace boost;
 
int main(int argc, char *argv[]) {
    asio::io_service ios;
    asio::io_service::strand strand{ios};
 
    try {
        std::cout << "Creating pipe";
        process::async_pipe pipe(ios, argv[1]);
 
        std::string s;
        s.resize(16);
 
        std::function < void() > read;
        read = [&]() {
            async_read(pipe, asio::buffer(s.data(), 5),
                       [&](const boost::system::error_code &ec, std::size_t size) {
                           if (!ec) {
                               std::cout << "Got something with size=" << size << std::endl;
                               std::cout << '\'' << s << '\'' << std::endl;
                           } else {
                               std::cerr << "error " << ec << std::endl;
                           }
                           read();
                       }
            );
        };
 
        asio::post(strand, read);
        ios.run();
    } catch (std::system_error &ec) {
        std::cout << "error: " << ec.what() << ", error code: " << ec.code() << std::endl;
    }
}
Client.cpp
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
using namespace boost;
 
int main(int argc, char *argv[]) {
    asio::io_service ios;
 
    try {
        std::cout << "Opening pipe";
        process::async_pipe pipe(ios, argv[1]);
 
        asio::async_write(pipe, asio::buffer("text"),
                          [](const boost::system::error_code &ec, std::size_t size) {
                              if (!ec) {
                                  std::cout << "Sent something with size=" << size << std::endl;
                              } else {
                                  std::cerr << "error " << ec << std::endl;
                              }
                          }
        );
 
        ios.run();
    } catch (std::system_error &ec) {
        std::cout << "error: " << ec.what() << ", error code: " << ec.code() << std::endl;
    }
}
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
15.05.2023, 01:16
Ответы с готовыми решениями:

Трубопровод связи между процессами Linux
Помогите, пожалуйста, с написанием программы на С! :cry: Задача такая: Стандартный вывод с...

Принудительный разрыв именованного канала
Приветствую. Есть группа многопоточных приложений которые обмениваются между собой информацией...

Странное поведение именованного канала
#include &quot;stdafx.h&quot; /* Код внутри stdafx.h: #pragma once #include &quot;targetver.h&quot; #include...

Простейший пример с использованием AJAX & Node.js
Доброго времени суток! Хотел сегодня написать простейший пример с использованием Ajax, и вот уже...

0
15.05.2023, 01:16
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
15.05.2023, 01:16
Помогаю со студенческими работами здесь

Создание канала связи между пользователем и оператором
Добрый день всем. Пишу курсовик по СУБД, задача — написать клиент-серверное приложение в Access...

Передача массива с помощью именованного канала от сервера клиенту
Сервер создает и печатает массива 10 целых случайных чисел в диапазоне от минус 50 до 50. С помощью...

Закрытие именованного канала при завершении работы программы
Добрый день. Пример: int main() { CreateNamedPipe(...); return 0; }

Переслать вектор N процессам, используя различные виды связи между процессами (MPI_Alltoall)
Переслать вектор, размерности M, N процессам, используя различные виды связи между процессами....

Обмен данными между процессами с использованием сообщений
Добрый день, форумчане! Помогите, пожалуйста, разобраться с данным видом взаимодействия процессов....

Обмен данными между процессами с использованием СООБЩЕНИЙ
Добрый день, форумчане! Помогите, пожалуйста, разобраться с данным видом взаимодействия процессов....

Обмен данными между процессами, с использованием socket
обмен данными с использованием socket используя TPC- socket обмен данными между процессами...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru