Es un lenguaje de programación orientado a objetos desarrollado por Microsoft. Deriva de los lenguajes C, C++, pero aplicando el sistema de objetos de Java. Su nombre viene de añadir otros dos ++ a C++, lo cual resultaría en #. Este lenguaje además soporta la mayoría de paradigmas de programación, incluyendo tales como el tipado dinámico y su contraparte el estático, y características funcionales.
A continuación, vamos a repasar todas las novedades que incluye la versión de C# 8.
Se trata de una novedad muy sencilla y fácil de usar, en versiones anteriores si teníamos un array y queríamos inicializarlo debíamos poner un new nombreArray(...) en cada elemento del array, con esta mejora ya podremos omitirlo y no será necesario escribirlo tantas veces. Vamos a ver un ejemplo para entenderlo mejor:
Una declaración using es una declaración de variable precedida por la palabra clave using. Indica al compilador que la variable que se declara debe eliminarse al final del ámbito de inclusión. Por ejemplo, considere el siguiente código que escribe un archivo de texto.
Las variables de tipo de referencia no acepta valores NULL. Pero añadiendo al nombre del tipo de referencia el signo ? se declara la variable como un tipo de referencia que si acepta valores NULL.
En los tipos de referencia que no aceptan valores NULL, el compilador usa el análisis de flujo para garantizar que las variables locales se inicializan en un valor no NULL cuando se declaran. Los campos se deben inicializar durante la construcción. Si la variable no se establece mediante una llamada a alguno de los constructores disponibles o por medio de un inicializador, el compilador genera una advertencia. Además, los tipos de referencia que no aceptan valores NULL no pueden tener asignado un valor que podría ser NULL.
El patrón de propiedades permite hallar la coincidencia con las propiedades del objeto examinado. Considere un sitio de comercio electrónico que debe calcular los impuestos de ventas según la dirección del comprador. Ese cálculo no es una responsabilidad fundamental de una clase Addres. Cambiará con el tiempo, probablemente con más frecuencia que el formato de dirección. El importe de los impuestos de ventas depende de la propiedad State de la dirección. El método siguiente usa el patrón de propiedades para calcular los impuestos de ventas a partir de la dirección y el precio.
Un elemento struct declarado con el modificador ref no puede implementar ninguna interfaz y, por tanto, no puede implementar IDisposable. Por lo tanto, para permitir que se elimine un elemento ref struct, debe tener un método void DIspose() accesible. Esto también se aplica a las declaraciones readonly ref struct.
Algunos algoritmos dependen de varias entradas. Los patrones de tupla permiten hacer cambios de función de varios valores, expresados como una tupla. El código siguiente muestra una expresión switch del juego piedra, papel, tijeras:
Los mensajes indican el ganador.
Los métodos de interfaz predeterminados(también conocidos como métodos de extensión virtual) permitirá a los desarrolladores utilizar la técnica de programación de rasgos, son una tecnología de programación orientada a objetos que promueve la reutilización de métodos entre clases no relacionadas.
El principal beneficio que brindan los métodos predeterminados es que ahora es posible agregar un nuevo método predeterminado a una interfaz existente sin romper las clases que implementan esa interfaz. En otras palabras, esta característica hace que sea opcional para los implementadores anular el método o no.
Los rangos e índices proporcionan una sintaxis concisa para especificar subrangos en una matriz.
Puede especificar un índice desde el final. Para especificar desde el final, puede usar el operador ^. Está familiarizado con array[2] lo que significa el elemento “2 desde el principio”. Ahora, array2 significa el elemento “2 desde el final”. El índice ^0 significa “el final” o el índice que sigue al último elemento.
Puede especificar un rango con el operador de rango: .. .Por ejemplo, 0..^0 especifica el rango completo de la matriz: 0 desde el principio hasta, pero sin incluir 0 desde el final. Cualquier operando puede usar “desde el principio” o “desde el final”. Además, se puede omitir cualquier operando. Los valores predeterminados son 0 para el índice de inicio y ^0 para el índice final.
El índice de cada elemento refuerza el concepto de “desde el inicio” y “desde el final”, y que los rangos son exclusivos del final del rango. El “inicio” de toda la matriz es el primer elemento. EL “final” de toda la matriz es pasado el último elemento.
Puede recuperar la última palabra con el índice ^1:
El siguiente código crea un subrango con las palabras “quick”, “brown” y “fox”. Va de words[1] a words[3]. El elemento words[4] no está en el rango.
El siguiente código crea un subrango con “lazy” y “dog”. Incluye words2 y words1. El índice del final words0 no se incluye:
En los ejemplos siguientes se crean rangos con final abierto para el inicio, el final o ambos:
También puede declarar rangos como variables:
El rango se puede usar luego dentro de los caracteres [ ]:
Una instrucción switch genera un valor en cada uno de sus bloques case. Las expresiones switch le permite usar una sintaxis de expresiones más concisa. Hay menos palabras clave case y break repetitivas y menos llaves. Ejemplo:
Sigue formándote en el mundo de la programación y no pierdas la oportunidad de consultar la página de nuestro curso de C#.