EventLoopThreadPool.cc revision 354280cf
1354280cfSShuo Chen// excerpts from http://code.google.com/p/muduo/ 2354280cfSShuo Chen// 3354280cfSShuo Chen// Use of this source code is governed by a BSD-style license 4354280cfSShuo Chen// that can be found in the License file. 5354280cfSShuo Chen// 6354280cfSShuo Chen// Author: Shuo Chen (chenshuo at chenshuo dot com) 7354280cfSShuo Chen 8354280cfSShuo Chen#include "EventLoopThreadPool.h" 9354280cfSShuo Chen 10354280cfSShuo Chen#include "EventLoop.h" 11354280cfSShuo Chen#include "EventLoopThread.h" 12354280cfSShuo Chen 13354280cfSShuo Chen#include <boost/bind.hpp> 14354280cfSShuo Chen 15354280cfSShuo Chenusing namespace muduo; 16354280cfSShuo Chen 17354280cfSShuo ChenEventLoopThreadPool::EventLoopThreadPool(EventLoop* baseLoop) 18354280cfSShuo Chen : baseLoop_(baseLoop), 19354280cfSShuo Chen started_(false), 20354280cfSShuo Chen numThreads_(0), 21354280cfSShuo Chen next_(0) 22354280cfSShuo Chen{ 23354280cfSShuo Chen} 24354280cfSShuo Chen 25354280cfSShuo ChenEventLoopThreadPool::~EventLoopThreadPool() 26354280cfSShuo Chen{ 27354280cfSShuo Chen // Don't delete loop, it's stack variable 28354280cfSShuo Chen} 29354280cfSShuo Chen 30354280cfSShuo Chenvoid EventLoopThreadPool::start() 31354280cfSShuo Chen{ 32354280cfSShuo Chen assert(!started_); 33354280cfSShuo Chen baseLoop_->assertInLoopThread(); 34354280cfSShuo Chen 35354280cfSShuo Chen started_ = true; 36354280cfSShuo Chen 37354280cfSShuo Chen for (int i = 0; i < numThreads_; ++i) 38354280cfSShuo Chen { 39354280cfSShuo Chen EventLoopThread* t = new EventLoopThread; 40354280cfSShuo Chen threads_.push_back(t); 41354280cfSShuo Chen loops_.push_back(t->startLoop()); 42354280cfSShuo Chen } 43354280cfSShuo Chen} 44354280cfSShuo Chen 45354280cfSShuo ChenEventLoop* EventLoopThreadPool::getNextLoop() 46354280cfSShuo Chen{ 47354280cfSShuo Chen baseLoop_->assertInLoopThread(); 48354280cfSShuo Chen EventLoop* loop = baseLoop_; 49354280cfSShuo Chen 50354280cfSShuo Chen if (!loops_.empty()) 51354280cfSShuo Chen { 52354280cfSShuo Chen // round-robin 53354280cfSShuo Chen loop = loops_[next_]; 54354280cfSShuo Chen ++next_; 55354280cfSShuo Chen if (static_cast<size_t>(next_) >= loops_.size()) 56354280cfSShuo Chen { 57354280cfSShuo Chen next_ = 0; 58354280cfSShuo Chen } 59354280cfSShuo Chen } 60354280cfSShuo Chen return loop; 61354280cfSShuo Chen} 62354280cfSShuo Chen 63