2015-03-30 87 views
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()

我不明白为什么它不起作用。我会很感激的帮助。线程是很新的给我:/

+0

你似乎并不被给你的线程的任何代码运行。 – 2015-03-30 23:50:28

+1

我只想指出,您给我们提供的错误的最佳描述是“错误”,我们甚至无法运行代码来找到自己的错误。 – chris 2015-03-30 23:51:26

+0

@JonathanPotter我为这个问题增加了更多细节。看起来好像我还有一些比预期更多的错误:(抱歉没有立即给出代码,我在发布后正在编辑它!感谢您的帮助!! – MR04 2015-03-30 23:57:43

回答

1

退出主()之前加入的内螺纹:

int main() 
{ 
    thread newThread(run); 
    newThread.join(); // <-- missing line 
    return 0; 
}