Indexadores en C#

Iniciado por DanielPy, 27 Agosto 2013, 22:50 PM

0 Miembros y 1 Visitante están viendo este tema.

DanielPy

Hola a todos.
En este caso les consulto 2 cosas.-
1):¿Me podrían decir si el uso de Indexadores es correcta?.-
2):¿Que estoy haciendo mal que el array no me queda ordenado.-?

Código (csharp) [Seleccionar]
using System;

namespace IndexadoresArray
{
    class ProgramaApp
    {
        static void Main(string[] argumentos)
        {
            Entorno _Entorno = new Entorno();
            _Entorno._entorno();
           
            Datos _datos = new Datos();
            _datos._Datos();

            Console.Write("\n\n Pulse una tecla para cerrar la aplicación...");
            Console.ReadLine();
        }
    }
}


Código (csharp) [Seleccionar]
using System;

namespace IndexadoresArray
{
    class Datos
    {
        private int[] numeros =  new int[10];

        public int this[byte indice]
        {
            get { return numeros[indice]; }
            set { numeros[indice] = value; }
        }
       
        public void _Datos()
        {
            Datos obj = new Datos();
            byte _top = 2,hasElMom = 1;
            int aux = 0;
            Console.SetCursorPosition(02, _top);
            Console.Write("Ingrese 10 entero(máximo 99999)");
            _top += 2;
            Console.SetCursorPosition(02, _top);
            Console.Write("Natutal   Ordenados");
            _top += 2;
            for (byte i = 0; i < 10; i++)
            {
                while (true)
                {
                    Console.SetCursorPosition(02, _top);
                    Console.Write("");
                    if ((int.TryParse(Console.ReadLine(), out aux)) && aux < 100000)
                    {
                        obj[i] = aux;
                        break;
                    }
                }
                Array.Sort(numeros);
                byte _topOrd = 6;
                for (byte f = 0; f < hasElMom; f++)
                {
                    Console.SetCursorPosition(12, _topOrd);
                    Console.Write("{0}", obj[f]);
                    _topOrd++;
                }
                _top++;
                hasElMom++;
            }
        }
    }
}


Bueno espero aflojar un poco, tengo miedo de cansarlos.-
Saludos.
Daniel

PD. Por unas horas voy a estar un poco ocupado en otra cosa (a las 19.10 juega la selección - Argentina)
abraza las cosas y personas malas como si fueran tu mas preciada joya,Son tus mas grandes maestros de paciencia sabiduría y amor
y cuando lo abrazas dejan de causar dolor.-

Juan.

Hay una cosa que no entiendo, Entorno, ¿sirve para algo? ( Entorno _Entorno = new Entorno(); _Entorno._entorno();)

Aparte, no creo que afecte mucho al programa eso, pero esto tampoco lo entiendo

Datos obj = new Datos(); (dentro de datos)

El objeto ya lo declaraste en main, ¿para que otro objeto?

Esto otro tampoco lo entiendo:

byte _top = 2,hasElMom = 1; ¿byte? Se desaconseja totalmente, en C# o usas un int o si es real un float/double. Todo lo demás es peor en todo, rendimiento, optimizar código, legibilidad, requerirá un cast implicito tarde o temprano

Vamos, tú código es una locura, no es claro y no hace cosas lógicas. Es el primer código tuyo que veo, pero no creo que me equivoque mucho si digo que no eres programador .net de hace tiempo, sino que vienes de otro lenguaje y te estás adaptando. ¿C?

Deberías mirarte algo de programación a objetos, creo que no terminas de entender el concepto y la filosofía de la misma y aparte, mejorar tú código, hay errores que hoy día no son aceptables, un while(true) con break dentro es uno de ellos, o forzar en el bucle for el 10 porque sí en vez de usar numeros.size() es otra de las cosas que dan buena impresión

Y ya lo de el constructor ejecute el programa no lo comento, un constructor es para inicializar los datos, no para ejecutar el programa. Aparte, los métodos/funciones se usan ahora de forma que cada uno de ellos haga solo una cosa, es decir, necesitarías uno para limpiar de la consola la parte que quieres, otro para ordenar y otro para imprimir el array ordenado

P.D el uso del índice si es correcto pero al tratarse de un array es innecesario

DanielPy

Hola a todos.
Bueno al fin lo logre, me faltan algunas cosas pero funciona de una manera aceptable.-

Código (csharp) [Seleccionar]
using System;

namespace IndexadoresArray
{
    class ProgramaApp
    {
        static void Main(string[] argumentos)
        {
            Entorno entorno = new Entorno();
            entorno._entorno();
           
            Datos datos = new Datos();
            datos._Datos();

            Console.Write("\n\n Pulse una tecla para cerrar la aplicación...");
            Console.ReadLine();
        }
    }
}


Código (csharp) [Seleccionar]
using System;

namespace IndexadoresArray
{
    class Entorno
    {
        public void _entorno()
        {
            Console.Title = " Indexadores";
            Console.WindowHeight = 30;
            Console.WindowWidth = 70;
            Console.BackgroundColor = ConsoleColor.Blue;
            Console.ForegroundColor = ConsoleColor.Yellow;
            Console.Clear();
        }
    }
}


Código (csharp) [Seleccionar]
using System;

namespace IndexadoresArray
{
    class Datos
    {
        private int[] numeros = new int[5];
       
        public int this[byte indice]
        {
            get { return numeros[indice];}
            set { numeros[indice] = value;}
        }

        public void _Datos()
        {
            Datos obj = new Datos();
            byte _top = 2;
            int aux = 0;
            Console.SetCursorPosition(02, _top);
            Console.Write("Ingrese 10 entero(máximo 99999)");
            _top += 2;
            Console.SetCursorPosition(02, _top);
            Console.Write("Natutal   Ordenados");
            _top += 2;
            Ordenar ordenar = new Ordenar();
            for (byte i = 0; i < numeros.Length; i++)
            {
                while (true)
                {
                    Console.SetCursorPosition(02, _top);
                    Console.Write("");
                    if ((int.TryParse(Console.ReadLine(), out aux)) && aux < 100000)
                    {
                        obj[i] = aux;
                        break;
                    }
                }
                _top++;
                ordenar.ordenar(obj.numeros, i);
            }
        }
    }
}


Código (csharp) [Seleccionar]
using System;

namespace IndexadoresArray
{
    class Ordenar
    {
        public void ordenar(int[] aOrdenar,int cTraigo)
        {
            int temp = 0; cTraigo++;
            for (int e = 0; e < cTraigo; e++)
            {
                for (int i = 0; i < cTraigo - 1; i++)
                {
                    if (aOrdenar[i] > aOrdenar[i + 1])
                    {
                        temp = aOrdenar[i];
                        aOrdenar[i] = aOrdenar[i + 1];
                        aOrdenar[i + 1] = temp;
                    }
                }
            }
            byte filaCd = 6;
            for (byte m = 0; m < cTraigo; m++)
            {
                Console.SetCursorPosition(12, filaCd); Console.Write("                   ");
                Console.SetCursorPosition(12, filaCd); Console.Write("" + aOrdenar[m]);
                filaCd++;
            }
        }
    }
}


Saludos.
Daniel
abraza las cosas y personas malas como si fueran tu mas preciada joya,Son tus mas grandes maestros de paciencia sabiduría y amor
y cuando lo abrazas dejan de causar dolor.-

DarK_FirefoX

#3
Primero que todo, trato de entender que esto es un clase que tu creas llamada Datos, ahora, debes crear una instancia de esta clase en el metodo main, o sea en el punto de partida de tu proyecto.

Código (csharp) [Seleccionar]
Datos a = new Datos()

Código (csharp) [Seleccionar]
class Datos
  {
      private int[] numeros = new int[5];

      public int this[byte indice]
      {
          get { return numeros[indice];}
          set { numeros[indice] = value;}
      }

      public void _Datos()
      {
          Datos obj = new Datos();
          byte _top = 2;
          int aux = 0;
          Console.SetCursorPosition(02, _top);
          Console.Write("Ingrese 10 entero(máximo 99999)");
          _top += 2;
          Console.SetCursorPosition(02, _top);
          Console.Write("Natutal   Ordenados");
          _top += 2;
          Ordenar ordenar = new Ordenar();
          for (byte i = 0; i < numeros.Length; i++)
          {
              while (true)
              {
                  Console.SetCursorPosition(02, _top);
                  Console.Write("");
                  if ((int.TryParse(Console.ReadLine(), out aux)) && aux < 100000)
                  {
                      obj[i] = aux;
                      break;
                  }
              }
              _top++;
              ordenar.ordenar(obj.numeros, i)
          }
      }
  }


segunda aclaración sobre lo del tamaño del array que me hablas. Cuando quieres pasarle datos a una instancia que vayas a crear de una clase, la clase en cuestion debe tener un constructor, un constructor es como un metodo que se llama cuando instancias una clase, por lo tanto le puedes pasar parametros. En este caso, le pides un dato al usuario por la consola

Código (csharp) [Seleccionar]
int size = int.Parse(Console.ReadLine());
//y se lo pasas a la instancia de datos
Datos a = new Datos(size);


Este constructor debe estar dentro de la clase datos con esta signatura

Código (csharp) [Seleccionar]

public Datos(int size)
{
//lo que quieras hacer, en este caso asignarle el parametro size a tu array
}


Por ultimo, como dice Juan. No deberias crear una instancia de tu mismo tipo en el método
Código (csharp) [Seleccionar]
public void Datos()


porque en este caso no es necesario.

Si lo haces porque quieres utilizar el array dentro de tu clase, utilizas la palabra reservada this

Ejemplo:
Código (csharp) [Seleccionar]
//Estamos dentro de la clase Datos y quieres acceder al indexer lo haces de esta manera
this[tuNumeroIndice] = ALGO;


Espero te haya sido de ayuda, saludos