4 #include <simgrid/s4u.hpp>
6 XBT_LOG_NEW_DEFAULT_CATEGORY(meh, "meh");
10 auto mbox = simgrid::s4u::Mailbox::by_name("meh");
11 int input_data[2] = {42, 51};
13 XBT_INFO("Sending and receiving %d and %d asynchronously", input_data[0], input_data[1]);
15 auto put1 = mbox->put_async(input_data, 1000*1000*500);
16 auto put2 = mbox->put_async(input_data + 1, 1000*1000*1000);
19 auto get1 = mbox->get_async((void**)&out1);
22 auto get2 = mbox->get_async((void**)&out2);
24 XBT_INFO("All comms have started");
25 std::vector<simgrid::s4u::CommPtr> comms = {put1, put2, get1, get2};
27 while (!comms.empty()) {
28 int index = simgrid::s4u::Comm::wait_any_for(&comms, 0.5);
30 XBT_INFO("wait_any_for: Timeout reached");
32 XBT_INFO("wait_any_for: A comm finished (index=%d, #comms=%zu)", index, comms.size());
33 comms.erase(comms.begin() + index);
37 XBT_INFO("All comms have finished");
38 XBT_INFO("Got %d and %d", *out1, *out2);
41 int main(int argc, char* argv[])
44 simgrid::s4u::Engine e(&argc, argv);
45 e.load_platform(argv[1]);
46 simgrid::s4u::Actor::create("worker", simgrid::s4u::Host::by_name("Tremblay"), worker);