// public override Object decode(Stream aux) public void decode(ref Clase03Array cOut, String aux) { int v1 = 0; int numEle1 = 0; string v2 = ""; int numEle2 = 0; String[] parametros = aux.Split(','); // Se esperan dos parámetros: un int y un string if (parametros.Length == 4) { v1 = Convert.ToInt16(parametros[0]); numEle1 = Convert.ToInt16(parametros[1]); v2 = parametros[2]; numEle2 = Convert.ToInt16(parametros[3]); } cOut.var1 = new int[numEle1]; for (int i = 0; i < numEle1; i++) { cOut.var1[i] = i; } /* cOut.var2 = new string[numEle2]; for (int i = 0; i < numEle2; i++) { cOut.var2[i] = Convert.ToString(i); } */ }
// public override Object decode(Stream aux) public void decode(ref Clase03Array cOut, String aux) { int v1 = 0; int numEle1 = 0; string v2 = ""; int numEle2 = 0; String[] parametros = aux.Split(','); // Se esperan dos parámetros: un int y un string if (parametros.Length == 4) { v1 = Convert.ToInt16(parametros[0]); numEle1 = Convert.ToInt16(parametros[1]); v2 = parametros[2]; numEle2 = Convert.ToInt16(parametros[3]); } cOut.var1 = new int[numEle1]; for (int i = 0; i < numEle1; i++) { cOut.var1[i] = i; } /* * cOut.var2 = new string[numEle2]; * for (int i = 0; i < numEle2; i++) * { * cOut.var2[i] = Convert.ToString(i); * } */ }
// public override Object decode(Stream aux) public Clase03Array decode(String s) { int v1 = 0; int numEle1 = 0; string v2 = ""; int numEle2 = 0; Clase03Array cOut = new Clase03Array(); String aux = s.ToString(); String[] parametros = aux.Split(','); // Se esperan dos parámetros: un int y un string if (parametros.Length == 4) { v1 = Convert.ToInt16(parametros[0]); numEle1 = Convert.ToInt16(parametros[1]); v2 = parametros[2]; numEle2 = Convert.ToInt16(parametros[3]); } cOut.var1 = new int[numEle1]; for (int i = 0; i < numEle1; i++) { cOut.var1[i] = i; } cOut.var2 = new string[numEle2]; for (int i = 0; i < numEle2; i++) { cOut.var2[i] = Convert.ToString(i); } return(cOut); }
protected Clase03Array decodificarClase03(String s) { Clase03Array cOut = null; watch.Restart(); Decodificador03A dec = new Decodificador03A(); for (int i = 0; i < this.veces; i++) { Object cAuxA = null; cAuxA = dec.decode(s); cOut = (Clase03Array)cAuxA; } watch.Stop(); Console.WriteLine("Decodificación con arrays A: " + watch.ElapsedMilliseconds + " milisegundos"); watch.Restart(); Decodificador03B decB = new Decodificador03B(); for (int i = 0; i < this.veces; i++) { decB.decode(ref cOut, s); } watch.Stop(); Console.WriteLine("Decodificación con arrays B: " + watch.ElapsedMilliseconds + " milisegundos"); watch.Restart(); Type t = typeof(Fase02.Clase03Array); for (int i = 0; i < this.veces; i++) { Object aux = s.decodificar(t); } watch.Stop(); Console.WriteLine("Decodificación con arrays C: " + watch.ElapsedMilliseconds + " milisegundos"); watch.Restart(); for (int i = 0; i < this.veces; i++) { SerializerStatic.decode(ref cOut, s); } watch.Stop(); Console.WriteLine("Decodificación con arrays D: " + watch.ElapsedMilliseconds + " milisegundos"); return(cOut); }
public override String encode(Object aux) { Clase03Array c = (Clase03Array)aux; int ele1 = 0; int numEle1 = 0; String ele2 = ""; int numEle2 = 0; foreach (int elemento in c.var1) { ele1 = elemento; numEle1++; } /* * foreach (String elemento in c.var2) * { * ele2 = elemento; * numEle2++; * } * * foreach (int elemento in c.var3) * { * ele2 = elemento.ToString(); * numEle2++; * } * * foreach (int elemento in c.var4) * { * ele2 = elemento.ToString(); * numEle2++; * } * * foreach (int[] elemento in c.var5) * { * foreach(int elemento2 in elemento) * { * ele2 = elemento2.ToString(); * numEle2++; * } * } */ return(string.Format("{0},{1},{2},{3}", ele1, numEle1, ele2, numEle2)); }
protected String codificarClase03(Clase03Array c) { String sAux = ""; watch.Restart(); Codificador03A codA = new Codificador03A(); for (int i = 0; i < this.veces; i++) { sAux = codA.encode(c); } watch.Stop(); Console.WriteLine("Codificación con arrays A: " + watch.ElapsedMilliseconds + " milisegundos"); watch.Restart(); Codificador03B codB = new Codificador03B(); for (int i = 0; i < this.veces; i++) { sAux = codB.encode(ref c); } watch.Stop(); Console.WriteLine("Codificación con arrays B: " + watch.ElapsedMilliseconds + " milisegundos"); watch.Restart(); for (int i = 0; i < this.veces; i++) { sAux = c.codificar(); } watch.Stop(); Console.WriteLine("Codificación con arrays C: " + watch.ElapsedMilliseconds + " milisegundos"); watch.Restart(); for (int i = 0; i < this.veces; i++) { sAux = SerializerStatic.encode(c); } watch.Stop(); Console.WriteLine("Codificación con arrays D: " + watch.ElapsedMilliseconds + " milisegundos"); return(sAux); }
public String encode(ref Clase03Array c) { int ele1 = 0; int numEle1 = 0; String ele2 = ""; int numEle2 = 0; foreach (int elemento in c.var1) { ele1 = elemento; numEle1++; } /* * foreach (String elemento in c.var2) * { * ele2 = elemento; * numEle2++; * } * * foreach (int elemento in c.var3) * { * numEle2 += elemento; * } * * foreach (int elemento in c.var4) * { * numEle2 += elemento; * } * * foreach (int[] elemento in c.var5) * { * foreach (int elemento2 in elemento) * { * numEle2 += elemento2; * } * } */ return(string.Format("{0},{1},{2},{3}", ele1, numEle1, ele2, numEle2)); }
public String encode(ref Clase03Array c) { int ele1 = 0; int numEle1 = 0; String ele2 = ""; int numEle2 = 0; foreach (int elemento in c.var1) { ele1 = elemento; numEle1++; } /* foreach (String elemento in c.var2) { ele2 = elemento; numEle2++; } foreach (int elemento in c.var3) { numEle2 += elemento; } foreach (int elemento in c.var4) { numEle2 += elemento; } foreach (int[] elemento in c.var5) { foreach (int elemento2 in elemento) { numEle2 += elemento2; } } */ return string.Format("{0},{1},{2},{3}", ele1, numEle1, ele2, numEle2); }
static void Main(string[] args) { string str = ""; #region ClasePrueba+ClaseB /* Fase02.ClasePrueba c = new Fase02.ClasePrueba(); Generador gPrueba = new Generador(c.GetType()); var serializadorPrueba = gPrueba.getSerializer(); if (serializadorPrueba != null) { string codigo = serializadorPrueba.codificar(c); Console.WriteLine(codigo); Fase02.ClasePrueba aux = new Fase02.ClasePrueba(); aux.var1 = 0; serializadorPrueba.decodificar(codigo, ref aux); Console.WriteLine(aux.var1 + "," + aux.var2.varB1 + "," + aux.var3); } else { Console.WriteLine("No se ha podido generar el serializador"); } */ #endregion #region Clase03Array /* Fase02.Clase03Array c3 = new Clase03Array(); Generador g3 = new Generador(c3.GetType()); dynamic serializador3 = g3.getSerializer(); if (serializador3 != null) { c3.var1 = new int[3]; for (int i = 0; i < 3; i++) { c3.var1[i] = i; } c3.var2 = new string[3]; for (int i = 0; i < 3; i++) { c3.var2[i] = i.ToString(); } c3.var4 = new int[3, 2, 2]; for (int i = 0; i < 3; i++) { for (int j = 0; j < 2; j++) { for (int k = 0; k < 2; k++) { c3.var4[i, j, k] = i * (j + 3) + (k * 3); } } } c3.var6 = new Dictionary<string, int>(); c3.var6.Add("cuatro", 4); c3.var6.Add("cinco", 5); c3.var6.Add("seis", 6); string codigo = serializador3.codificar(c3); Console.WriteLine(codigo); Fase02.Clase03Array c3aux = new Clase03Array(); serializador3.decodificar(codigo, ref c3aux); for (int i = 0; i < 3; i++) { Console.Write(c3aux.var1[i]); } Console.WriteLine(""); if(c3aux.var2 == null) { Console.Write("¡var2 no se ha serializado!"); } else { for (int i = 0; i < 3; i++) { Console.Write(c3aux.var2[i]); } } Console.WriteLine(""); for (int i = 0; i < 3; i++) { for (int j = 0; j < 2; j++) { for (int k = 0; k < 2; k++) { Console.Write(c3aux.var4[i, j, k]); } } } foreach(KeyValuePair<string, int> aux in c3aux.var6) { Console.WriteLine(aux.Key + " = " + aux.Value); } */ #endregion /* foreach (Fase02.ClaseViti i in c3aux.var4) { Console.WriteLine(i.v1.ToString() + "," + i.v2.ToString()); } foreach (KeyValuePair<int, string> i in c3aux.var5) { Console.WriteLine(i.Key.ToString() + "," + i.Value.ToString()); } } */ #region Clase01Basica /* Fase02.Clase01Basica c1 = new Clase01Basica(); c1.var1 = 2; c1.var2 = "Hola"; Generador g1 = new Generador(c1.GetType()); dynamic serializador1 = g1.getSerializer(); if (serializador1 != null) { Type tipo1 = serializador1.GetType(); Console.WriteLine(tipo1.FullName); string codigo = serializador1.codificar(c1); Console.WriteLine(codigo); c1 = new Fase02.Clase01Basica(); c1 = serializador1.decodificar(codigo, ref c1); Console.WriteLine(c1.var1); Console.WriteLine(c1.var2); } else { Console.WriteLine("No se ha podido generar el serializador"); } */ #endregion Fase02.Clase03Array c3a = new Clase03Array(); Generador g3a = new Generador(c3a.GetType()); dynamic serializador3a = g3a.getSerializer(); if (serializador3a != null) { #region Datos Clase03Array c3a.var1 = new int[3]; for (int i = 0; i < 3; i++) { c3a.var1[i] = i; } c3a.var2 = new string[3]; for (int i = 0; i < 3; i++) { c3a.var2[i] = "Número " + Convert.ToString(i); } c3a.var3 = new int[1, 2]; int cont = 0; for (int i = 0; i < 1; i++) { for (int j = 0; j < 2; j++) { c3a.var3[i, j] = cont; cont++; } } c3a.var4 = new int[1, 2, 3]; cont = 0; for (int i = 0; i < 1; i++) { for (int j = 0; j < 2; j++) { for (int k = 0; k < 3; k++) { c3a.var4[i, j, k] = cont; cont++; } } } c3a.var5 = new int[3][]; cont = 0; for (int i = 0; i < 3; i++) { int[] aux = new int[4]; for (int j = 0; j < 4; j++) { aux[j] = cont; cont++; } c3a.var5[i] = aux; } c3a.var6 = new Dictionary<string, int>(); c3a.var6.Add("uno", 1); c3a.var6.Add("dos", 2); c3a.var6.Add("tres", 3); #endregion string codigo = serializador3a.codificar(c3a); Console.WriteLine(codigo); Clase03Array aux3a = new Clase03Array(); Fase02.DentroDelArray auxDentro = new DentroDelArray(); auxDentro.uno = 1; auxDentro.dos = "dos"; Fase02.DentroDelArray auxDentro2 = new DentroDelArray(); auxDentro2.uno = 3; auxDentro2.dos = "cuatro"; aux3a.var7 = new DentroDelArray[2]; aux3a.var7[0] = auxDentro; aux3a.var7[1] = auxDentro2; serializador3a.decodificar(codigo, ref aux3a); for (int i = 0; i < 3; i++) { Console.Write(c3a.var1[i] + ","); } Console.WriteLine(); /* for (int i = 0; i < 3; i++) { Console.Write(c3a.var2[i] + ","); } Console.WriteLine(); */ for (int i = 0; i < 1; i++) { for (int j = 0; j < 2; j++) { Console.Write(c3a.var3[i, j] + ","); } } Console.WriteLine(); for (int i = 0; i < 1; i++) { for (int j = 0; j < 2; j++) { for (int k = 0; k < 3; k++) { Console.Write(c3a.var4[i, j, k]); } } } Console.WriteLine(); /* for (int i = 0; i < 3; i++) { int[] aux = new int[4]; for (int j = 0; j < 4; j++) { Console.Write(aux[j] + ","); } c3a.var5[i] = aux; Console.WriteLine(); } Console.WriteLine(); */ foreach(KeyValuePair<string, int> par in c3a.var6) { Console.WriteLine(par.Key + "=>" + par.Value); } } else { Console.WriteLine("No se ha podido generar el serializador"); } /* Fase02.Clase07ClaseConTodo c7 = new Clase07ClaseConTodo(); Generador g7 = new Generador(c7.GetType()); dynamic serializador7 = g7.getSerializer(); if (serializador7 != null) { Type tipo7 = serializador7.GetType(); Console.WriteLine(tipo7.FullName); Console.Write(serializador7.codificar(c7)); // serializador7.encode(c7, ref str); } else { Console.WriteLine("No se ha podido generar el serializador"); } */ Console.ReadKey(); }
static void Main(string[] args) { string str = ""; Fase02.Clase01Basica c1 = new Clase01Basica(); // c1.var1 = 2; // c1.var2 = "Hola"; Fase02.Clase03Array c3 = new Clase03Array(); c3.var1 = new int[1]; for (int i = 0; i < 1; i++) { c3.var1[i] = i; } c3.var2 = new string[3]; for (int i = 0; i < 3; i++) { c3.var2[i] = "Número " + Convert.ToString(i); } /* c3.var3 = new int[1,2]; int cont = 0; for (int i = 0; i < 1; i++) { for (int j = 0; j < 2; j++) { c3.var3[i, j] = cont; cont++; } } c3.var4 = new int[1, 2, 3]; cont = 0; for (int i = 0; i < 1; i++) { for (int j = 0; j < 2; j++) { for (int k = 0; k < 3; k++) { c3.var4[i, j, k] = cont; cont++; } } } c3.var5 = new int[3][]; cont = 0; for (int i = 0; i < 3; i++) { int[] aux = new int[4]; for (int j = 0; j < 4; j++) { aux[j] = cont; cont++; } c3.var5[i] = aux; } */ Fase02.Clase04Struct c4 = new Clase04Struct(); c4.valor3.valor1 = 1; c4.valor3.valor2 = "hola"; Fase02.Clase06ClaseDerivada c6 = new Clase06ClaseDerivada(); c6.var1 = 1; c6.var2 = "hola"; c6.var3 = 2; /* Generador g1 = new Generador(c1.GetType()); dynamic serializador1 = g1.getSerializer(); if (serializador1 != null) { Type tipo = serializador1.GetType(); Console.WriteLine(tipo.FullName); serializador1.encode(c1, ref str); c1 = new Clase01Basica(); c1 = serializador1.decode(str, c1); Console.WriteLine("Variables normales:"); Console.WriteLine(c1.var1); Console.WriteLine(c1.var2); } else { Console.WriteLine("No se ha podido generar el serializador"); } Generador g6 = new Generador(c6.GetType()); dynamic serializador6 = g6.getSerializer(); if (serializador6 != null) { Type tipo6 = serializador6.GetType(); Console.WriteLine(tipo6.FullName); serializador6.encode(c6, ref str); c6 = new Clase06ClaseDerivada(); c6 = serializador6.decode(str, c6); Console.WriteLine("Variables heredadas:"); Console.WriteLine(c6.var1); Console.WriteLine(c6.var2); Console.WriteLine(c6.var3); } else { Console.WriteLine("No se ha podido generar el serializador"); } Generador g3 = new Generador(c3.GetType()); dynamic serializador3 = g3.getSerializer(); if (serializador3 != null) { Type tipo3 = serializador3.GetType(); Console.WriteLine(tipo3.FullName); serializador3.encode(c3, ref str); c3 = new Clase03Array(); c3 = serializador3.decode(str, c3); Console.WriteLine("Array var1:"); for (int i = 0; i < c3.var1.Length; i++) { Console.WriteLine(c3.var1[i]); } Console.WriteLine("Array var2:"); for (int i = 0; i < c3.var2.Length; i++) { Console.WriteLine(c3.var2[i]); } Console.WriteLine("Array var3:"); for (int i = 0; i < 1; i++) { for(int j = 0; j < 2; j++) { Console.Write(c3.var3[i, j]); } Console.WriteLine(); } Console.WriteLine("Array var4:"); for (int i = 0; i < 1; i++) { for (int j = 0; j < 2; j++) { for (int k = 0; k < 3; k++) { Console.WriteLine(c3.var4[i,j,k]); } Console.WriteLine(); } Console.WriteLine(); } Console.WriteLine("Array var5:"); for (int i = 0; i < 3; i++) { Console.WriteLine("Array del elemento " + i); for (int j = 0; j < 4; j++ ) { Console.WriteLine(c3.var5[i][j]); } Console.WriteLine(); } } else { Console.WriteLine("No se ha podido generar el serializador"); } */ Generador g4 = new Generador(c4.GetType()); dynamic serializador4 = g4.getSerializer(); if (serializador4 != null) { Type tipo4 = serializador4.GetType(); Console.WriteLine(tipo4.FullName); serializador4.encode(c4, ref str); c4 = new Clase04Struct(); c4 = serializador4.decode(str, c4); Console.WriteLine("Clase con estructura+:"); Console.WriteLine(c4.valor3.valor1); Console.WriteLine(c4.valor3.valor2); } else { Console.WriteLine("No se ha podido generar el serializador"); } Console.ReadKey(); }
static void Main(string[] args) { Program p = new Program(); p.watch = new System.Diagnostics.Stopwatch(); /* * 01. Clase básica */ Clase01Basica c1 = new Clase01Basica(); Clase01Basica c1decoded; /* * c1.var1 = 1; * c1.var2 = "2"; */ Console.WriteLine("Clase con dos atributos"); s = p.codificarClase01(c1); c1decoded = p.decodificarClase01(s); Console.WriteLine("=================="); /* * 02. Clase con arrays */ Clase02ArrayNormal c2 = new Clase02ArrayNormal(); Clase02ArrayNormal c2decoded; Console.WriteLine("Clase con arrays"); s = p.codificarClase02(c2); c2decoded = p.decodificarClase02(s); Console.WriteLine("=================="); /* * 03. Clase con arrays */ Clase03Array c3 = new Clase03Array(); Clase03Array c3decoded; c3.var1 = new int[1]; for (int i = 0; i < 1; i++) { c3.var1[i] = i; } c3.var2 = new string[2]; for (int i = 0; i < 2; i++) { c3.var2[i] = Convert.ToString(i); } /* * c3.var3 = new int[3, 4]; * for (int i = 0; i < 3; i++) * { * for (int j = 0; j < 4; j++) * { * c3.var3[i,j] = i+j; * } * } * * c3.var4 = new int[4, 5, 6]; * for (int i = 0; i < 4; i++) * { * for (int j = 0; j < 5; j++) * { * for (int k = 0; k < 6; k++) * { * c3.var4[i, j, k] = i + j + k; * } * } * } * * c3.var5 = new int[4][]; * for (int i = 0; i < 4; i++) * { * int[] aux = new int[5]; * for (int j = 0; j < 5; j++) * { * aux[j] = j; * } * c3.var5[i] = aux; * } */ Console.WriteLine("Clase con cinco arrays"); s = p.codificarClase03(c3); c3decoded = (Clase03Array)p.decodificarClase03(s); Console.WriteLine("=================="); /* * 04. Clase con una estructura */ Clase04Struct c4 = new Clase04Struct(); c4.valor3 = new Clase04Struct.estructura(1, "2"); Clase04Struct c4decoded; Console.WriteLine("Clase con un atributo Struct"); s = p.codificarClase04(c4); c4decoded = p.decodificarClase04(s); Console.WriteLine("=================="); /* * 05. Clase con una clase */ Clase05Clase c5 = new Clase05Clase(); Clase05Clase.ClaseInterna c5int = new Clase05Clase.ClaseInterna(); c5int.var1 = 1; c5int.var2 = "2"; c5.var3 = c5int; Clase05Clase c5decoded; s = p.codificarClase05(c5); c5decoded = p.decodificarClase05(s); Console.WriteLine("=================="); /* * 06. Clase con una clase derivada */ Clase06ClaseDerivada c6 = new Clase06ClaseDerivada(); c6.var1 = 1; c6.var2 = "2"; c6.var3 = 3; Clase06ClaseDerivada c6decoded; s = p.codificarClase06(c6); c6decoded = p.decodificarClase06(s); Console.WriteLine("=================="); /* * 07. Clase con todo */ Clase07ClaseConTodo c7 = new Clase07ClaseConTodo(); c7.basePublicInt = 1; c7.lista = new List <int>(); c7.lista.Add(1); c7.lista.Add(2); c7.publicArray2DInt = new int[1, 2]; c7.publicArray2DInt[0, 0] = 1; c7.publicArray2DInt[0, 1] = 1; c7.publicArrayInt = new int[3]; c7.publicArrayInt[0] = 1; c7.publicArrayInt[1] = 2; c7.publicArrayInt[2] = 3; c7.publicArrayMatrizEscalonadaInt = new int[2][]; int[] arrayAaux = new int[3]; arrayAaux[0] = 1; arrayAaux[1] = 2; arrayAaux[2] = 3; c7.publicArrayMatrizEscalonadaInt[0] = arrayAaux; c7.publicArrayMatrizEscalonadaInt[1] = arrayAaux; c7.publicInt = 30; Clase07ClaseConTodo c7decoded; Console.WriteLine("Clase con todo"); s = p.codificarClase07(c7); c7decoded = p.decodificarClase07(s); Console.WriteLine("=================="); /* * 01. Struct básica * Struct01Basica s1 = new Struct01Basica(); * s1.var1 = 1; * s1.var2 = "2"; * * p.codificarStruct01(s1); * Object c1decodedAux_ = p.decodificarStruct01(1, "2"); * * p.watch.Restart(); * Struct01Basica c1decoded_ = (Struct01Basica)c1decodedAux_; * p.watch.Stop(); * Console.WriteLine("Tiempo de conversión de objeto: " + p.watch.ElapsedMilliseconds + " milisegundos"); */ Console.ReadLine(); }
public string benchmarkClase03Arrays() { string linea1 = ""; string linea2 = ""; /* * 03. Clase con arrays */ linea1 += "Clase03Arrays (Encode);"; linea2 += "Clase03Arrays (Decode);"; Console.WriteLine("============== Clase con distintos tipos de array (Clase03Array) ==============\r\n"); // Instanciando y rellenando campos Clase03Array c = new Clase03Array(); Clase03Array decoded; #region Datos Clase03Array c.var1 = new int[3]; for (int i = 0; i < 3; i++) { c.var1[i] = i; } c.var2 = new string[3]; for (int i = 0; i < 3; i++) { c.var2[i] = "Número " + Convert.ToString(i); } c.var3 = new int[1, 2]; int cont = 0; for (int i = 0; i < 1; i++) { for (int j = 0; j < 2; j++) { c.var3[i, j] = cont; cont++; } } c.var4 = new int[1, 2, 3]; cont = 0; for (int i = 0; i < 1; i++) { for (int j = 0; j < 2; j++) { for (int k = 0; k < 3; k++) { c.var4[i, j, k] = cont; cont++; } } } c.var5 = new int[3][]; cont = 0; for (int i = 0; i < 3; i++) { int[] aux = new int[4]; for (int j = 0; j < 4; j++) { aux[j] = cont; cont++; } c.var5[i] = aux; } c.var6 = new Dictionary<string, int>(); c.var6.Add("uno", 1); c.var6.Add("dos", 2); c.var6.Add("tres", 3); c.var7 = new DentroDelArray[2]; DentroDelArray aux1 = new DentroDelArray(); aux1.uno = 1; aux1.dos = "dos"; c.var7[0] = aux1; DentroDelArray aux2 = new DentroDelArray(); aux2.uno = 1; aux2.dos = "dos"; c.var7[1] = aux2; #endregion // - XMLSerializer #region XMLSerializer FileStream fs; linea1 += ";"; linea2 += ";"; /* *** Este serializador no admite arrays complejos XmlSerializer serializer = new XmlSerializer(typeof(Clase03Array)); TextWriter writer = new StreamWriter("fichero.txt"); watch.Restart(); // Comienza a contar el tiempo for (int i = 0; i < veces; i++) { serializer.Serialize(writer, c); } watch.Stop(); writer.Close(); // Generamos el fichero de nuevo, con una única serialización writer = new StreamWriter("fichero.txt"); serializer.Serialize(writer, c); writer.Close(); Console.WriteLine("Codificación Clase01Basica con XMLSerializer: " + watch.ElapsedMilliseconds + " milisegundos"); linea1 += watch.ElapsedMilliseconds + ";"; watch.Restart(); // Comienza a contar el tiempo for (int i = 0; i < veces; i++) { fs = new FileStream("fichero.txt", FileMode.Open); decoded = (Clase03Array)serializer.Deserialize(fs); fs.Close(); } watch.Stop(); Console.WriteLine("Decodificación Clase01Basica con XMLSerializer: " + watch.ElapsedMilliseconds + " milisegundos"); linea2 += watch.ElapsedMilliseconds + ";"; */ #endregion // - BinaryFormatter #region BinaryFormatter Console.WriteLine("Serialización con BinaryFormatter"); // Construct a BinaryFormatter and use it to serialize the data to the stream. BinaryFormatter formatter = new BinaryFormatter(); try { long tiempoTotal = 0; for (int i = 0; i < veces; i++) { fs = new FileStream("BinaryFormatter.dat", FileMode.Create); watch.Restart(); // Comienza a contar el tiempo formatter.Serialize(fs, c); watch.Stop(); tiempoTotal += watch.ElapsedMilliseconds; fs.Close(); } watch.Stop(); Console.WriteLine("Codificación Clase01Basica con BinaryFormatter: " + tiempoTotal + " milisegundos"); linea1 += tiempoTotal + ";"; } catch (SerializationException e) { Console.WriteLine("Failed to serialize. Reason: " + e.Message); throw; } fs = new FileStream("BinaryFormatter.dat", FileMode.Open); try { watch.Restart(); // Comienza a contar el tiempo for (int i = 0; i < veces; i++) { decoded = (Clase03Array)formatter.Deserialize(fs); fs.Close(); fs = new FileStream("BinaryFormatter.dat", FileMode.Open); } watch.Stop(); fs.Close(); Console.WriteLine("Decodificación Clase01Basica con BinaryFormatter: " + watch.ElapsedMilliseconds + " milisegundos"); linea2 += watch.ElapsedMilliseconds + ";"; } catch (SerializationException e) { Console.WriteLine("Failed to deserialize. Reason: " + e.Message); throw; } finally { fs.Close(); } #endregion // - SOAPFormatter #region SOAPFormatter linea1 += ";"; linea2 += ";"; /* Console.WriteLine("Serialización con SOAPFormatter"); FileStream fs3 = new FileStream("DataFile.soap", FileMode.Create); fs3.Close(); SoapFormatter soapFormatter = new SoapFormatter(); try { long tiempoTotal = 0; for (int i = 0; i < veces; i++) { fs3 = new FileStream("DataFile.soap", FileMode.Create); watch.Restart(); // Comienza a contar el tiempo soapFormatter.Serialize(fs3, c); watch.Stop(); tiempoTotal += watch.ElapsedMilliseconds; fs3.Close(); } Console.WriteLine("Codificación Clase01Basica con SOAPFormatter: " + tiempoTotal + " milisegundos"); linea1 += tiempoTotal + ";"; } catch (SerializationException e) { Console.WriteLine("Failed to serialize. Reason: " + e.Message); throw; } fs3 = new FileStream("DataFile.soap", FileMode.Open); try { watch.Restart(); // Comienza a contar el tiempo for (int i = 0; i < veces; i++) { decoded = (Clase03Array)soapFormatter.Deserialize(fs3); fs3.Close(); fs3 = new FileStream("DataFile.soap", FileMode.Open); } watch.Stop(); Console.WriteLine("Decodificación Clase01Basica con SOAPFormatter: " + watch.ElapsedMilliseconds + " milisegundos"); linea2 += watch.ElapsedMilliseconds + ";"; } catch (SerializationException e) { Console.WriteLine("Failed to deserialize. Reason: " + e.Message); throw; } finally { fs3.Close(); } */ #endregion // DataContractSerializer #region DataContractSerializer MemoryStream stream1 = new MemoryStream(); MemoryStream stream2 = new MemoryStream(); linea1 += ";"; linea2 += ";"; /* Console.WriteLine("Serialización con DataContractSerializer"); //Serialize the Record object to a memory stream using DataContractSerializer. DataContractSerializer DCserializer = new DataContractSerializer(typeof(Clase03Array)); for (int i = 0; i < veces; i++) { watch.Restart(); // Comienza a contar el tiempo DCserializer.WriteObject(stream1, c); watch.Stop(); if (i == 0) { stream1.Position = 0; stream1.CopyTo(stream2, (int)stream1.Length); } } Console.WriteLine("Codificación Clase01Basica con DataContractSerializer: " + watch.ElapsedMilliseconds + " milisegundos"); linea1 += watch.ElapsedMilliseconds + ";"; watch.Restart(); // Comienza a contar el tiempo for (int i = 0; i < veces; i++) { stream2.Position = 0; //Deserialize the Record object back into a new record object. decoded = (Clase03Array)DCserializer.ReadObject(stream2); } watch.Stop(); Console.WriteLine("Decodificación Clase01Basica con DataContractSerializer: " + watch.ElapsedMilliseconds + " milisegundos"); linea2 += watch.ElapsedMilliseconds + ";"; */ #endregion DataContractSerializer // SharpSerializer (XML) #region SharpSerializer Console.WriteLine("Serialización con SharpSerializer (XML)"); var SharpSerializer = new SharpSerializer(); watch.Restart(); // Comienza a contar el tiempo for (int i = 0; i < veces; i++) { SharpSerializer.Serialize(c, "SharpSerializer.xml"); } watch.Stop(); Console.WriteLine("Codificación Clase01Basica con SharpSerializer (XML): " + watch.ElapsedMilliseconds + " milisegundos"); linea1 += watch.ElapsedMilliseconds + ";"; watch.Restart(); // Comienza a contar el tiempo for (int i = 0; i < veces; i++) { decoded = (Clase03Array)SharpSerializer.Deserialize("SharpSerializer.xml"); } watch.Stop(); Console.WriteLine("Decodificación Clase01Basica con SharpSerializer (XML): " + watch.ElapsedMilliseconds + " milisegundos"); linea2 += watch.ElapsedMilliseconds + ";"; #endregion SharpSerializer // SharpSerializer (Binario) #region SharpSerializer Console.WriteLine("Serialización con SharpSerializer (Binario)"); var SharpSerializer2 = new SharpSerializer(true); watch.Restart(); // Comienza a contar el tiempo for (int i = 0; i < veces; i++) { SharpSerializer2.Serialize(c, "SharpSerializer.dat"); } watch.Stop(); Console.WriteLine("Codificación Clase01Basica con SharpSerializer (Binario): " + watch.ElapsedMilliseconds + " milisegundos"); linea1 += watch.ElapsedMilliseconds + ";"; watch.Restart(); // Comienza a contar el tiempo for (int i = 0; i < veces; i++) { decoded = (Clase03Array)SharpSerializer2.Deserialize("SharpSerializer.dat"); } watch.Stop(); Console.WriteLine("Decodificación Clase01Basica con SharpSerializer (Binario): " + watch.ElapsedMilliseconds + " milisegundos"); linea2 += watch.ElapsedMilliseconds + ";"; #endregion SharpSerializer // Protobuf #region Protobuf linea1 += ";"; linea2 += ";"; /* Console.WriteLine("Serialización con Protobuf"); Stream protoStream = new MemoryStream(); Stream protoStream2 = new MemoryStream(); watch.Restart(); // Comienza a contar el tiempo for (int i = 0; i < veces; i++) { ProtoBuf.Serializer.Serialize(protoStream, c); if (i == 0) { protoStream2.Position = 0; stream1.CopyTo(protoStream2, (int)protoStream.Length); } } watch.Stop(); Console.WriteLine("Codificación Clase01Basica con Protobuf: " + watch.ElapsedMilliseconds + " milisegundos"); linea1 += watch.ElapsedMilliseconds + ";"; watch.Restart(); // Comienza a contar el tiempo for (int i = 0; i < veces; i++) { protoStream.Position = 0; decoded = ProtoBuf.Serializer.Deserialize<Clase03Array>(protoStream2); } watch.Stop(); Console.WriteLine("Decodificación Clase01Basica con Protobuf: " + watch.ElapsedMilliseconds + " milisegundos"); linea2 += watch.ElapsedMilliseconds + ";"; */ #endregion Protobuf // - Nuestro proyecto en CSV #region NuestroProyecto(CSV) Console.WriteLine("Serialización con nuestro proyecto (CSV)"); // Generando el serializador a partir del tipo Fase06.Generador g1 = new Fase06.Generador(c.GetType()); dynamic serializador1 = g1.getSerializer(); string str = ""; if (serializador1 != null) { watch.Restart(); // Comienza a contar el tiempo for (int i = 0; i < veces; i++) { str = serializador1.codificar(c); // strSerializado = Clase01BasicaCodec.codificar(c1); } watch.Stop(); Console.WriteLine("Codificación Clase01Basica con nuestro proyecto (CSV): " + watch.ElapsedMilliseconds + " milisegundos"); linea1 += watch.ElapsedMilliseconds + ";"; decoded = new Clase03Array(); watch.Restart(); // Comienza a contar el tiempo for (int i = 0; i < veces; i++) { serializador1.decodificar(str, ref decoded); } watch.Stop(); Console.WriteLine("Decodificación Clase01Basica con nuestro proyecto (CSV): " + watch.ElapsedMilliseconds + " milisegundos"); linea2 += watch.ElapsedMilliseconds + ";"; } else { Console.WriteLine("Error generando el serializador"); } #endregion NuestroProyecto(CSV) // - Nuestro proyecto en XML #region NuestroProyecto(XML) Console.WriteLine("Serialización con nuestro proyecto en XML"); // Generando el serializador a partir del tipo g1 = new Fase06.Generador(c.GetType(), "XML"); serializador1 = g1.getSerializer(); if (serializador1 != null) { watch.Restart(); // Comienza a contar el tiempo for (int i = 0; i < veces; i++) { str = serializador1.codificar(c); } watch.Stop(); Console.WriteLine("Codificación Clase01Basica con nuestro proyecto (XML): " + watch.ElapsedMilliseconds + " milisegundos"); linea1 += watch.ElapsedMilliseconds + ";"; decoded = new Clase03Array(); watch.Restart(); // Comienza a contar el tiempo for (int i = 0; i < veces; i++) { serializador1.decodificar(str, ref decoded); } watch.Stop(); Console.WriteLine("Decodificación Clase01Basica con nuestro proyecto (XML): " + watch.ElapsedMilliseconds + " milisegundos"); linea2 += watch.ElapsedMilliseconds + ";"; } else { Console.WriteLine("Error generando el serializador"); } return linea1 + "\r\n" + linea2; #endregion NuestroProyecto(XML) }
protected String codificarClase03(Clase03Array c) { String sAux = ""; watch.Restart(); Codificador03A codA = new Codificador03A(); for (int i = 0; i < this.veces; i++) { sAux = codA.encode(c); } watch.Stop(); Console.WriteLine("Codificación con arrays A: " + watch.ElapsedMilliseconds + " milisegundos"); watch.Restart(); Codificador03B codB = new Codificador03B(); for (int i = 0; i < this.veces; i++) { sAux = codB.encode(ref c); } watch.Stop(); Console.WriteLine("Codificación con arrays B: " + watch.ElapsedMilliseconds + " milisegundos"); watch.Restart(); for (int i = 0; i < this.veces; i++) { sAux = c.codificar(); } watch.Stop(); Console.WriteLine("Codificación con arrays C: " + watch.ElapsedMilliseconds + " milisegundos"); watch.Restart(); for (int i = 0; i < this.veces; i++) { sAux = SerializerStatic.encode(c); } watch.Stop(); Console.WriteLine("Codificación con arrays D: " + watch.ElapsedMilliseconds + " milisegundos"); return sAux; }
static void Main(string[] args) { Program p = new Program(); p.watch = new System.Diagnostics.Stopwatch(); /* * 01. Clase básica */ Clase01Basica c1 = new Clase01Basica(); Clase01Basica c1decoded; /* c1.var1 = 1; c1.var2 = "2"; */ Console.WriteLine("Clase con dos atributos"); s = p.codificarClase01(c1); c1decoded = p.decodificarClase01(s); Console.WriteLine("=================="); /* * 02. Clase con arrays */ Clase02ArrayNormal c2 = new Clase02ArrayNormal(); Clase02ArrayNormal c2decoded; Console.WriteLine("Clase con arrays"); s = p.codificarClase02(c2); c2decoded = p.decodificarClase02(s); Console.WriteLine("=================="); /* * 03. Clase con arrays */ Clase03Array c3 = new Clase03Array(); Clase03Array c3decoded; c3.var1 = new int[1]; for (int i = 0; i < 1; i++) { c3.var1[i] = i; } c3.var2 = new string[2]; for (int i = 0; i < 2; i++) { c3.var2[i] = Convert.ToString(i); } /* c3.var3 = new int[3, 4]; for (int i = 0; i < 3; i++) { for (int j = 0; j < 4; j++) { c3.var3[i,j] = i+j; } } c3.var4 = new int[4, 5, 6]; for (int i = 0; i < 4; i++) { for (int j = 0; j < 5; j++) { for (int k = 0; k < 6; k++) { c3.var4[i, j, k] = i + j + k; } } } c3.var5 = new int[4][]; for (int i = 0; i < 4; i++) { int[] aux = new int[5]; for (int j = 0; j < 5; j++) { aux[j] = j; } c3.var5[i] = aux; } */ Console.WriteLine("Clase con cinco arrays"); s = p.codificarClase03(c3); c3decoded = (Clase03Array)p.decodificarClase03(s); Console.WriteLine("=================="); /* * 04. Clase con una estructura */ Clase04Struct c4 = new Clase04Struct(); c4.valor3 = new Clase04Struct.estructura(1, "2"); Clase04Struct c4decoded; Console.WriteLine("Clase con un atributo Struct"); s = p.codificarClase04(c4); c4decoded = p.decodificarClase04(s); Console.WriteLine("=================="); /* * 05. Clase con una clase */ Clase05Clase c5 = new Clase05Clase(); Clase05Clase.ClaseInterna c5int = new Clase05Clase.ClaseInterna(); c5int.var1 = 1; c5int.var2 = "2"; c5.var3 = c5int; Clase05Clase c5decoded; s = p.codificarClase05(c5); c5decoded = p.decodificarClase05(s); Console.WriteLine("=================="); /* * 06. Clase con una clase derivada */ Clase06ClaseDerivada c6 = new Clase06ClaseDerivada(); c6.var1 = 1; c6.var2 = "2"; c6.var3 = 3; Clase06ClaseDerivada c6decoded; s = p.codificarClase06(c6); c6decoded = p.decodificarClase06(s); Console.WriteLine("=================="); /* * 07. Clase con todo */ Clase07ClaseConTodo c7 = new Clase07ClaseConTodo(); c7.basePublicInt = 1; c7.lista = new List<int>(); c7.lista.Add(1); c7.lista.Add(2); c7.publicArray2DInt = new int[1,2]; c7.publicArray2DInt[0,0] = 1; c7.publicArray2DInt[0,1] = 1; c7.publicArrayInt = new int[3]; c7.publicArrayInt[0] = 1; c7.publicArrayInt[1] = 2; c7.publicArrayInt[2] = 3; c7.publicArrayMatrizEscalonadaInt = new int[2][]; int[] arrayAaux = new int[3]; arrayAaux[0] = 1; arrayAaux[1] = 2; arrayAaux[2] = 3; c7.publicArrayMatrizEscalonadaInt[0] = arrayAaux; c7.publicArrayMatrizEscalonadaInt[1] = arrayAaux; c7.publicInt = 30; Clase07ClaseConTodo c7decoded; Console.WriteLine("Clase con todo"); s = p.codificarClase07(c7); c7decoded = p.decodificarClase07(s); Console.WriteLine("=================="); /* * 01. Struct básica Struct01Basica s1 = new Struct01Basica(); s1.var1 = 1; s1.var2 = "2"; p.codificarStruct01(s1); Object c1decodedAux_ = p.decodificarStruct01(1, "2"); p.watch.Restart(); Struct01Basica c1decoded_ = (Struct01Basica)c1decodedAux_; p.watch.Stop(); Console.WriteLine("Tiempo de conversión de objeto: " + p.watch.ElapsedMilliseconds + " milisegundos"); */ Console.ReadLine(); }