Пример #1
0
//state determines to which list/state gRunning will be pushed to.
void switchThreads(State state)
{
	gTotalQuantums++;
	if(gReady.empty() )
//		either main thread is the only thread and it is running.
//		or other thread is running and main must be in ready list.
	{
		gRunning->increaseQuantum();
	}
	else
	{
		Thread* next = gReady.pop();
		int retVal = 0;
		switch(state)
		{
		case READY :
			gReady.push(gRunning);
			gRunning->setState(READY);
			retVal = sigsetjmp(*(gRunning->getThreadState() ),1);
			break;
		case BLOCKED :
			gRunning->setState(BLOCKED);
			gBlocked[gRunning->getID()] = gRunning;
			retVal = sigsetjmp(*(gRunning->getThreadState() ),1);
			break;
		case TERMINATED :
			gThreads.erase(gRunning->getID() );
			gAvailableID.push(gRunning->getID() );
			delete gRunning;
			retVal = 0;
			break;
		default :
			break;
		}
		if (retVal == 0)
		{
			gRunning = next;
			next->setState(RUNNING);
			gRunning->increaseQuantum();
			siglongjmp(*(gRunning->getThreadState() ),1);
		}
	}

	if (setitimer(ITIMER_VIRTUAL, &gTimer, NULL) == FAILURE)
	{
		int errTmp = errno;
		std::cerr<< SETITIMER_ERR << strerror(errTmp) << std::endl;
		exit(1);

	}
}
Пример #2
0
int main( int argc, char** argv ) {
	cout << "\n Double link list\n";
	DoubleLink<int> dblVec;
	dblVec.push( 3 );
	dblVec.push( 1 );
	dblVec.push( 10 );
	dblVec.push( 15 );
	dblVec.push( 8 );
	dblVec.display();
	dblVec.pop();
	dblVec.display();
	
	
	cout << "\n Stack list\n";
	Stack<int> stack;
	stack.push( 3 );
	stack.push( 1 );
	stack.push( 10 );
	stack.push( 15 );
	stack.push( 8 );
	stack.display();
	stack.pop();
	stack.display();
//	cout << stack.find( 10 ) << endl;
	
	cout << "\n Queue list\n";
	Queue<int> queue;
	queue.push( 3 );
	queue.push( 1 );
	queue.push( 10 );
	queue.push( 15 );
	queue.push( 8 );
	queue.display();
	queue.pop();
	queue.display();
//	cout << queue.find( 10 ) << endl;
	
	
	cout << "\n Circle list\n";
	CircleLink<int> circle;
	circle.push( 3 );
	circle.push( 1 );
	circle.push( 10 );
	circle.push( 15 );
	circle.push( 8 );
	circle.display();
	circle.pop();
	circle.display();
//	cout << circle.find( 10 ) << endl;
	
	
	cout << "\n Sorted list\n";
	SortedList<int> sort;
	sort.push( 3 );
	sort.push( 1 );
	sort.push( 10 );
	sort.push( 15 );
	sort.push( 8 );
	sort.display();
	sort.pop();
	sort.display();
//	cout << sort.find( 10 ) << endl;
	
	cout << "\nPriority list\n";
	PriorityList<int> plist;
	plist.push( 3 );
	plist.push( 1 );
	plist.push( 10 );
	plist.push( 15 );
	plist.push( 8 );
	plist.display();
	plist.pop();
	plist.display();
	cout << plist.find( 10 ) << endl;
	plist.display();
	
}