ClubEnsayos.com - Ensayos de Calidad, Tareas y Monografias
Buscar

Naturaleza social del ser humano


Enviado por   •  23 de Febrero de 2016  •  Documentos de Investigación  •  1.164 Palabras (5 Páginas)  •  290 Visitas

Página 1 de 5

#include "stdafx.h"

#include <iostream>

using namespace std;

/**************************

* DEFINICION DE CALLBACKS *

* (PROYECTO 1) *

**************************/

static int function1(int param)

{

cout << "Parametro: " << param << "\n";

cout << "Funcion: " << 1 << "\n";

return 1;

}

class ClassA

{

public:

static int function2(int param);

};

int ClassA::function2(int param)

{

cout << "Parametro: " << param << "\n";

cout << "Funcion: " << 2 << "\n";

return 2;

}

class ClassB

{

public:

static void setCallBack(int (ClassB::*&cb)(int));

private:

int function3(int param);

};

int ClassB::function3(int param)

{

cout << "Parametro: " << param << "\n";

cout << "Funcion: " << 3 << "\n";

return 3;

}

void ClassB::setCallBack(int (ClassB::*&cb)(int))

{

cb = &ClassB::function3;

}

typedef int(*CallBack)(int);

typedef int(ClassB::*CallBackB)(int);

/*****************************

* DEFINICION DE KERNEL Y PCB *

* (PROYECTO 2) *

*****************************/

#define MAX 10 //La cantidad maxima de procesos

//DEFINICION DE CONSTANTES PARA ESTADOS DEL PROCESO

//NOTA: No todas las constantes se utilizan por ahora

#define RUNNING 1 //El proceso se esta ejecutando

#define BLOCKED 2 //El proceso se encuentra bloqueado

#define READY 3 //El proceso se encuentra listo para su ejecucion

#define SUSPENDED 4 //El proceso se ha suspendido

#define WAITING 5

#define DONE 6

#define READY_AND_SUSPENDED (READY | SUSPENDED) //Listo y suspendido

#define BLOCKED_AND_SUSPENDED ((BLOCKED | SUSPENDED) + 2) //Bloqueado y suspendido

#define SUCCESSFUL 0 //Resultado exitoso ->UTILIZADA EN TODAS LAS FUNCIONES<-

//DEFINICION DE CONSTANTES DEL RESULTADO DE AGREGAR UN PROCESO

#define UNAVAILABLE 1 //Posicion no disponible para agregar al proceso

#define OVERFLOW 2 //La cantidad de procesos agregados ha sido alcanzada

#define OUT_OF_RANGE 3 //El indice para agregar ha sido sobrepasado

//DEFINICION DE CONSTANTES DEL RESULTADO DE CORRER UN PROCESO

//TODO: Pueden existir mas casos, revisar. Quizas sea mejor retornar el valor de status en el pcb

#define PROCESS_IS_NULL 1 //No hay proceso en esa posicion

#define PROCESS_IS_DONE 2 //El proceso ha sido terminado y desea ejecutarse

#define PROCESS_NOT_FOUND 3 //El proceso no ha sido encontrado

//TODO: Es probable que se necesite hacer un template con la clase PCB

///<summary>Process Control Block <para>Registra la informacion de un proceso</para></summary>

class PCB

{

private:

///<summary>Representa el identificador de proceso</summary>

int id;

public:

///<summary>status: Estado del proceso <para>*function: Puntero a la funcion que debe ejecutar</para></summary>

int status, *function;

///<summary>Objeto a utilizar en caso de que la funcion no sea estatica</summary>

ClassB *obj;

///<summary><param name = "id">Identificador de proceso</param>

///<param name = "status">Estado con el que se inicializa el proceso</param>

///<param name = "callback">puntero a la funcion</param></summary>

PCB(int id, int status, int *callback)

{

this->id = id;

this->status = status;

this->function = callback;

this->obj = NULL;

}

///<summary><param name = "id">Identificador de proceso</param>

///<param name = "status">Estado con el que se inicializa el proceso</param>

///<param name = "callback">puntero a la funcion</param>

///<param name = "obj">Objeto inicializado para una funcion no estatica</param></summary>

PCB(int id, int status, int *callback, ClassB *obj)

{

this->id = id;

this->status = status;

this->function = callback;

this->obj = obj;

}

~PCB()

{

this->id = this->status = 0;

this->function = NULL;

if (this->obj != NULL)

{ //TODO: Agregar el destructor de obj, si es necesario

this->obj = NULL;

}

}

///<summary>Retorna el id del PCB</summary>

int getId()

{

return this->id;

}

};

///<summary>Kernel que lleva la tabla de procesos</summary>

class Kernel

{

private:

///<summary>Contador de identificadores</summary>

int id_count;

///<summary>Valida si un proceso nuevo puede ser agregado en la posicion

///</param name = "index">Indice en que se quiere insertar el proceso</param>

///<para><returns>Entero que inidica el resultado</returns></para></summary>

int validateNewProcess(int index)

{

if (index >= MAX || index < 0)

return OUT_OF_RANGE;

if (this->pcb[index] != NULL)

{

if (this->pcb[index]->status != DONE)

return UNAVAILABLE;

else

killProcessAt(index);

}

if (count >= MAX)

return OVERFLOW;

return SUCCESSFUL;

}

///<summary>Corre un proceso al recibir el PCB

///<param name = "pcb">Puntero al Bloque de Control de Proceso</param></summary>

static void runProcess(PCB *pcb)

{

int result;

int *function = pcb->function;

pcb->status = RUNNING;

if (pcb->obj != NULL)

...

Descargar como (para miembros actualizados) txt (12 Kb) pdf (87 Kb) docx (17 Kb)
Leer 4 páginas más »
Disponible sólo en Clubensayos.com