<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="es">
	<id>https://www.ecured.cu/index.php?action=history&amp;feed=atom&amp;title=Iteradores_%28Programaci%C3%B3n%29</id>
	<title>Iteradores (Programación) - Historial de revisiones</title>
	<link rel="self" type="application/atom+xml" href="https://www.ecured.cu/index.php?action=history&amp;feed=atom&amp;title=Iteradores_%28Programaci%C3%B3n%29"/>
	<link rel="alternate" type="text/html" href="https://www.ecured.cu/index.php?title=Iteradores_(Programaci%C3%B3n)&amp;action=history"/>
	<updated>2026-06-10T07:34:49Z</updated>
	<subtitle>Historial de revisiones para esta página en el wiki</subtitle>
	<generator>MediaWiki 1.31.16</generator>
	<entry>
		<id>https://www.ecured.cu/index.php?title=Iteradores_(Programaci%C3%B3n)&amp;diff=3443517&amp;oldid=prev</id>
		<title>Javiermartin jc: Texto reemplazado: «&lt;div align=&quot;justify&quot;&gt;» por «»</title>
		<link rel="alternate" type="text/html" href="https://www.ecured.cu/index.php?title=Iteradores_(Programaci%C3%B3n)&amp;diff=3443517&amp;oldid=prev"/>
		<updated>2019-07-06T18:34:43Z</updated>

		<summary type="html">&lt;p&gt;Texto reemplazado: «&amp;lt;div align=&amp;quot;justify&amp;quot;&amp;gt;» por «»&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;es&quot;&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;← Revisión anterior&lt;/td&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;Revisión del 18:34 6 jul 2019&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l1&quot; &gt;Línea 1:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Línea 1:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;−&lt;/td&gt;&lt;td style=&quot;color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;del class=&quot;diffchange diffchange-inline&quot;&gt;&amp;lt;div align=&amp;quot;justify&amp;quot;&amp;gt;&lt;/del&gt;{{Definición|Nombre= Iteradores (Programación)&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;+&lt;/td&gt;&lt;td style=&quot;color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;{{Definición|Nombre= Iteradores (Programación)&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;|imagen= |concepto= Es un puntero que es utilizado por un algoritmo para recorrer los elementos almacenados en un contenedor}}&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;|imagen= |concepto= Es un puntero que es utilizado por un algoritmo para recorrer los elementos almacenados en un contenedor}}&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&amp;#160; &amp;#160;&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&amp;#160; &amp;#160;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;

&lt;!-- diff cache key wiki1:diff::1.12:old-1736417:rev-3443517 --&gt;
&lt;/table&gt;</summary>
		<author><name>Javiermartin jc</name></author>
		
	</entry>
	<entry>
		<id>https://www.ecured.cu/index.php?title=Iteradores_(Programaci%C3%B3n)&amp;diff=1736417&amp;oldid=prev</id>
		<title>Majibacoa2 jc en 16:22 19 nov 2012</title>
		<link rel="alternate" type="text/html" href="https://www.ecured.cu/index.php?title=Iteradores_(Programaci%C3%B3n)&amp;diff=1736417&amp;oldid=prev"/>
		<updated>2012-11-19T16:22:45Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;es&quot;&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;← Revisión anterior&lt;/td&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;Revisión del 16:22 19 nov 2012&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l120&quot; &gt;Línea 120:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Línea 120:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;*[[Iteradores de salida (Programación)|Iteradores de salida (Programación)]]&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;*[[Iteradores de salida (Programación)|Iteradores de salida (Programación)]]&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;*[[Iteradores de inserción (Programación)|Iteradores de inserción (Programación)]]&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;*[[Iteradores de inserción (Programación)|Iteradores de inserción (Programación)]]&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot;&gt;&amp;#160;&lt;/td&gt;&lt;td class='diff-marker'&gt;+&lt;/td&gt;&lt;td style=&quot;color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;*[[Manipulación de Iteradores (Programación)|Manipulación de Iteradores (Programación)]]&lt;/ins&gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;== Fuente ==&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;== Fuente ==&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;* [http://msdn.microsoft.com/es-es/library/dscyy5s0%28v=vs.80%29.aspx Iteradores]&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;* [http://msdn.microsoft.com/es-es/library/dscyy5s0%28v=vs.80%29.aspx Iteradores]&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;[[Category:Informática]] [[Category:Lenguajes_de_programación]] [[Category:Programación]]&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;[[Category:Informática]] [[Category:Lenguajes_de_programación]] [[Category:Programación]]&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;

&lt;!-- diff cache key wiki1:diff::1.12:old-1736118:rev-1736417 --&gt;
&lt;/table&gt;</summary>
		<author><name>Majibacoa2 jc</name></author>
		
	</entry>
	<entry>
		<id>https://www.ecured.cu/index.php?title=Iteradores_(Programaci%C3%B3n)&amp;diff=1736118&amp;oldid=prev</id>
		<title>Majibacoa2 jc en 14:15 19 nov 2012</title>
		<link rel="alternate" type="text/html" href="https://www.ecured.cu/index.php?title=Iteradores_(Programaci%C3%B3n)&amp;diff=1736118&amp;oldid=prev"/>
		<updated>2012-11-19T14:15:51Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;es&quot;&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;← Revisión anterior&lt;/td&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;Revisión del 14:15 19 nov 2012&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l119&quot; &gt;Línea 119:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Línea 119:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;*[[Iteradores de entrada (Programación)|Iteradores de entrada (Programación)]]&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;*[[Iteradores de entrada (Programación)|Iteradores de entrada (Programación)]]&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;*[[Iteradores de salida (Programación)|Iteradores de salida (Programación)]]&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;*[[Iteradores de salida (Programación)|Iteradores de salida (Programación)]]&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot;&gt;&amp;#160;&lt;/td&gt;&lt;td class='diff-marker'&gt;+&lt;/td&gt;&lt;td style=&quot;color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;*[[Iteradores de inserción (Programación)|Iteradores de inserción (Programación)]]&lt;/ins&gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;== Fuente ==&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;== Fuente ==&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;* [http://msdn.microsoft.com/es-es/library/dscyy5s0%28v=vs.80%29.aspx Iteradores]&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;* [http://msdn.microsoft.com/es-es/library/dscyy5s0%28v=vs.80%29.aspx Iteradores]&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;[[Category:Informática]] [[Category:Lenguajes_de_programación]] [[Category:Programación]]&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;[[Category:Informática]] [[Category:Lenguajes_de_programación]] [[Category:Programación]]&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;

&lt;!-- diff cache key wiki1:diff::1.12:old-1735551:rev-1736118 --&gt;
&lt;/table&gt;</summary>
		<author><name>Majibacoa2 jc</name></author>
		
	</entry>
	<entry>
		<id>https://www.ecured.cu/index.php?title=Iteradores_(Programaci%C3%B3n)&amp;diff=1735551&amp;oldid=prev</id>
		<title>Majibacoa2 jc en 18:41 18 nov 2012</title>
		<link rel="alternate" type="text/html" href="https://www.ecured.cu/index.php?title=Iteradores_(Programaci%C3%B3n)&amp;diff=1735551&amp;oldid=prev"/>
		<updated>2012-11-18T18:41:15Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;es&quot;&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;← Revisión anterior&lt;/td&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;Revisión del 18:41 18 nov 2012&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l117&quot; &gt;Línea 117:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Línea 117:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;*[[Operadores|Operadores]] &amp;#160;&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;*[[Operadores|Operadores]] &amp;#160;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;*[[Sentencias (Programación)|Sentencias (Programación)]]&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;*[[Sentencias (Programación)|Sentencias (Programación)]]&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot;&gt;&amp;#160;&lt;/td&gt;&lt;td class='diff-marker'&gt;+&lt;/td&gt;&lt;td style=&quot;color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;*[[Iteradores de entrada (Programación)|Iteradores de entrada (Programación)]]&lt;/ins&gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot;&gt;&amp;#160;&lt;/td&gt;&lt;td class='diff-marker'&gt;+&lt;/td&gt;&lt;td style=&quot;color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;*[[Iteradores de salida (Programación)|Iteradores de salida (Programación)]]&lt;/ins&gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;== Fuente ==&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;== Fuente ==&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;* [http://msdn.microsoft.com/es-es/library/dscyy5s0%28v=vs.80%29.aspx Iteradores]&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;* [http://msdn.microsoft.com/es-es/library/dscyy5s0%28v=vs.80%29.aspx Iteradores]&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;[[Category:Informática]] [[Category:Lenguajes_de_programación]] [[Category:Programación]]&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;[[Category:Informática]] [[Category:Lenguajes_de_programación]] [[Category:Programación]]&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;

&lt;!-- diff cache key wiki1:diff::1.12:old-1735530:rev-1735551 --&gt;
&lt;/table&gt;</summary>
		<author><name>Majibacoa2 jc</name></author>
		
	</entry>
	<entry>
		<id>https://www.ecured.cu/index.php?title=Iteradores_(Programaci%C3%B3n)&amp;diff=1735530&amp;oldid=prev</id>
		<title>Majibacoa2 jc: Página creada con '&lt;div align=&quot;justify&quot;&gt;{{Definición|Nombre= Iteradores (Programación) |imagen= |concepto= Es un puntero que es utilizado por un algoritmo para recorrer los elementos almacenados...'</title>
		<link rel="alternate" type="text/html" href="https://www.ecured.cu/index.php?title=Iteradores_(Programaci%C3%B3n)&amp;diff=1735530&amp;oldid=prev"/>
		<updated>2012-11-18T18:01:02Z</updated>

		<summary type="html">&lt;p&gt;Página creada con &amp;#039;&amp;lt;div align=&amp;quot;justify&amp;quot;&amp;gt;{{Definición|Nombre= Iteradores (Programación) |imagen= |concepto= Es un puntero que es utilizado por un algoritmo para recorrer los elementos almacenados...&amp;#039;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Página nueva&lt;/b&gt;&lt;/p&gt;&lt;div&gt;&amp;lt;div align=&amp;quot;justify&amp;quot;&amp;gt;{{Definición|Nombre= Iteradores (Programación)&lt;br /&gt;
|imagen= |concepto= Es un puntero que es utilizado por un algoritmo para recorrer los elementos almacenados en un contenedor}}&lt;br /&gt;
 &lt;br /&gt;
'''Iteradores (Programación)'''. Un iterador es un [[Puntero (C++)|puntero]] que es utilizado por un [[Algoritmo|algoritmo]] para recorrer los elementos almacenados en un contenedor. Dado que los distintos algoritmos necesitan recorrer los contenedores de diversas maneras para realizar diversas operaciones, y los contenedores deben ser accedidos de formas distintas, existen diferentes tipos de iteradores. Cada contenedor de la Librería Estándar puede generar un iterador con funcionalidad adecuada a la técnica de almacenamiento que utiliza. Es precisamente el tipo de iterador requerido como argumento, lo que distingue qué algoritmos STL pueden ser utilizados con cada clase de contenedor. Por ejemplo, si un contenedor solo dispone de iteradores de acceso secuencial, no pueden utilizarse con algoritmos que exijan iteradores de acceso aleatorio.&lt;br /&gt;
&lt;br /&gt;
Los iteradores sirven para señalar elementos dentro de los contenedores de la STL, también se utilizan para señalar elementos dentro de otras estructuras: flujos (Streams) y bufers de flujo (Buffers streams). Además se han definido de modo que cuando los elementos de [[Matriz|matriz]] están definidos mediante subíndices son también iteradores. La consecuencia es que ciertos algoritmos pueden aplicarse también sobre las matrices (las matrices son un tipo de estructura de datos, y que el operador elemento de matriz [] se define como la indirección de un puntero). &lt;br /&gt;
==Ejemplo==&lt;br /&gt;
 &lt;br /&gt;
 vector&amp;lt;int&amp;gt; cInt;                // contenedor tipo vector para enteros&lt;br /&gt;
 ...                              // introducimos algunos enteros en cInt&lt;br /&gt;
 std::vector&amp;lt;int&amp;gt;::iterator iT1;  // iterador-a-vector-de-int&lt;br /&gt;
 ...&lt;br /&gt;
 iT1 = cInt.begin();              // iT1 señala al primer miembro de cInt&lt;br /&gt;
 ...&lt;br /&gt;
 std::cout &amp;lt;&amp;lt; *iT1;               // muestra el primer miembro de cInt&lt;br /&gt;
 ...&lt;br /&gt;
 ++iT1;                           // desplaza iT1 al segundo miembro&lt;br /&gt;
 std::cout &amp;lt;&amp;lt; *iT1;               // muestra el segundo miembro de cInt &lt;br /&gt;
==La clase iterator==&lt;br /&gt;
La [[Sentencias (Programación)|sentencia]] anterior, donde se declara un iterador iT1 de la clase vector&amp;lt;int&amp;gt; es fundamental para entender la naturaleza de los iteradotes&lt;br /&gt;
  std::vector&amp;lt;int&amp;gt;::iterator iT1;&lt;br /&gt;
Esta sentencia intancia un objeto iT1 de la clase iterator que pertenece al espacio de una instanciación concreta, vector&amp;lt;int&amp;gt;, de una clase genérica vector&amp;lt;T&amp;gt;. La clase iterator para vectores-de-int está definida en el [[Ámbito (Programación)|ámbito]] de la clase genérica vector&amp;lt;T&amp;gt;.  Es decir, la definición del contenedor vector es algo como: &lt;br /&gt;
 template &amp;lt;class T, ...&amp;gt; vector {&lt;br /&gt;
   public:&lt;br /&gt;
   class iterator;&lt;br /&gt;
 };&lt;br /&gt;
A su vez esta clase iterator debe dispone de su propia definición en algún punto de la cabecera &amp;lt;vector&amp;gt;:&lt;br /&gt;
 &lt;br /&gt;
 class vector&amp;lt;T&amp;gt;::iterator {&lt;br /&gt;
 /* definición dependiente de la implementación */&lt;br /&gt;
 }; &lt;br /&gt;
Esta es la razón por la que coloquialmente se dice que un contenedor puede generar un iterador adecuado. Como puede verse, existen tantas clases iterator como contenedores distintos; todas ellas son distintas e independientes. Aunque comparten el mismo nombre y están definidas en subespacio distintos de std (recuerde que las clases constituyen ámbitos en sí mismas). &lt;br /&gt;
 typedef implementation defined iterator;&lt;br /&gt;
 typedef implementation defined const_iterator;&lt;br /&gt;
 typedef implementation defined size_type;&lt;br /&gt;
 typedef implementation defined difference_type;&lt;br /&gt;
 typedef std::reverse_iterator&amp;lt;iterator&amp;gt; reverse_iterator;&lt;br /&gt;
 typedef std::reverse_iterator&amp;lt;const_iterator&amp;gt; const_reverse_iterator; &lt;br /&gt;
==Características==&lt;br /&gt;
Existen diversas características principales que distinguen unos iteradores de otros. Podemos resumirlas como sigue:&lt;br /&gt;
* Capacidad de modificar los datos subyacentes. En este sentido pueden ser de solo lectura; solo escritura, o lectura/escritura. &lt;br /&gt;
* Tipo de desplazamiento que puede realizarse con ellos para recorrer el contenedor. Puede ser de avance secuencial; avance y retroceso secuencial, o acceso aleatorio. &lt;br /&gt;
* Otras características adicionales. Por ejemplo, la posibilidad de ser utilizados por algoritmos que permiten insertar o borrar elementos del contenedor asociado.  &lt;br /&gt;
==Categorías==&lt;br /&gt;
El estándar distingue cinco variedades de iteradores (denominadas categorías) en función de algunas de las características antes enunciadas:&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; border=&amp;quot;1&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Categoría&lt;br /&gt;
! Nombre genérico&lt;br /&gt;
! Resumen de propiedades&lt;br /&gt;
|-&lt;br /&gt;
| Acceso aleatorio&lt;br /&gt;
| RandomAccessIterator&lt;br /&gt;
|Lectura/escritura. Acceso aleatorio&lt;br /&gt;
|-&lt;br /&gt;
| Bidireccional&lt;br /&gt;
| BidirectionalIterator&lt;br /&gt;
| Lectura/escritura, movimiento adelante y atrás&lt;br /&gt;
|-&lt;br /&gt;
| Adelante&lt;br /&gt;
| ForwardIterator&lt;br /&gt;
| Lectura/escritura, movimiento hacia delante.&lt;br /&gt;
|-&lt;br /&gt;
| Entrada&lt;br /&gt;
| InputIterator&lt;br /&gt;
| Solo lectura, movimiento hacia delante&lt;br /&gt;
|-&lt;br /&gt;
| Salida&lt;br /&gt;
| OutputIterator&lt;br /&gt;
| Solo escritura, movimiento hacia delante&lt;br /&gt;
|} &lt;br /&gt;
Nombre genérico  es un especificador de tipo, de forma que existen cinco tipos de iteradores. Para poder efectuar la resolución de [[Sobrecarga de operadores|sobrecarga]] basándose en diferencias de categoría con funciones que utilizan iteradores como argumento, la STL proporciona cinco clases que representan cada una de estas categorías. Corresponden al esquema de la figura adjunta y responden las definiciones siguientes: &lt;br /&gt;
 struct InputIterator { ... };&lt;br /&gt;
 struct OutputIterator { ... };&lt;br /&gt;
 struct FordwarIterator : public InpuptIterator { ... };&lt;br /&gt;
 struct BidirectionalIterator : public FordwardIterator { ... };&lt;br /&gt;
 struct RandomAccessIterator : public BidirectionalIterator { ... }; &lt;br /&gt;
== Tipos de iteradotes== &lt;br /&gt;
Los iteradores pueden ser clasificados de varias formas según la característica que se considere. &lt;br /&gt;
=== Iteradores reversibles y no-reversibles=== &lt;br /&gt;
Para distinguirlos de los que sirven para recorrer la secuencia en una sola dirección, no-reversibles, los que permiten recorrerla secuencialmente en ambas direcciones, o mediante acceso aleatorio, se denominan reversibles. &lt;br /&gt;
=== Iteradores constantes y mutables=== &lt;br /&gt;
Otra característica distintiva de los iteradores es si pueden o no utilizarse para modificar los valores de los miembros del contenedor asociado. En este sentido, un iterador constante (const_iterator) es aquel que solo sirve para acceso y no puede usarse para modificaciones; en caso contrario el iterador es mutable.&lt;br /&gt;
 &lt;br /&gt;
Los iteradores salida (OutputIterator) nunca son constantes, y los de entrada (InputIterator) lo son siempre. Otros iteradores pueden ser constantes o no, dependiendo de cómo sean creados. Existen iteradores bidireccionales (BidirectionalIterator) constantes y no-constantes; lo mismo para los de acceso aleatorio (RandomAccessIterator). &lt;br /&gt;
=== Iteradores de flujo=== &lt;br /&gt;
En [[C++|C++]] las entradas/salidas pueden ser realizadas al estilo clásico C, aunque el lenguaje proporciona un nuevo método mediante clases denominadas de forma genérica iostreams que encapsulan las funcionalidad de las Librerías tradicionales C de E/S, es decir, permiten leer y escribir desde/en los flujos de E/S.&lt;br /&gt;
La STL proporciona dos iteradores diseñados especialmente para ser utilizados con los flujos de entrada/salida (en este sentido los flujos actúan a modo de contenedores), lo que permite que los algoritmos de la STL puedan ser utilizados directamente con los flujos de E/S.&lt;br /&gt;
* istream_iterator para leer datos de un flujo de entrada. &lt;br /&gt;
* ostream_iterator para escribir en un flujo de salida. &lt;br /&gt;
== Operatoria y álgebra de iteradotes== &lt;br /&gt;
Lo mismo que los [[Puntero (C++)|punteros]], los iteradores disponen también de un álgebra rudimentaria, de forma que pueden realizarse ciertas operaciones con ellos.  El diseño de la STL garantiza que cada iterador que acepta una operación, lo hace siempre mediante la misma interfaz. &lt;br /&gt;
Los operadores que aceptan la suma y resta unaria ++ y -- mueven respectivamente un iterador de cualquier tipo hasta el elemento siguiente o anterior, dentro del contenedor asociado. Del mismo modo, la aplicación del operador de indirección * sobre cualquier iterador permite acceder al miembro correspondiente. &lt;br /&gt;
Dependiendo del tipo de miembros contenidos en el contenedor, la diferenciación de un iterador *i produce siempre una entidad T que es:&lt;br /&gt;
 a.-  Un objeto (instancia de clase)&lt;br /&gt;
 b.-  Una enumeración &lt;br /&gt;
 c.-  Un tipo fundamental preconstruido en el lenguaje  &lt;br /&gt;
El tipo de T es el tipo-valor del iterador. &lt;br /&gt;
En el primer caso (cuando los miembros del contenedor son instancias de clases), para cada iterador i en el que esté definida la expresión (*i).m para acceder a un miembro m del objeto, puede utilizarse también la sintaxis i-&amp;gt;m con el mismo significado que si se trata de punteros-a-clases.&lt;br /&gt;
Del mismo modo que en los punteros regulares, además de la suma y resta unarias, en los iteradores también pueden estar definidas las operaciones suma y resta con un entero y diferencia (distancia) de dos iteradores. Sean It1 e It2 dos iteradores relativos al mismo contenedor, y n un entero. &lt;br /&gt;
== Valores posibles== &lt;br /&gt;
Los iteradores de cualquier tipo siempre pueden adoptar un valor que señale a una posición después del último elemento de su estructura de datos (algo que puede ocurrir también con los subíndices de matrices); este valor se conoce como valor después del final (&amp;quot;past-the-end&amp;quot;). Estos iteradores no son diferenciables.  Por contra, los que señalan a posiciones dentro de la estructura si lo son. &lt;br /&gt;
Los punteros pueden ser nulos, significando entonces que no señalan nada. También los iteradores pueden no asignar ningún valor específico. En ciertas circunstancias, cuando los iteradores no señalan a ninguna estructura de datos (contenedor), se dice que tienen un valor singular. Los valores deferenciables y los past-the-end no son nunca valor singular. Del mismo modo que es un error diferenciar un puntero nulo, también es un error diferenciar un iterador que no está denotando ningún valor. &lt;br /&gt;
== Accesibilidad y Rango== &lt;br /&gt;
Muchos de los algoritmos de la STL operan sobre un subconjunto de los miembros de un contenedor definido entre dos iteradores a y b; en tal caso, se dice que el par a, b constituyen un rango, y se designa [1] mediante [a, b). El rango [a, a) es el rango nulo. &lt;br /&gt;
Un iterador b se dice que es accesible desde otro iterador a, si y solo si, existe una secuencia finita de operaciones ++a que hagan que a == b; en este instante ambos iteradores referencian al mismo contenedor. &lt;br /&gt;
La utilización de rangos en los algoritmos se ajusta a las siguientes reglas:&lt;br /&gt;
* Si un algoritmo utiliza un rango [a, b) el rango      debe ser válido.  Esto significa que b debe ser accesible desde a [2]. &lt;br /&gt;
* La operación asociada al algoritmo se realiza en      los elementos comprendidos dentro del rango, empezando por el elemento      señalado por a hasta el señalado por b (excluyendo este último). &lt;br /&gt;
Los rangos pueden utilizarse para describir todo el contenido de un contenedor construyendo un iterador para el elemento inicial y otro especial, después del último, para el final (estos iteradores serían proporcionados por los métodos begin y end). Los iteradores también pueden ser utilizados para describir sub-secuencias dentro de un contenedor utilizando dos iteradores a los miembros que definen los límites inferior y superior de la secuencia. &lt;br /&gt;
== Precauciones con los iteradotes== &lt;br /&gt;
Los iteradores son un tipo de punteros a ciertas estructuras de datos (contenedores). Ciertos contenedores ofrecen la capacidad de crecer a medida que se van insertando nuevos elementos. Para minimizar la fragmentación, suelen utilizar un mecanismo que asigna inicialmente espacio para un cierto número de elementos. Cuando este espacio se ha agotado, se asigna un nuevo espacio para doble número de elementos que la primera vez, y un mecanismo automático copia los elementos del espacio original en el nuevo. A continuación el espacio original es desechado.&lt;br /&gt;
Esta maniobra es conocida como recolocación del contenedor (&amp;quot;Reallocation&amp;quot;), y tiene el inconveniente que los punteros (iteradores) a los elementos del contenedor apuntan a direcciones erróneas después de una recolocación. El programador debe ser consciente de ello y no guardar iteradores sino índices.&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
== Puede Consultar ==&lt;br /&gt;
*[[Función (programación)|Función (programación)]]&lt;br /&gt;
*[[Operadores|Operadores]] &lt;br /&gt;
*[[Sentencias (Programación)|Sentencias (Programación)]]&lt;br /&gt;
== Fuente ==&lt;br /&gt;
* [http://msdn.microsoft.com/es-es/library/dscyy5s0%28v=vs.80%29.aspx Iteradores]&lt;br /&gt;
[[Category:Informática]] [[Category:Lenguajes_de_programación]] [[Category:Programación]]&lt;/div&gt;</summary>
		<author><name>Majibacoa2 jc</name></author>
		
	</entry>
</feed>