void AGVScheduler::assign_task_to_agv(std::vector<Task>& tasks, std::vector<AGV>& agvs) { // 首先按照任务的完成状态、优先级进行排序 std::sort(tasks.begin(), tasks.end(), [](const Task& task_1, const Task& task_2) { if (task_1.completed != task_2.completed) { return !task_1.completed; } else { return task_1.priority < task_2.priority; } }); for (const auto& task : tasks) { std::cout << "Task name: " << task.id << ", Completed: " << task.completed << ", Priority: " << task.priority << std::endl; } // 遍历任务列表,分配任务给可用的小车 for (auto& task : tasks) { if (!task.completed) { AGV* closest_agv = nullptr; // 初始化为 nullptr // 查找可用的小车 while (closest_agv == nullptr) { for (auto& agv : agvs) { if (agv.getState()) { closest_agv = &agv; break; } } if (closest_agv == nullptr) { // 没有可用的小车,等待一段时间再查找 std::this_thread::sleep_for(std::chrono::seconds(1)); } } // 找到最近的可用小车 int min_distance = INT_MAX; for (auto& agv : agvs) { if (agv.getState()) { int distance = abs(agv.getCurrentX()- task.start_x) + abs(agv.getCurrentY() - task.start_y); if (distance < min_distance) { min_distance = distance; closest_agv = &agv; } } } closest_agv->setCurrentX(closest_agv->getCurrentX()); closest_agv->setCurrentY(closest_agv->getCurrentY()); closest_agv->setEndCoord(task.end_x, task.end_y); // 将任务终点分配给 AGV 对象的终点坐标 closest_agv->setStartCoord(task.start_x, task.start_y); // 将任务起点分配给 AGV 对象的终点坐标 closest_agv->setState(false); task.completed = true; std::cout << closest_agv->getid() << "," << task.id << endl; } } },修改爲找到可用的小車,找不到等待一段时间再查找。已經找到的可用小車的任務繼續下面的流程,黨等待一段時間找到可用任務的小車也繼續下面的流程
时间: 2023-07-16 15:16:55 浏览: 92
好的,您需要将代码中的以下部分修改为:
```
// 查找可用的小车
while (closest_agv == nullptr) {
for (auto& agv : agvs) {
if (agv.getState()) {
closest_agv = &agv;
break;
}
}
if (closest_agv == nullptr) {
// 没有可用的小车,等待一段时间再查找
std::this_thread::sleep_for(std::chrono::seconds(1));
}
}
```
这样,当没有可用的小车时,程序会暂停一秒钟,然后再次查找可用的小车。已经找到可用小车的任务会继续执行下面的流程,而等待中的任务会在下一次查找时继续分配给可用的小车。
相关问题
void assign_task_to_agv(std::vector<Task>& tasks, std::vector<AGV>& agvs);怎麽修改: threads.push_back(std::thread(&AGVScheduler::assign_task_to_agv, std::vector<Task>& tasks, std::vector<AGV>& agvs));
在创建新的线程时,需要将函数的参数直接传递给 `std::thread` 构造函数,不需要在参数类型前面加上参数名。因此,正确的写法应该是:
```
threads.push_back(std::thread(&AGVScheduler::assign_task_to_agv, std::ref(tasks), std::ref(agvs)));
```
这样就可以将 `tasks` 和 `agvs` 作为参数传递给 `AGVScheduler::assign_task_to_agv` 函数,并在新的线程中运行该函数。注意,这里使用了 `std::ref` 来将 `tasks` 和 `agvs` 引用传递给线程,避免了拷贝。
void assign_task_to_agv(std::vector<Task>& tasks, std::vector<AGV>& agvs);,void MainWindow::moveAgvs(int i),void MainWindow::action_agv() { std::vectorstd::thread threads; threads.push_back(std::thread(&AGVScheduler::assign_task_to_agv, std::ref(tasks), std::ref(agvs))); // 分配小车 for (int i = 0; i < agvs.size(); i++) { threads.push_back(std::thread(& MainWindow::moveAgvs, i)); // 更新 AGV } for (auto& t : threads) { t.join(); ,報錯:no matching function for call to “std:: thread :: _ lnvoker<std::tuple<std::tuple<void(AGVScheduler::*)(std::vector<Task>)...怎麽修改
这个错误通常是由于函数指针类型不匹配导致的。在这段代码中,错误可能是由于 `AGVScheduler::assign_task_to_agv` 函数的类型与 `std::thread` 构造函数所需的类型不匹配。
请检查 `AGVScheduler::assign_task_to_agv` 函数的类型,确保其与 `std::thread` 构造函数所需的类型一致。由于 `AGVScheduler::assign_task_to_agv` 是一个成员函数,因此需要使用类的指针或引用来调用该函数。正确的写法应该是:
```
threads.push_back(std::thread(&AGVScheduler::assign_task_to_agv, &agvScheduler, std::ref(tasks), std::ref(agvs)));
```
这样就可以将 `agvScheduler` 对象、`tasks` 和 `agvs` 作为参数传递给 `AGVScheduler::assign_task_to_agv` 函数,并在新的线程中运行该函数。注意,这里使用了 `&agvScheduler` 来传递 `AGVScheduler` 对象的指针,同时使用了 `std::ref` 来将 `tasks` 和 `agvs` 引用传递给线程,避免了拷贝。
阅读全文
相关推荐
![pdf](https://img-home.csdnimg.cn/images/20241231044930.png)
![zip](https://img-home.csdnimg.cn/images/20241231045053.png)
![zip](https://img-home.csdnimg.cn/images/20241231045053.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![zip](https://img-home.csdnimg.cn/images/20241231045053.png)
![pdf](https://img-home.csdnimg.cn/images/20241231044930.png)
![zip](https://img-home.csdnimg.cn/images/20241231045053.png)
![ppt](https://img-home.csdnimg.cn/images/20241231044937.png)
![zip](https://img-home.csdnimg.cn/images/20241231045053.png)
![pdf](https://img-home.csdnimg.cn/images/20241231044930.png)
![rar](https://img-home.csdnimg.cn/images/20241231044955.png)
![zip](https://img-home.csdnimg.cn/images/20241231045053.png)
![pdf](https://img-home.csdnimg.cn/images/20241231044930.png)