⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 cartest.cpp

📁 C++高级编程这本书所附的源代码
💻 CPP
字号:
#include "CarFactory.h"
#include <vector>

using namespace std;

CarFactory* getLeastBusyFactory(const vector<CarFactory*>& inFactories)
{
  if (inFactories.size() == 0) return NULL;

  CarFactory* bestSoFar = inFactories[0];


  for (size_t i = 1; i < inFactories.size(); i++)
    {
      if (inFactories[i]->getNumCarsInProduction() <
	  bestSoFar->getNumCarsInProduction()) {
	bestSoFar = inFactories[i];
      }
    }

  return bestSoFar;
}

int main(int argc, char** argv)
{
  vector<CarFactory*> factories;

  // Create 3 Ford factories and 1 Toyota factory. 
  FordFactory* factory1 = new FordFactory();
  FordFactory* factory2 = new FordFactory();
  FordFactory* factory3 = new FordFactory();
  ToyotaFactory* factory4 = new ToyotaFactory();

  // To get more interesting results, pre-preorder some cars.
  factory1->requestCar();
  factory1->requestCar();
  factory2->requestCar();
  factory4->requestCar();

  // Add the factories to a vector.
  factories.push_back(factory1);
  factories.push_back(factory2);
  factories.push_back(factory3);
  factories.push_back(factory4);

  // Build 10 cars from the least busy factory.
  for (int i = 0; i < 10; i++) {
    CarFactory* currentFactory = getLeastBusyFactory(factories);
    Car* theCar = currentFactory->requestCar();
    theCar->info();
  }
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -