lunes, 26 de mayo de 2008

Acumuladores y contadores

Acumuladores y contadores

Acumulador
En un CPU de computadora, el acumulador es el registro en el que son almacenados temporalmente los resultados aritméticos y lógicos intermedios que serán tratados por la Unidad aritmético-lógica (ALU).

Sin un registro como un acumulador, sería necesario escribir el resultado de cada cálculo (como adición, multiplicación, desplazamiento (shift), etc.) en la memoria principal, quizás justo para ser leída inmediatamente otra vez para su uso en la siguiente operación. El acceso a la memoria principal es significativamente más lento que el acceso a un registro como el acumulador porque la tecnología usada para la memoria principal es más lenta (pero más barata) que la usada para un registro interno del CPU.
Contador de programa

El contador de programa, es un registro del procesador de un computador que indica la posición donde está el procesador en su secuencia de instrucciones. Dependiendo de los detalles de la máquina particular, contiene o la dirección de la instrucción que es ejecutada, o la dirección de la próxima instrucción a ser ejecutada. El contador de programa es incrementado automáticamente en cada ciclo de instrucción de tal manera que las instrucciones son leídas en secuencia desde la memoria. Ciertas instrucciones, tales como las bifurcaciones y las llamadas y retornos de subrutinas, interrumpen la secuencia al colocar un nuevo valor en el contador de programa.

MÉTODOS PARA LEER DATOS

MÉTODOS PARA LEER DATOS

Existen dos métodos para leer datos, el primero sirve para leer sólo un carácter y el segundo lee una cadena completa de caractéres.

variable=console.read( );
cadena=console.readLine( );

Para guardar un dato dentro de una variable se ocupa la siguiente sintaxis.
,
Tipo variable=tipo.Parse(Console.readline( );)
int Nom_1=int.Parse(Console.readLine( );)

Parse: transforma la entrada a una estructura de datos que ahora si por las dos puede ser procesada.

ESTRUCTURAS DE CONTROL
Evaluan una o mas alternativas y pueden ser bidireccional o multidireccional.

Insturccion int (bidireccional): instrucción condicinal más usada en los diversos lenguajes de programación.Su sintaxis es:
if(condicional)
{
grupo cierto de instrucciones;
}
else
{
grupo falso de instrucciones;
}

Instruccion Switch (multidireccional): existen ocasiones o programas donde se exige evaluar muchas condiciones a la vez. en estos casos se usa una condición compuesta muy grande o se debe intentar convertir el problema a uno que se pueda resolver usando la instrucción switch.
Esta instrucción es de decisión múltiple donde el compilador prueba o busca e valor contenido en un variable entera o caracter contra una lista de constantes apropiadas, cuando la computadora encuentra el valor de igualdad entre variable y constante entnces ejecuta el grupo de instrucciones asociados a dicha constante, si no encuentra el valor de igualdad entonces ejecuta un grupo de instrucciones asociados a un default aunque éste último es opcional.

Switch (variable)
{
case "a":
a+b
break;
case "b":
a-b
break;
case default:
-error-

case 1
case 2
instrucciones
break

Espacio de nombres

Espacio de nombres:
Clasificación especial usada para agrupar un conjunto de clases y estructuras relacionadas, también se ocupa para aislar ese grupo de nombres en conjunto de tipos de datos separados y distintos.
Es imposible tener 2 clases con el mismo nombre en un espacio de nombres, pero es posible que existan clases con el mismo nombre en espacios de nombres diferentes.

Los espacios de nombres pueden ser predefinidos o definidos por el usuario.

El .net tiene clases en espacios de nombre predefinidos, por ejemplo system.

Para definir un espacio de nombre se utiliza.
Namespace nombreespacio
{
Clase del nombre de nombres.
}

Clases unidad básica de la programación orientada a objetos. Todo programa c# se organiza en clase que encapsula datos y comportamientos.
Una clase se construye con la palabra class y el símbolo de inicio y fin de un bloque.para delimitar la codificacion de sus miembros ,

Class nombreclase
{
codificación de loa miembros de la clase
}


Clase Mesa (conceptos generales)
Objeto

Clase Animal
Subclases Carivoros
Objeto: león con dientes picudos y melena grande. (lo que es de él)

Métodos para escribir datos:

Un método es reconocido por tener paréntesis y por los paraámetros que puede contener. Los métodos usados para escribir satos en pantalla son:
1. Write: escribe sin añadir el caractér de fion de línea a la cadena.
2. WriteLine si añade el caractér de fin de línea a la cadena ,de modo que lo siguiente que se escriba se colocará en la siguiente línea

Clase método ("cadena de caractéres")
Consola Write ("hola")

( al final siempre se pone ; )

Ejemplo:
Console. Write ("Hola");
Console. WriteLine ("Pepe");
Console. Write ("¿Como estas, ");
Console, WriteLine ("¿bien?");

Resultado en consola:
HolaPepe
¿Como estas, ¿bien?

LENGUAJE DE PROGRAMACIÓN
El lenguaje de programación tiene 3 herramientas esenciales: la declaración y uso de variables, cíclos y condicionales.

Elementos léxicos de un programa

Elementos léxicos de un programa

1) Comentarios: anotaciones para documentar el programa. Se utilizan de la siguiente forma :
// para documentar sobre un renglon
/* texto */ se utiliza para comentar parrafos

2) Palabras reservadas: palabras que tienen un determinado significado para el compilador.

3) Identificadores: nombre que lor programadores dan a los diferentes elementos de un programa. Las características que deben contener son las sigueintes:
Secuencia de digitos, caracteres.
No deben coincidir con una palabra reservada.
No deben empezar con un dígito.
Son sensibles a mayúsculas y minúsculas.
Se acostumbra poner significativos y que la primera letra de la palabra sea en mayúsculas.
No se permiten los acentos y los espacios.

4) Operadores y Puntersos
Operadores: indican las operaciones que se van a realizar */-+(concatenar o unir)%
Punteros: agrupan o separan. { }

5) Literales: Valores constantes escritos directamente en el programa.
6) Directivas del preprocesador: son intrucciones al compilador, comienzan con #

Sentencias y bloques.

-Sentencia: Representacion de una acción o secuencia de acciones ejecutables o no ejecutables. (ejecutables +-*/ )
(no ejecutable son las declaraciones)

-Bloque: grupo de sentencias delimitadas por llaves.

Método Main

Es un punto de entrada al programa y la ejecución siempre inicia en el método main. Debe tener las sigueintes caracterísicas:
- declarado static en una clase o estructura
- regresar void o int
- debe ser escrito con mayúscula la primera latra y minuscula lo demás
- puede no tener parámentros o recibir un arreglo de strings.

using system,
namespace consoleapplication1
{
class Class1
{
static void Main (string [ ] args)
{
// TODO se agerga código para la aplicacion
}
}
}

Programación

PROGRAMACIÓN EN C#

1.- ¿Qué es programar?
Programar es hacer que la computadora obedezca una serie de instrucciones bien detalladas. Utiliza un lenguaje de programación que indica como tiene que reaccioonar ante la interacción del usuario.

Se cooce como programación de computadoras a la implementación de un algoritmo en un determinado lenguaje de programación, conformando un programa.

2.- Programa
Concepto desarrollado desarrollado por Von Newmann en 1946.
Union de una secuencia de instrucciones que una computadora puede interpretar y ejecutar. Y una estructura de datos que almacenan la información independiente de las instrucciones que dicha secuencia maneja.
Para ello se usan lenguajes de programación que sirven para programar la secuencia de instrucciones requerida. Según Niklaus Wirth un rpogrma esta formadop por algoritmos yy estructuras de datos.

Lenguaje de programacion

1) tiene un numero limitado de simbolos y tambien un numero limitado de palabras.
2) constituido por un conjunto de reglas sintacticas y semanticas
-sintacticas: se refieren a la especificacion de la formacion de intrucciones validas
-semanticas: especifican el significado de estas intrucciones
3) la escritura o codificacion del programa puede resultar una tarea senciulla si conocemos las reglas sintacticas y semanticas que constituyen el lenguaje de programacion

Antecedentes de C#

Lenguaje B, escrito por Ken Thompson en 1970 con el objetivo de recodificar el sistema operativo UNIX, que hasta el momento se había programado en ensamblador. La pega del ensamblador era que lo ligaba a una serie de máquinas concretas, por lo que conseguir un lenguaje abstraído de cada máquina conseguiría una portabilidad del sistema muchísimo mayor. A su vez B fue inspirado en el BCPL de Martin Richard, diseñado tres años antes.

En 1972 es Dennis Ritchie (de los Laboratorios Bell de AT&T) quien diseña finalmente C a partir del B de Thompson, aportando un diseño de tipos y estructuras de datos que consiguen una claridad y eficacia en el lenguaje muy superior. Es un lenguaje que permite realizar una programación estructurada economizando las expresiones, con abundancia de operadores y tipos de datos (aunque los básicos sean pocos), codificando en alto y bajo nivel simultáneamente, reemplazando ventajosamente la programación en ensamblador y permitiendo una utilización natural de las funciones primitivas del sistema. Además, no está orientado a ningún área en especial y sobre todo consigue un código objeto altamente optimizado que repercute en que los programas son muy rápidos.

Durante muchos años no existen reglas estándar para el lenguaje, pero en 1983 se decide formar un comité con el objetivo de crear el estándar ANSI (Instituto Nacional Americano de Estándares). El proceso dura seis años y a principios de los 90 el estándar es reconocido por la ISO (Organización Internacional de Estándares) y comienza a comercializarse con el nombre ANSI C.

Paralelamente, en 1980 surge C++ de la mano de Bjarne Stroustrup (también de Laboratorios Bell de AT&T). Diseña este lenguaje con el objetivo de añadir a C nuevas características: clases y funciones virtuales (de SIMULA67), tipos genéricos y expresiones (de ADA), la posibilidad de declarar variables en cualquier punto del programa (de ALGOL68), y sobre todo, un auténtico motor de objetos con herencia múltiple que permite combinar la programación imperativa de C con la programación orientada a objetos. Estas nuevas características mantienen siempre la esencia del lenguaje C: otorgan el control absoluto de la aplicación al programador, consiguiendo una velocidad muy superior a la ofrecida por otros lenguajes.

El siguiente hecho fundamental en la evolución de C++ es sin duda la incorporación de la librería STL años más tarde, obra de Alexander Stepanov y Adrew Koening. Esta librería de clases con contenedores y algoritmos genéricos proporciona a C++ una potencia única entre los lenguajes de alto nivel.

Debido al éxito del lenguaje, en 1990 se reúnen las organizaciones ANSI e ISO para definir un estándar que formalice el lenguaje. El proceso culmina en 1998 con la aprobación del ANSI C++.

La última variante que ha surgido de C es el moderno C#. En el año 2000, Microsoft presenta su plataforma .NET junto con un nuevo lenguaje, C# (diseñado por Anders Hejlsberg), que servirá de lenguaje principal de la plataforma. C# es un híbrido de C++ y Java que fusiona, principalmente, la capacidad de combinar operadores propia del primero (no incorpora la herencia múltiple) con la plena orientación a objetos del segundo. La orientación a objetos es tal que el propio programa está encapsulado en una clase.

Actualmente C# se encuentra entre los 10 lenguajes más utilizados. A pesar de su corta historia, ha recibido la aprobación del estándar de dos organizaciones: en el 2001 se aprueba el ECMA y en el 2003 el ISO.

Fases de slución de un problema

Fases de slución de un problema

1.- Análisis del Problema. (Mapa general del problema)
2.- Definicón del problema. (delimitación)
3.- Definición de entradas y salidas. (Lo que se busca obtener al finalizar el problema)
4.- Proceso de solución. (Pasos a seguir para solucionar el problema de manera precisa)
5.- Comprobación. (Rectificar el proceso de solución)



1. Análisis del prblema
2. Diseño del Algoritmo
3. Codificación: transcribir lo hecho en algoritmo en lenguaje de programación.
4. Compilació y ejecución: Lenguaje de programación, en la maquina y ejecutándose para buscar errores
5. Verificación: busqueda y descricpción de los errores
6. Depuración: correción de los errores
7. Documentación:


Algoritmo: sucesión de pasos a seguir para llegar a una solución.

Análsis de problema: Pintar una pared
Definición del problema: Pinar una pared de 2 x 5
Definición de entradas y salidas
Entradas: Pared, pintura, brocha y periódico.
Salida: Pared de la recámara pintada:
Proceso de solución: pasos a seguir.

Reglas para dibujar un diagramas de flujo.

Reglas para dibujar un diagramas de flujo.

Los Diagramas de flujo se dibujan generalmente usando algunos símbolos estándares; sin embargo, algunos símbolos especiales pueden también ser desarrollados cuando séan requeridos. Algunos símbolos estándares, que se requieren con frecuencia para diagramar programas de computadora se muestran a continuación:

Inicio o fin del programa

Pasos, procesos o líneas de instruccion de programa de computo

Operaciones de entrada y salida

Toma de desiciónes y Ramificación

Display, para mostrar datos

Envía datos a la impresora