0
我正在处理一个赋值,其中主函数创建了一个运行名为run()
的函数的主线程。在run函数内部,我试图使用一个客户对象创建一个新线程(模拟客户走到商店并离开)。一旦声明了一个客户对象,它就会运行一个模拟进入商店然后离开的人的功能。Thread.join()给我一个错误?
我在这里有主要功能。在里面,它声明了一个执行run()
函数的主线程,在我试图创建一个新线程的run函数内部,并且每次创建一个新线程时,都会创建一个新的客户对象,并且客户ID会增加。然后,我试图执行newCustThread.join()
,以便先前的客户线程在while循环继续并创建下一个客户线程之前完成。
主:
#include <iostream>
#include <thread>
#include "classBarberShop.h"
#include "classCustomer.h"
using namespace std;
void run();
void createCustomerObj(int customerID, BarberShop newShop);
int WAIT_TIME = 3;
BarberShop newShop();
int customerID = 1;
int main(){
thread newThread(run);
return 0;
}
void run(){
while (customerID <= 5){
thread newCustThread(Customer newCustomer(int customerID, BarberShop newShop));
newCustThread.join(); // <===== ERROR HERE
customerID++;
}
return;
}
classBarberShop.h
#include <iostream>
using namespace std;
enum bState {
FULL = -1,
EMPTY = 0,
OCCUPIED = 1,
SLEEPING = 2,
DONE = 3,
WAITING = 4
};
class BarberShop {
public:
BarberShop(){
chairNum = 5;
barber = SLEEPING;
for (int i = 0; i < chairNum; i++){
chairState[i] = EMPTY;
}
}
bool findChair(int passingCustomer){
int getEmptyChair = getFirstEmptyChair();
if (getEmptyChair == FULL){
return false;
}
else {
chairState[getEmptyChair] = OCCUPIED;
}
return true;
}
int getHairCut(int customer){
if (barber == SLEEPING){
barber = OCCUPIED;
return SLEEPING;
}
else if (barber == OCCUPIED){
bool chairFound = findChair(customer);
if (chairFound == false){
return FULL;
}
else{
/*while (barber == OCCUPIED){
}*/
for (int i = 0; i < chairNum; i++){
if (chairState[i] == OCCUPIED){
chairState[i] = EMPTY;
break;
}
}
barber = OCCUPIED;
return WAITING;
}
}
else{
barber = OCCUPIED;
return DONE;
}
}
int leaveBarberShop(int customer){
bool isWaiting = isAnyoneWaiting();
if (isWaiting == true){
barber = DONE;
}
else{
barber = SLEEPING;
}
//notify();
}
int getFirstEmptyChair(){
for (int i = 0; i < chairNum; i++){
if (chairState[i] == EMPTY){
return i;
}
return FULL;
}
}
bool isAnyoneWaiting(){
for (int i = 0; i < chairNum; i++){
if (chairState[i] == OCCUPIED){
return true;
}
}
return false;
}
//private:
int chairNum;
int barber;
int chairState[5];
};
classCustomer.h
#include <iostream>
#include "classBarberShop.h"
using namespace std;
class Customer {
int customer;
BarberShop shop;
int bstate;
int HAIRCUT_TIME = 5;
Customer(int passingCustomer, BarberShop passingShop) {
shop = passingShop;
customer = passingCustomer;
run();
}
void run() {
int sleepingTime = (int)(HAIRCUT_TIME * rand());
cout << "ENTERING SHOP: Customer [" << customer << "] entering barber shop for haircut." << endl;
bstate = OCCUPIED;
bstate = shop.getHairCut(customer);
if (bstate == WAITING){
cout << "Barber's busy: Customer [" << customer << "] has waited and now wants a haircut." << endl;
}
else if (bstate == SLEEPING){
cout << "Barber's asleep: Customer [" << customer << "] is waking him up and getting a haircut." << endl;
}
else if (bstate == FULL){
cout << "Barber shop is full: Customer [" << customer << "] is leaving shop." << endl;
return;
}
else {
cout << "HAIRCUT: Customer [" << customer << "] is getting haircut." << endl;
}
//******Suspend thread here?
cout << "LEAVING SHOP: Customer [" << customer << "] haircut finished: leaving shop." << endl;
bstate = shop.leaveBarberShop(customer);
return;
}
};
该程序在创建客户对象时运行。在创建对象时,由于构造函数的原因,运行classCustomer.h
中的函数run()
。
我不明白为什么它不起作用。我会很感激的帮助。线程是很新的给我:/
你似乎并不被给你的线程的任何代码运行。 – 2015-03-30 23:50:28
我只想指出,您给我们提供的错误的最佳描述是“错误”,我们甚至无法运行代码来找到自己的错误。 – chris 2015-03-30 23:51:26
@JonathanPotter我为这个问题增加了更多细节。看起来好像我还有一些比预期更多的错误:(抱歉没有立即给出代码,我在发布后正在编辑它!感谢您的帮助!! – MR04 2015-03-30 23:57:43