Diferencia entre revisiones de «First in, first out»

Contenido eliminado Contenido añadido
Marcecoro (discusión · contribs.)
m Deshecha la edición 74063485 de 201.183.137.113 (disc.)
Marcecoro (discusión · contribs.)
Sin resumen de edición
Línea 1:
'''Primero“Primero en entrar, primero en salirsalir”''', (Enen [[idioma inglés|inglés]] ''First'''first in, first out'', también se usan las [[sigla]]s''' ('''''FIFO''''') , es un concepto utilizado en [[Estructura de datos|estructuras de datos]], [[contabilidad de costes]] y [[teoría de colas]]. Guarda analogía con las personas que esperan en una cola y van siendo atendidas en el orden en que llegaron, es decir, que ''la‘la primera persona que entra es la primera persona que sale''sale’.
 
También se le denomina «primero en llegar, primero en ser atendido», (delen inglés '''''first come, first served''''' o ('''''FCFS''''').
 
== Informática ==
[[Archivo:Fifo.PNG|thumb|Esquema de funcionamiento de una [[cola (estructura de datos)|cola]] FIFO.]]
 
PEPSEn [[informática]], FIFO se utiliza en estructuras de datos para implementar [[cola (estructura de datos)|colas]]. La implementación puede efectuarse con ayuda de [[arrayArreglo (computación)|arreglos]]s o [[vector (programación)|vectores]], o bien mediante el uso de [[puntero]]s y [[asignación dinámica de memoria]].
 
Si se implementa mediante vectores, el número máximo de elementos que puede almacenar FIFO está limitado al que se haya establecido en el código del programa antes de la compilación (cola '''<u>estática'''</u>) o durante su ejecución (cola '''<u>pseudoestática'''</u> ó '''<u>dinámica'''</u>). Sea cual sea la opción elegida, el número de elementos que podrá almacenar la cola quedará determinado durante toda la ejecución del programa. Así, el sistema debe reservar el tamaño de memoria necesario para acoger todos los datos, sea cual sea el número de elementos usados.
 
En algunas aplicaciones, esto supone un problema ya que puede desconocerse el número de elementos a contener en la cola. La sencilla solución de reservar más memoria de la que se supone que se necesitará, puede conducir a un despilfarro de la memoria (la cola puede que esté llena, aprovechando toda la memoria reservada; o bien, nunca terminar de llenarse, ocupando recursos innecesarios en memoria). Sin embargo, si se usa asignación dinámica de memoria, el número máximo no está declarado en tiempo de compilación sino en tiempo de ejecución, es decir, se reserva memoria a medida que se necesite expandir el tamaño de la cola (adaptándose al tamaño necesario en cada momento en función de los elementos que hay en la cola), haciendo un mejor uso de la memoria disponible.
 
Uno de los usos de las colas es la exploración "en‘en anchura"anchura’ de un [[Árbol binario de búsqueda|árbol binario de búsqueda]]. Otro uso típico de las colas, es la gestión de descargas de una aplicación ''[[Peer-to-peer|P2P]]''.
 
== Contabilidad ==
{{AP|FIFO y LIFO (contabilidad)}}
 
En [[contabilidad]], FIFO es un método para registrar el valor de un inventario.

Su uso es apropiado cuando se cuenta con varios lotes de un mismo producto. Este método presume que el primer producto ingresado en el almacén será el primero en salir por efectos del inventario.
 
== Electrónica ==
{{AP|registro tubo}}
 
Los FIFOsFIFO se usan comúnmente en circuitos de [[electrónica]] para almacenaje y hacer control de flujo. Hablando de hardware, un FIFO consiste básicamente en un conjunto de punteros de lectura/escritura, almacenamiento y lógica de control. El almacenamiento puede ser ''[[SRAM]]'', ''[[flip-flop]]s'', ''[[latch]]es'' o cualquier otra forma adecuada de almacenamiento. Para FIFOsFIFO de un tamaño importante se usa usualmente una SRAM de doble puerto, donde uno de los puertos se usa para la escritura y el otro para la lectura.
 
Un FIFO“FIFO sincrónicosincrónico” maneja el mismo [[Señal de reloj|reloj]] (clock) tanto para las lecturas como para las escrituras. Un FIFO“FIFO asicrónicoasicrónico” es aquel que utiliza diferentes relojes (clocks) uno para lectura y otro para la escritura. Cuando se habla de FIFOsFIFO asincrónicosasincrónico se introduce el tema de la [[Metaestable#En_electr.C3.B3nica_digitalEn electrónica digital|meta-estabilidad]].
 
Una implementación común de un FIFO asincrónico usa un [[Códigocódigo Gray]] (o cualquier código de unidad de distancia) para los punteros de lectura y escritura de modo de asegurarse una generación de banderas (''flags'') segura/estable.
Otra nota adicional respecto de la generación de banderas es que uno debe necesariamente usar punteros aritméticos para generar banderas para implementaciones asincrónicas de FIFO.
Por otro lado, uno puede usar tanto un acercamiento "''leaky bucket''" o punteros aritméticos para generar banderas en una implementación FIFO sincrónica.
IFO, se pueden enumerar: ''full'' (lleno), ''empty'' (vacío), ''almost full'' (casi lleno) o ''almost empty'' (casi vacío).
 
Por otro lado, uno puede usar tanto un acercamiento "''leaky bucket''" o punteros aritméticos para generar banderas en una implementación FIFO sincrónica.
=== FIFO full/empty (lleno/vacío) ===
 
IFOEn FIFO, se pueden enumerar: ''full'' (lleno), ''empty'' (vacío), ''almost full'' (casi lleno) o ''almost empty'' (casi vacío).
 
=== ''FIFO full/empty ''(lleno/vacío) ===
En hardware, un FIFO se usa para propósitos de sincronización. Comportándose como una [[cola circular]] y, por lo tanto, contiene dos punteros:
#Puntero de Lectura / Registro de Dirección de Lectura
#Puntero de Escritura / Registro de Dirección de Escritura
 
Las direcciones de lectura y escritura están ambas inicialmente en la primera ubicación de la memoria y la cola FIFO está '''Vacíavacía'''.
;FIFO Vacíavacía: Cuandocuando el registro de dirección de lectura alcanza al registro de dirección de escritura, la cola FIFO dispara la señal o bandera ''Vacío''<u>vacío</u>.
;FIFO Llenallena: Cuandocuando el registro de dirección de escritura alcanza al registro de dirección de lectura, la cola FIFO dispara la señal o bandera.
 
== Véase también ==