InicioArticulos y noticiasBases de datosProgramaciónForosInternetServiciosContratacionEmail
Tutorial C#
Introduccion a C#
Programacion con C#
Fundamentos de C#
Operadores
Instrucciones
Estrcuturas de control.
Definición de clases
Creación de objetos
Herencia y métodos virtuales
Polimorfismo
Ocultación de miembros
Miembros de tipo
Encapsulación
Espacios de nombres
Importación de espacios de nombres
Espacio de nombres distribuidos
Variables y tipos de datos
Tablas unidimensionales
Tablas multidimensionales
La clase System.Array
Cadenas de texto
Constantes
Orden de inicialización de variables
Métodos
Métodos externos
Constructores
Destructores
Propiedades
Indizadores
Redefinición de operadores
Delegados y eventos
La clase MulticastDelegate
Llamadas asíncronas
Implementación interna de los delegados
Eventos
Estructuras
Boxing y unboxing
Constructores de estructuras
Enumeraciones
Interfaces
Excepciones
Otras instrucciones
Atributos
Definición de nuevos atributos
Lectura de atributos en tiempo de ejecución
Atributos de compilación
Pseudoatributos
Código inseguro
Definición de punteros
Manipulación de punteros
Operadores relacionados con código inseguro
Fijación de variables apuntadas
Novedades de C# 2.0
Genéricos
Tipos parciales
Iteradores
Mejoras en la manipulación de delegados
Tipos anulables
Modificadores de visibilidad de bloques get y set
Clases estáticas
Referencias a espacios de nombres
Supresión temporal de avisos
Atributos condicionales
Incrustación de tablas en estructuras
Modificaciones en el compilador
También puedes ver ...
Creando cadenas de conexión ConnectionStrings en .net 3.5 o visual Studio 2008 usando SqlConnectionStringBuilder
Migración de WSE a WCF (Web Services de 2005 a 2008)
Generar archivos PDF con C#
TransactionScope - Simplificando el trabajo con transacciones.
LinQ To SQL - Un ejemplo sencillo
Cómo activar Intelisense (autocompletado) en el Web.config
Leer un campo XML de SQL Server 2005 con C#
TripleDES - Un ejemplo practico en C#
Mostrar un GridView dentro de un DataList
String.Format

Afiliados
La Web del programador
MundoProgramacion


 

Otras instrucciones

    Las instrucciones vistas hasta ahora son comunes a muchos lenguajes de programación. Sin embargo, en C# también se ha incluido un buen número de nuevas instrucciones propias de este lenguaje. Estas instrucciones se describen en los siguientes apartados:

Instrucciones checked y unchecked

    Las instrucciones checked y unchecked permiten controlar la forma en que tratarán los desbordamientos que ocurran durante la realización de operaciones aritméticas con tipos básico enteros. Funcionan de forma similar a los operadores checked y unchecked ya vistos en el Tema 4: Aspectos léxicos, aunque a diferencia de éstos son aplicables a bloques enteros de instrucciones y no a una única expresión. Así, la instrucción checked se usa de este modo:


checked
    <instrucciones>

    Todo desbordamiento que se produzca al realizar operaciones aritméticas con enteros en <instrucciones> provocará que se lance una excepción System.OverflowException. Por su parte, la instrucción unchecked se usa así:

unchecked
     <instrucciones>

    En este caso, todo desbordamiento que se produzca al realizar operaciones aritméticas con tipos básicos enteros en <instrucciones> será ignorado y lo que se hará será tomar el valor resultante de quedarse con los bits menos significativos necesarios.

    Por defecto, en ausencia de estas instrucciones las expresiones constantes se evalúan como si se incluyesen dentro de una instrucción checked y las que no constantes como si se incluyesen dentro de una instrucción unchecked. Sin embargo, a través de la opción /checked del compilador es posible tanto hacer que por defecto se comprueben los desbordamientos en todos los casos para así siempre poder detectarlos y tratarlos.

    Desde Visual Studio.NET, la forma de controlar el tipo de comprobaciones que por defecto se harán es a través de View à Propety Pages à Configuration Settings à Build à Check  for overflow underflow.

    El siguiente código muestra un ejemplo de cómo usar ambas instrucciones:


 using System;
 
 class Unchecked
 {
  static short x = 32767;   // Valor maximo del tipo short
  
  public static void Main()
  {
   unchecked
   {
    Console.WriteLine((short) (x+1));  // (1)
    Console.WriteLine((short) 32768); // (2)
   }
  }

    En un principio este código compilaría, pero los desbordamientos producidos por el hecho de que 32768 no es un valor que se pueda representar con un short (16 bits con signo) provocarían que apareciese por pantalla dicho valor truncado, mostrándose:


 -32768

 -32678

    Sin embargo, si sustituyésemos la instrucción unchecked por checked, el código anterior ni siquiera compilaría ya que el compilador detectaría que se va a producir un desbordamiento en (2) debido a que 32768 es constante y no representable con un short.

    Si eliminamos la instrucción (2) el código compilaría ya que (x+1) no es una expresión constante y por tanto el compilador no podría detectar desbordamiento al compilar. Sin embargo, cuando se ejecutase la aplicación se lanzaría una System.OverflowException.

Instrucción lock

    La instrucción lock es útil en aplicaciones concurrentes donde múltiples hilos pueden estar accediendo simultáneamente a un mismo recurso, ya que lo que hace es garantizar que un hilo no pueda acceder a un recurso mientras otro también lo esté haciendo. Su sintaxis es la siguiente:


lock (<objeto>)
          <instrucciones>

    Su significado es el siguiente: ningún hilo puede ejecutar las <instrucciones> del bloque indicado si otro las está ejecutando, y si alguno lo intenta se quedará esperando hasta que acabe el primero. Esto también afecta a bloques de <instrucciones> de cualquier otro lock cuyo <objeto> sea el mismo. Este <objeto> ha de ser de algún tipo referencia.

    En realidad, la instrucción anterior es equivalente a hacer:


System.Threading.Monitor.Enter(<objeto>);
try
{
 <instrucciones>
}
finally
{
 System.Threading.Monitor.Exit(<objeto>);
}

    Sin embargo, usar lock tiene dos ventajas: es más compacto y eficiente (<objeto> sólo se evalúa una vez)

    Una buena forma de garantizar la exclusión mutua durante la ejecución de un método de un cierto objeto es usando this como <objeto> En el caso de que se tratase de un método de tipo, en tanto que this no tiene sentido dentro de estos métodos estáticos una buena alternativa sería usar el objeto System.Type que representase a ese tipo. Por ejemplo:


class C
{
 public static void F()
 {
  lock(typeof(C))
  {
   // ... Código al que se accede exclusivamente
  }
 }
}

Instrucción using

    La instrucción using facilita el trabajo con objetos que tengan que ejecutar alguna tarea de limpieza o liberación de recursos una vez que termine de ser útiles. Aunque para estos menesteres ya están los destructores, dado su carácter indeterminista puede que en determinadas ocasiones no sea conveniente confiar en ellos para realizar este tipo de tareas. La sintaxis de uso de esta instrucción es la siguiente:


using (<tipo> <declaraciones>)
            <instrucciones>

    En <declaraciones> se puede indicar uno o varios objetos de tipo <tipo> separados por comas. Estos objetos serán de sólo lectura y sólo serán accesibles desde <instrucciones>. Además, han de implementar la interfaz System.IDisposable definida como sigue:


interface IDisposable
{
 void Dispose()
}

    En la implementación de Dispose() se escribiría el código de limpieza necesario, pues el significado de using consiste en que al acabar la ejecución de <instrucciones>, se llama automáticamente al método Dispose() de los objetos definidos en <declaraciones>.

    Hay que tener en cuenta que la llamada a Dispose() se hace sea cual sea la razón de que se deje de ejecutar las <instrucciones> Es decir, tanto si se ha producido una excepción como si se ha acabado su ejecución normalmente o con una instrucción de salto, Dispose() es siempre llamado. En realidad una instrucción using como:


using (R1 r1 = new R1())
{
 r1.F();
}

    Es tratada por el compilador como:


{
 R1 r1 = new R1()
 try
 {
  r1.F();
 }
 finally
 {
  if (r1!=null)
   ((IDisposable) r1).Dispose();
 }
}

    Si se declarasen varios objetos en <declaraciones>, a Dispose() se le llamaría en el orden inverso a como fueron declarados. Lo mismo ocurre si se anidasen varias instrucciones using: primero se llamaría al Dispose() de las variables declaradas en los using internos y luego a las de los externos. Así, estas dos instrucciones son equivalentes:


using (Recurso obj = new Recurso(), obj2= new Recurso())
{
 r1.F();
 r2.F();
}
using (Recurso obj = new Recurso())
{
 using (Recurso obj2= new Recurso())
 {
  r1.F();
  r2.F();
 }
}

    El siguiente ejemplo resume cómo funciona la sentencia using:


using System;
class A:IDisposable
{
 public void Dispose()
 {
  Console.WriteLine("Llamado a Dispose() de {0}", Nombre);
 }
 
 public A(string nombre)
 {
  Nombre = nombre;
 }
 string Nombre;
}
class Using
{
 public static void Main()
 {
  A objk = new A("objk");
  using (A obj1 = new A("obj1"), obj2 = new A("objy"))
  {
   Console.WriteLine("Dentro del using");
  }
  Console.WriteLine("Fuera del using");
 }
}

    La salida por pantalla resultante de ejecutar este ejemplo será:

 Dentro del using

 Llamando a Dispose() de objy

 Llamando a Dispose() de obj1

 Fuera del using

    Como se deduce de los mensajes de salida obtenidos, justo antes de salirse del using se llama a los métodos Dispose() de los objetos declarados en la sección <declaraciones> de dicha instrucción y en el mismo orden en que fueron declarados.

Instrucción fixed

    La instrucción fixed se utiliza para fijar objetos en memoria de modo que el recolector de basura no pueda moverlos durante la ejecución de un cierto bloque de instrucciones.

    Esta instrucción sólo tiene sentido dentro de regiones de código inseguro, concepto que se trata en el Tema 18: Código inseguro, por lo que será allí es donde se explique a fondo cómo utilizarla. Aquí sólo diremos que su sintaxis de uso es:


fixed(<tipoPunteros> <declaracionesPunterosAFijar>)
      <instrucciones>


Inicio | Tutorial C# ExcepcionesTutorial C#Atributos Versión para imprimir Foros de consulta


Añadir comentario ... Para preguntar utiliza los foros
Autor:

Título:


Para preguntar utiliza los foros.



Inicio | Tutorial C# ExcepcionesTutorial C#Atributos Versión para imprimir

Otras instrucciones
Autor: José Antonio González Seco
Visitas: 5962 Fecha de publicación: 14/11/2006
José Antonio es experto en tecnologias Microsoft. Imparte cursos y conferencias en congresos sobre C# y .NET en Universidades de toda España (Sevilla, Barcelona, San Sebastián, Valencia, Oviedo, etc.) en representación de grandes empresas como Microsoft.




Visitas: 310 | Comentarios: 0 | Archivo: Articulos
Categorias: Visual Basic .NET|C#|ASP.NET|ASP.NET|Programación|ADO.NET
27/09/2008 Navegando ....
Visitas: 85 | Comentarios: 0 | Archivo: Articulos
Categorias: Humor
Visitas: 207 | Comentarios: 0 | Archivo: Articulos
Categorias: Visual Basic .NET|C#|ASP.NET|ASP.NET|Programación|WCF
Visitas: 937 | Comentarios: 0 | Archivo: Articulos
Categorias: C#
Visitas: 209 | Comentarios: 0 | Archivo: Articulos
Categorias: JavaScript|ASP.NET
Visitas: 675 | Comentarios: 0 | Archivo: Articulos
Categorias: Windows XP|Linux|Windows Vista
Visitas: 455 | Comentarios: 0 | Archivo: Articulos
Categorias: Linux|BSD
Visitas: 236 | Comentarios: 0 | Archivo: Articulos
Categorias: Programación|Actualidad
18/08/2008 SQL Server 2008
Visitas: 1135 | Comentarios: 1 | Archivo: Articulos
Categorias: Transact-SQL
Visitas: 789 | Comentarios: 0 | Archivo: Articulos
Categorias: C#|ADO.NET|LinQ

Útimos temas recibidos en los foros ...
Coastal Inversiones SAC Coastal Vacations Oportunidad de Negocios por lecasur ... [ASP.NET] 0 11/10/2008
Negocios Rentables desde tu Hogar Coastal Vacations por lecasur ... [Access] 0 11/10/2008
COASTAL VACATIONS OPORTUNIDAD DE NEGOCIOS RENTABLES por lecasur ... [Actualidad] 0 11/10/2008
hacer el nombre de una tabla variable por leicolei ... [SQL Server] 2 10/10/2008
ayuda por yo ... [C#] 2 09/10/2008
Mostar nombre en una sesion de usuario por jhors ... [ASP.NET] 1 10/10/2008
Analista por Rolando ... [SQL Server] 0 10/10/2008
SQL dinámico en TRIGGERS por Alastor ... [ORACLE] 2 03/10/2008
Crystal Reports 8.5 por selvinalberto ... [Visual Basic 6.0] 0 10/10/2008
Agregar Columnas a un datagridview por Tony ... [Visual Basic .NET] 3 20/11/2007
Problema cargando un pl/sql Embebido en Pro*C por ejrivas ... [ORACLE] 0 10/10/2008
Verificar conexion a internet por giraldo ... [Visual Basic .NET] 3 11/12/2006

Access CGI JSP ORACLE UNIX
Actualidad HTML/DHTML/XHTML LINUX PHP Visual Basic .NET
ASP ISAPI MS DOS Power Builder Visual Basic 6.0
ASP.NET Java mySQL SQL WIN 98/NT/2000/XP
C# JavaScript Opinion SQL Server

devjoker  Te recomendamos además ...
22/10/2007 DoPDF - Crea archivos PDF facilmente
23/09/2008 Migración de WSE a WCF (Web Services de 2005 a 2008)
28/11/2006 Definición de nuevos atributos    forma parte de...Tutorial C#
27/10/2006 Eventos    forma parte de...Tutorial C#
01/06/2007 Autogenerado ESSALUD (Solución)
19/09/2006 Recuperar datos BLOB de ORACLE
22/10/2005 Tablas    forma parte de...Tutorial SQL
22/10/2005 Componentes del lenguaje SQL    forma parte de...Tutorial SQL
12/06/2007 Estructuras de control en Transact SQL    forma parte de...Tutorial de Transact SQL
22/10/2005 Consultar datos. SELECT    forma parte de...Tutorial SQL

 

Encuesta
¿A que perfil te adaptas mejor?
[Ver] [Votar]