Tarea pagweb

907 views

Published on

Ejemplos y analisis de paginas web

Published in: Education
  • Be the first to comment

  • Be the first to like this

Tarea pagweb

  1. 1. Nombre de la Asignatura: Programación I<br />Ejemplo de Pagina 1:<br />Universidad Simón Bolívar<br />Departamento de Computación<br />CI2126 Computación II <br />Gabriela Ochoa<br />Lectura y Escritura en Archivos Secuenciales<br />La clase de hoy cubre la creación, lectura y escritura de archivos. Adicionalmente veremos como pasar argumentos desde la línea de comandos al programa. Un aspecto importante de cualquier programa, es su habilidad de comunicarse con el mundo exterior. La lectura de archivos con datos de entrada, y la escritura de archivos de salida con los resultados, constituye una manera simple pero efectiva de comunicación.<br />Funciones de Librería para la Entrada y Salida (E/S) de Archivos<br />Existen rutinas para abrir y cerrar archivos, y para leer y escribir en ellos utilizando datos formateados, de manera similar a como se hace el formato de datos para entrada y salida en pantalla.<br />La función fopen se utiliza para abrir un archivo, y asociarle una variable apuntador a archivo con la cual el programa puede referirse a la fuente del archivo. El prototipo de fopen es:<br />FILE *fopen(const char *filename, const char *modo);<br />fopen retorna un apundador al archivo si la llamada fue exitosa, y si no, retorna NULL. El apuntador al archivo se utiliza para identificar la fuente del mismo, se pasa como parámetro a las rutinas de escritura, lectura y manejo del archivo. El filename y modo son cadenas de caracteres. Los modos válidos son:<br />ModoUsorAbre para lecturawAbre o crea para escritura. Descarta (destruye) cualquier contenido previoaAbre o crea para escritura. Agrega a (escribe después de) cualquier contenido previor+Abre para modificaciones (lectura y escritura)w+Abre o crea para modificación. Descarta (destruye) cualquier contenido previoa+Abre o crea para modificación. Agrega a cualquier contenido previo<br />Para declarar una variable de tipo apuntador a archivo:<br />#include <stdlib.h><br />FILE *fp;<br />Ejemplo de apertura de un archivo:<br />fp = fopen(" datos.txt" ," w" );<br />La función fflush se usa para físicamente escribir (bajar) en el archivo cualquier data almacenada en el " buffer" intermedio. Para hacer los programas más eficientes y reducir las llamadas al sistema, los archivos mantienen un buffer (memoria) intermedia, una vez que el buffer está lleno, los datos se escriben en el archivo. La rutina fflush fuerza a que el buffer sea escrito en el archivo asociado. Su prototipo es:<br />int fflush(FILE *fp);<br />Recibe un apuntador a archivo como parámetro. Retorna cero si la llamada fue exitosa y EOF si no lo fue. EOF es una constante especial que denota que se ha llegado al final del archivo.<br />Para cerrar los archivos se utiliza la función fclose. Su prototipo es:<br />int fclose(FILE *fp);<br />Fclose retorna cero si fue exitosa y EOF si hubo alguna falla.<br />Para escribir datos en un archivo se utiliza la fprintf. Esta función es muy similar a printf, que ya sabemos manejar bien. La única diferencia es que fprintf tiene un argumento adicional, el apuntador a archivo que especifica la fuente donde queremos escribir. Su prototipo es:<br />int fprintf(FILE *fp, const char* format, ....);<br />fprintf retorna el número de caracteres que fueron escritos exitosamente o un número negativo en caso de falla.<br />Para leer datos de un archivo se utiliza la función fscanf. Esta función es muy similar a scanf, que ya sabemos manejar bien. La única diferencia es que fscanf tiene un argumento adicional, el apundador a archivo que especifica la fuente de donde queremos leer. Recuerden que los argumentos para guardar datos deben ser apuntadores (i.e, llevan & en caso de ser variables simples, y solo el nombre en caso de ser arreglos de caracteres). Su prototipo es:<br />int fscanf(FILE *stream, const char* format, ....);<br />Ejemplo<br />El siguiente programa abre un archivo que contiene un nombre y cedula de identidad. Luego abre un archivo de salida y escribe estos datos (pero en orden invertido). El archivo de entrada fue creado con un editor de texto.<br />Archivo de entrada: entrada.txt<br />Pedro 18878798<br />#include <stdio.h><br />int main()<br />{ <br /> char ifilename[] = " entrada.txt" ;<br /> char ofilename[] = " salida.txt" ;<br /> char name[30];<br /> int idNum;<br /> FILE *ofp, *ifp; /* Declara apuntadores a archivo */<br /> ifp = fopen(ifilename," r" ); /* Abre archivo de entrada */<br /> fscanf(ifp," %s %d" ,name,&idNum); /* Lee datos de entrada */<br /> ofp = fopen(ofilename," w" ); /* Abre archivo de salida */<br /> fprintf(ofp," %d %s " ,idNum, name); /* Escribe los datos */<br /> fclose(ifp); fclose(ofp); /* Cierra los archivos */<br /> return 0;<br />} <br />Archivo de salida: salida.txt<br />18878798 Pedro <br />Ejercicio de Practica<br />Extender el ejercicio anterior para que sea capaz de leer y escribir múltiples pares de nombres y cédulas. Sugerencia: Crear un ciclo y chequear cuando la rutina scanf retorna EOF.<br />Solucion:<br />#include <stdio.h><br />int main(){<br />char ifilename[] = " c:/entrada.txt" ;<br />char ofilename[] = " c:/salida.txt" ;<br />char name[30];<br />int idNum;<br />FILE *ofp, *ifp;<br />ifp = fopen(ifilename," r" ); /* Abrir archivo entrada */<br />ofp = fopen(ofilename," w" ); /* Abrir archivo salida */<br />while (fscanf(ifp," %s %d" ,name,&idNum) != EOF) {/*Leer datos */<br /> fprintf(ofp," %d %s " ,idNum, name); /* Escribir datos */<br />}<br />fclose(ifp); fclose(ofp); /* Cerrar archivos */<br />return 0;<br />} <br />Otras Rutinas Útiles<br />int fgetc(FILE *fp); Retorna el siguiente carácter del archivo referenciado por fp, o EOF si se ha llegado al final del archivo. El tipo de retorno es int en lugar de char, debido a que el carácter EOF debe ser manejado.<br />int *fgets(char *s, int n, FILE *fp); Retorna un apuntador a la cadena de caracteres leída si resulta exitoso, o NULL si se llega al final del archivo o si ocurre un error. La cadena es también almacenada en el arreglo de caracteres especificado como argumento. Un máximo de n-1 caracteres serán leídos. Lo cual da espacio para guardar el carácter de fin de cadena ''.<br />int fputs(const char s*, FILE *fp); Escribe una cadena de caracteres en el archivo, retorna EOF si hubo alguna falla. <br />int fputc(int c, FILE *fp); Escribe un carácter solo en el archivo, si hubo algún problema devuelve EOF.<br />int sprintf(char *buffer, const char *format, ...); Esta función es similar a fprintf, excepto que los datos son escritos en un arreglo (o buffer) de caracteres en lugar de en un archivo de salida.<br />int sscanf(char *buffer, const char *format, ...); Esta función es similar a fscanf, excepto que los datos son leídos de un arreglo (o buffer) de caracteres en lugar de un archivo de entrada.<br />Argumentos de Línea de Comando<br />C provee un mecanismo para pasar argumentos desde la línea de comandos al programa que se va a ejecutar. Cuando el programa comienza su ejecución, la rutina main es llamada con dos argumentos: un contador y un apuntador a un arreglo de cadenas de caracteres. El contador es llamado por convención argc y el apuntador argv. El uso de argv es un poco truculento. Dado que argv es un apuntador a un arreglo de cadenas de caracteres, la primera cadena de caracteres es referenciada por argv[0] (o *argv). La segunda cadena es referenciada por argv[1] (o *(argv + 1)), la tercera por argv[2], y así sucesivamente. La primera cadena de caracteres, argv[0], contiene el nombre del programa. Los argumentos comienzan realmente con argv[1]. <br />Un ejemplo de llamada de un programa llamado copia, que copie un archivo en otro archivo seria: copia fuente.txt destino.txt. Esto es, el nombre del programa más dos argumentos que corresponderían a los nombres de los archivos fuente y destino.<br />Veamos un ejemplo que simplemente muestra los argumentos de un programa.<br />#include <stdio.h><br />int main(int argc, char *argv[])<br />{<br /> int i;<br /> fprintf(" The number of command line arguments is %d " , argc);<br /> fprintf(" The program name is %s " ,argv[0]);<br /> for (i = 1; i < argc; i++) {<br /> fprintf(" %s" ,argv[i]);<br /> }<br /> fprintf(" " );<br /> return 0;<br />}<br />Referencias<br />Tutorial de Programación en C , conciso y bien escrito, con enlaces a muchos otros recursos para la programación en C y C ++.<br />Ir a Pagina del Curso<br />Aspectos Generales:<br />URL:http://www.ldc.usb.ve/~gabro/teaching/CI2126/Clase2_Archivos.htm<br />Utilización en el Aula:<br />Tipología: La Universidad Simón Bolívar, Departamento de Computación, por :Gabriela Ochoa. No especifica su cargo o grado de Instrucción.<br />Destinatario: La página fue pensada para ser usada por alumnos de niveles avanzados, especialistas e investigadores.<br />Nivel: usuarios de superior, o profesional.<br />Actividades: El sitio no incluye actividades para realizar con los alumnos.<br />La página pertenece a la Universidad Simón Bolívar destinada al área educativa tecnológica. <br />La página es no es de tipo portal ya que no cuenta con diversos recursos y herramientas que permiten la interacción, descarga de materiales y suscripción a revistas. Está destinada principalmente a profesionales de la educación, siendo el nivel académico de sus contenidos en el área de educación profesional o superior. La página se encuentra en Venezuela.<br />Aspectos Curriculares:<br />Interés para el Profesorado: la página sirve solo para uso del docente. <br />La página no permite descarga de materiales, libros digitales y pero si hay vínculos hacia otras páginas.<br />Aspectos Gráficos:<br />El entorno estático está diseñado con una fuente de tamaño muy pequeño lo cual puede dificultar su lectura, los colores son suaves lo cual hace agradable la interfaz y no posee imágenes.<br />En relación al entorno dinámico, posee ningún elemento animado.<br />No tiene elementos multimedia, tales como videos, archivos de imágenes o sonidos.<br />Aspectos Técnicos: <br />Libertad de Acceso: El acceso a la página es gratis y los usuarios no pueden suscribir a un envío de noticias vía correo electrónico para enterarse de las novedades de allí descritas.<br />Publicidad: no cuenta con enlaces a cursos pagos y promoción de eventos ni posee spam de publicidad.<br />Navegabilidad: si posee hipervínculos o enlaces dentro de la página. La navegabilidad en la página se hace ligera y no tarda en cargar , los vínculos no todos están correctamente activos.<br />Interactividad : No posee, foros, chat, envío de mensajes, o cuestionarios. No cuenta con un blog y correo de contacto.<br />Conclusión:<br />La página no se adapta a los requerimientos académicos de la asignatura por lo que no será utilizada como material de consulta para mis estudiantes. Solo como material de apoyo docente.<br />Ejemplo 2:<br />Versión 3.0 <br />800x600 mínimo <br />En esta lección:Escritura-----Abrir un archivo-----Cerrar un archivo-----Concatenar datos-----Lectura-----Leer una palabra-----Leer una línea-----Asignación especial-----Otras secciones:Conceptos básicos-----Programando en C-----Programando en C++-----Programando Windows 9x.-----Teoría electrónica-----Circuitos electrónicos-----Actividades adicionales-----Hipervínculos-----Contácteme:Dudas y comentarios-----Escritura de un archivoA lo largo de ésta lección veremos la mecánica necesaria para escribir y leer datos a un archivo, empezaremos con la escritura. Como siempre, los códigos especifican en primer lugar algunas sentencias #include, y en el caso concreto del primer código de ejemplo se ha declarado un nuevo tipo de variable. Estudie el siguiente código:#include <stdio.h>#include <string.h>int main(){ FILE *fp; fp = fopen(" prueba.htm" , " w" ); /* Abrir archivo para escritura */ fprintf(fp, " <HTML> " ); fprintf(fp, " <BODY> " ); fprintf(fp, " Esta es la primera linea de texto. " ); fprintf(fp, " <CENTER>Esta es la segunda" " linea</CENTER> " ); fprintf(fp, " Y esta es la <B>tercera linea" " de texto.</B> " ); fclose(fp); /* Cerrar el archivo antes de terminar el programa */ printf(" Se ha creado el archivo: prueba.htm " ); return 0;}El tipo FILE es una estructura (misma que estudiaremos en la siguiente lección) que estádefinida en el archivo de cabecera stdio.h, se usa para definir un puntero que se utilizará en operaciones con archivos. Por definición, C requiere para accesar a un archivo de un puntero de tipo FILE, como es normal, se puede utilizar cualquier nombre para representar dicho puntero, es común utilizar fp, así que éste nombre utilizamos en el primer código.Cómo abrir un archivoAntes de poder escribir datos en un archivo, debemos abrirlo, esto significa que debemos decirle al sistema que deseamos escribir en un archivo especificando el nombre del mismo, para esto utilizamos la función fopen ( ), especificada en la línea 8 del código. El puntero de archivo, fp en éste caso, señala a la estructura para el archivo siendo necesarios dos argumentos para ésta función, el nombre del archivo en primer lugar, y el atributo del archivo. El nombre del archivo es cualquier nombre válido para su sistema operativo y puede ser expresado sea en minúsculas ó mayúsculas, incluso si así lo desea, como una combinación de ámbas, el nombre se encierra entre comillas. En el ejemplo escogí el nombre prueba.htm. Es importante que en el directorio donde trabaje éstos ejemplos no exista un archivo con éste nombre pues al ejecutar el programa se sustituirán los datos del mismo, en caso de no existir un archivo con el nombre especificado, el programa lo creará.Lectura (" r" )El segundo parámetro es el atributo del archivo y puede ser cualquiera de éstas tres letras, " r" , " w" , ó " a" , y deben estar en letra minúscula. Existen atributos adicionales en C que permiten operaciones de Entrada/Salida (E/S) más flexibles por lo que es recomendable laconsulta de la documentación del compilador. Cuando se utiliza " r" el archivo se abre paraoperaciones de lectura, para operaciones de escritura utilizamos " w" y cuando se especifica " a" es porque deseamos agregar datos adicionales a los ya existentes en el archivo, o sea concatenar datos. Abrir un archivo para lectura implica la existencia del mismo, si ésta condición no es válida el puntero de archivo será igual a NULL y ésto puede ser verificado utilizando el siguiente código:if (fp==NULL){ printf(" Error al abrir el archivo " ); exit (1);}Es una buena práctica de programación checar todos los punteros de archivo en una forma similar al código de arriba, el valor de 1 utilizado como parámetro de exit ( ) será explicado más adelante.Escritura (" w" )Cuando un archivo se abre para operaciones de escritura, si éste no existe entonces será creado, y si existe será reescrito dando como resultado la pérdida de los datos existentes en el archivo previo. Si ocurre por alguna razón un error al abrir el archivo, el puntero dearchivo retorna un valor de NULL que puede ser checado como se especificó arriba.Concatenar (" a" )Cuando un archivo se abre para concatenar datos, si no existe será creado inicialmente vacío. Si el archivo existe, el punto de entrada de datos se situa al final de los datos existentes en el archivo, de ésta manera es como se agregan nuevos datos al archivo. El puntero de archivo se puede verificar como yá se explicó.Salida al archivoLa salida de datos hacia un archivo es prácticamente idéntica a la forma en quedesplegamos datos en el dispositivo estándar de salida, las únicas diferencias reales son el nombre de una nueva función y la adición del puntero de archivo como uno de los argumentos de la función. En el código de ejemplo, la función fprintf ( ) reemplaza a la familiar printf ( ) y el puntero de archivo vá como argumento dentro del paréntesis de lafunción, como se aprecia en las líneas 9 a la 13 del código de ejemplo.Cerrando el archivoPara cerrar un archivo se utiliza la función fclose ( ) con el puntero de archivo dentro delparéntesis. En algunos programas sencillos no es necesario cerrar el archivo ya que el sistema operativo se encarga de cerrar los archivos que hayan quedado abiertos antes de retornar el control al usuario, sin embargo es buena práctica cerrar en código todo aquel archivo que se abra.Compile y ejecute el programa, la única salida que verá en pantalla es la línea que indica la creación del archivo especificado, después de correr el programa verifique en su directorio de trabajo la existencia del archivo prueba.htm. Por la extensión utilizada es fácil suponer que se trata de un pequeño archivo web, su navegador lo puede visualizar de la forma convencional, pero también puede abrir éste archivo con un editor de texto común (como Notepad), entonces se dará cuenta que el código HTML está inconcluso,este" problemita" lo resolveremos más adelante por lo que le recomiendo que conserve éste archivo pues se utilizará en las prácticas que siguen.Volver al principioConcatenar datosComo vimos en el programa anterior, el archivo generado llamado prueba.htm está Inconcluso así que es hora de corregir ésta situación, lo haremos utilizando el código que Sigue el cual hace uso del atributo para concatenar datos y además utilizaremos una nueva función para escribir en el archivo un solo dato a la vez:#include <stdio.h>#include <string.h>#include <stdlib.h>int main(){ FILE *final; final = fopen(" Prueba.htm" , " a" ); /* Abrir archivo para concatenar */ if (final == NULL) { printf(" Falla al abrir el archivo " ); exit (EXIT_FAILURE); } putc(' ', final); putc('<', final); putc('/', final); putc('B', final); putc('O', final); putc('D', final); putc('Y', final); putc('>', final); putc(' ', final); putc('<', final); putc('/', final); putc('H', final); putc('T', final); putc('M', final); putc('L', final); putc('>', final); putc(' ', final); fclose(final); return EXIT_SUCCESS;}En primer lugar observe que en este programa se efectúa la verificación del éxito al abrir el archivo, la constante llamada EXIT_FAILURE está definida en el archivo de cabecera stdlib.h generalmente con el valor de 1. La constante llamada EXIT_SUCESS a su vez está definida generalmente con el valor de 0. El sistema operativo puede utilizar el valor retornado para determinar si el programa está operando normalmente ó si es necesario tomar alguna acción correctiva, por ejemplo, si un programa se ejecuta en dos partes y la primera de ellas retorna un valor de error, entonces no hay necesidad de ejecutar la segunda parte del programa.La función putc ( )La parte del programa que nos interesa es la función llamada putc ( ) ejemplificada de la línea 16 a la 32, ésta función extrae al archivo un carácter a la vez, el caracter en cuestión es el primer argumento de la función y el puntero de archivo el segundo y último argumento dentro del paréntesis. Observe que para especificar un caracter determinado se utiliza la comilla sencilla, incluyendo el caso del caracter de retorno de carro ' '. Compile y ejecute el programa. Antes de correr el programa asegurese de la existencia del archivo prueba.htm en su directorio de trabajo, generado en el programa anterior, después de correr el programa, abra el archivo con un editor de texto y observe que ahora el documento web está completo.Volver al principioLectura de un archivoComo ya tenemos un archivo para leer podemos utilizar un nuevo programa, como en los Programas anteriores, éste empieza con algunas declaraciones y abriendo el archivo prueba.htm especificando que deseamos efectuar operaciones de lectura mediante el atributo " r" , el programa ejecuta un bucle do while para leer del archivo un solo carácter a la vez y desplegarlo en pantalla hasta detectar un caracter EOF (End Of File, Fin de Archivo). Por último cerramos el archivo y el programa termina.#include <stdio.h>#include <stdlib.h>int main(){ FILE *nombre; int c; nombre = fopen(" Prueba.htm" , " r" ); if (nombre == NULL) { printf(" El archivo no existe " ); exit (EXIT_FAILURE); } else { do { c = getc(nombre); /* Obtiene un caracter del archivo */ putchar(c); /* Lo despliega en pantalla y continua... */ } while (c != EOF); /* hasta encontrar EOF (el final del archivo)*/ } fclose(nombre); return EXIT_SUCCESS;}En este punto afrontamos un problema común en programación C. La variable regresada por la función getc ( ) es un caracter, por lo que podemos utilizar para el propósito una variable de tipo char, el problema empieza si tratamos de utilizar una variable de tipo unsigned char, ya que C regresa -1 para EOF. Una variable de tipo unsigned char no puede contener valores negativos ya que su rango está entre 0 y 255 por lo que retornará 255 para un valor negativo valor que no compara con EOF, en este caso el programa nunca terminará. Para prevenir esta situación, utilice una variable de tipo int, ya que este tipo de variable siempre incluye el signo. En este programa leimos del archivoun caracter a la vez, en el siguiente leeremos una palabra a la vez.Lectura de una palabraEl siguiente programa es prácticamente igual que el anterior excepto que ésta vez se utiliza la función fscanf ( ) para leer una cadena a la vez, como fscanf ( ) detiene la lectura de caracteres al encontrar un caracter de espacio ó uno de nueva línea, lee por lo tanto una palabra a la vez desplegando los resultados en una palabra por línea, el nuevo código es:#include <stdio.h>int main(){ FILE *fp1; char palabra[100]; int c; fp1 = fopen(" Prueba.htm" , " r" ); do { /* Obtiene una palabra del archivo */ c = fscanf(fp1, " %s" , palabra); printf(" %s " , palabra); /* la despliega en pantalla */ } while (c != EOF); /* Se repite hasta encontrar EOF */ fclose(fp1); return 0;}Al ejecutar éste programa la salida es la siguiente: El problema es que se imprime dos veces la última palabra, para resolver este detalle modificamos el anterior código así:#include <stdio.h>int main(){ FILE *fp1; char palabra[100]; int c; fp1 = fopen(" Prueba.htm" , " r" ); do { /* Obtiene una palabra del archivo */ c = fscanf(fp1, " %s" , palabra); if (c != EOF) printf(" %s " , palabra); /* La despliega en pantalla */ } while (c != EOF); /* Se repite hasta encontrar EOF */ fclose(fp1); return 0;}Es bueno hacer notar que un programador experimentado no escribiría el código como lo hicimos en el ejemplo ya que compara c con EOF dos veces por cada ciclo del bucle y esto es ineficiente. Utilizamos código que trabaja y es fácil de leer pero conforme usted gane experiencia en C, Usted utilizará métodos más eficientes de codificar, aunque sean más difíciles de leer, por ejemplo:while((c = fscanf(fp1, " %s" , palabra) != EOF){ printf(" %s " , palabra);}Lectura de una líneaSiguiendo la misma secuencia de los ejemplos de éste capítulo, analizaremos la forma de leer una línea completa de texto, para esto tenemos el código que detallo enseguida:#include <stdio.h>#include <stdlib.h>int main(){ FILE *fp1; char palabra[100]; char *c; fp1 = fopen(" Prueba.htm" , " r" ); if (fp1 == NULL) { printf(" Error al abrir el archivo " ); exit (EXIT_FAILURE); } do { c = fgets(palabra, 100, fp1); /* Obtiene una linea del archivo */ if (c != NULL) printf(" %s" , palabra); /* La despliega en pantalla */ } while (c != NULL); /* Se repite hasta encontrar NULL */ fclose(fp1); return EXIT_SUCCESS;}Ahora utilizamos la función fgets ( ) la cual lee una línea completa, incluyendo el carácterde nueva línea y coloca los datos en un buffer (espacio de memoria RAM temporal). El buffer a ser leído es el primer argumento en la llamada a la función en tanto que el máximo número de caracteres a ser leídos es el segundo argumento, seguido por el puntero de archivo. Esta función leerá caracteres en el buffer hasta que encuentre el caracter de nueva línea, ó lea el máximo número de caracteres menos uno, lo que ocurraprimero. El espacio final se reserva para el caracter nulo (NULL) del fin de la cadena. Además, si se encuentra un EOF, la función retorna NULL. NULL está definido a cero en elarchivo stdio.hLos ejemplos de éste capítulo realmente no requieren de mucha explicación, el código lo podemos modificar para introducir el nombre del archivo que deseamos abrir de ésta forma:#include <stdio.h>#include <stdlib.h>int main(){ FILE *fp1; char palabra[100], nombre[25]; char *c; printf(" Introduzca el nombre del archivo -> " ); scanf(" %s" , nombre); /* Lee el archivo deseado */ fp1 = fopen(nombre, " r" ); if (fp1 == NULL) { printf(" Error al abrir el archivo " ); exit (EXIT_FAILURE); } do { c = fgets(palabra, 100, fp1); /* Obtiene una linea del archivo */ if (c != NULL) printf(" %s" , palabra); /* La despliega en pantalla */ } while (c != NULL); /* Hasta encontrar NULL */ fclose(fp1); return EXIT_SUCCESS;}La salida del programa es la siguiente:Volver al principioAsignación especialA lo largo de este capítulo hemos tratado el uso de diferentes funciones para operaciones de lectura y escritura, se trata de un tema particularmente útil en el desarrollo de un programa. Como seguramente habrá notado, utilizamos para los ejemplos un archivo llamado Prueba.htm, por la extensión utilizada y por la naturaleza del texto incluído en el mismo sabemos que se trata de un documento web que puede ser visualizado en su navegador. Para terminar este capítulo y a manera de resumen que a la vez nos sirva de introducción al siguiente capítulo, le presento el siguiente código que Yo espero despierte en Usted un poco (ó un mucho) de curiosidad, experimente con el programa y si Usted desea, mándeme su opinión por correo electrónico.#include <stdio.h>#include <stdlib.h>enum HTMLid{ HTML_NINGUNO, HTML_BODY, HTML_cBODY, HTML_B, HTML_cB, HTML_HTML, HTML_cHTML, HTML_CENTER, HTML_cCENTER};static struct{ char *htmlcodigo; enum HTMLid id;}lista_de_codigos[]={ {" <HTML>" , HTML_HTML}, {" </HTML>" , HTML_cHTML}, {" <BODY>" , HTML_BODY}, {" </BODY>" , HTML_cBODY}, {" <CENTER>" , HTML_CENTER}, {" </CENTER>" , HTML_cCENTER}, {" <B>" , HTML_B}, {" </B>" , HTML_cB}, {NULL, HTML_NINGUNO}};char texto[128];int itexto=0, c;int main(){ int i, ietiqueta=0; char etiqueta[64]; FILE *archivo; enum HTMLid codigo; archivo = fopen(" Prueba.htm" , " r" ); /* Abre el archivo para lectura */ if (archivo == NULL) { printf(" El archivo no existe... " ); exit (EXIT_FAILURE); } else { do /* Checa todos los caracteres del archivo */ { c=getc(archivo); if (c=='<') /* Lee la etiqueta html */ { /* incluye el principio de la etiqueta */ etiqueta[ietiqueta++]=c; do { c=getc(archivo); etiqueta[ietiqueta++]=c; } while(c!='>'); etiqueta[ietiqueta]=0; codigo=HTML_NINGUNO; for(i=0; lista_de_codigos[i].htmlcodigo!=NULL; i++) { if(stricmp(etiqueta, lista_de_codigos[i].htmlcodigo)==0) { codigo=lista_de_codigos[i].id; break; } } switch (codigo) { case HTML_NINGUNO: break; case HTML_HTML: printf(" Empieza el documento web " ); break; case HTML_cHTML: printf(" Fin del documento web " ); break; case HTML_B: printf(" Empieza la etiqueta B " ); break; case HTML_cB: printf(" Termina la etiqueta B " ); break; case HTML_BODY: printf(" Empieza la etiqueta BODY " ); break; case HTML_cBODY: printf(" Termina la etiqueta BODY " ); break; case HTML_CENTER: printf(" Empieza la etiqueta CENTER " ); break; case HTML_cCENTER: printf(" Termina la etiqueta CENTER " ); break; } ietiqueta=0; } else rollo(); } while(c!=EOF); } fclose(archivo); texto[itexto]=0; printf(texto); return EXIT_SUCCESS;}rollo(){ texto[itexto++]=c;}La salida del programa es la siguiente:Volver al principio© 1998, 1999 Virgilio Gómez Negrete, Derechos Reservados <br />Aspectos Generales:<br />URL: http://www.modelo.edu.mx/univ/virtech/prograc/clecesc.htm#superior <br />Utilización en el Aula:<br />Tipología: <br />Hecha por :Virgilio Gómez Negrete.No especifica su cargo o grado de Instrucción.<br />Destinatario: La página fue pensada para ser usada por alumnos de niveles avanzados, especialistas e investigadores y estudiantes.<br />Nivel: usuarios de nivel superior, estudiantes y profesionales.<br />Actividades: El sitio incluye actividades para realizar con los alumnos.<br />La página cuenta con diversos recursos y herramientas que permiten la interacción, más no la descarga de materiales y suscripción a revistas. Está destinada principalmente a profesionales de la educación, siendo el nivel académico de sus contenidos en el área de educación profesional o superior. La página fue hecha en ciudad de México.<br />Aspectos Curriculares:<br />Interés para el Profesorado y Estudiantil : La página sirve para uso del docente, y usuario común o estudiantil. <br />La página no permite descarga de materiales, libros digitales y si hay vínculos hacia otras páginas.<br />Aspectos Gráficos:<br />El entorno estático está diseñado con una fuente de tamaño normal para su lectura, los colores son suaves lo cual hace agradable la interfaz y posee imágenes.<br />En relación al entorno dinámico, posee ningún elemento animado.<br />No tiene elementos multimedia, tales como videos, archivos de imágenes o sonidos.<br />Aspectos Técnicos: <br />Libertad de Acceso: El acceso a la página es gratis y los usuarios no pueden suscribir a un envío de noticias vía correo electrónico para enterarse de las novedades de allí descritas.<br />Publicidad: no cuenta con enlaces a cursos pagos y promoción de eventos ni posee spam de publicidad.<br />Navegabilidad: si posee hipervínculos o enlaces dentro de la página. La navegabilidad en la página se hace ligera y no tarda en cargar , los vínculos uno solo no está correctamente activos.<br />Interactividad: No posee, foros, chat, si posee posibilidad de envío de mensajes, no cuenta con cuestionarios. No tiene un blog y si un correo de contacto.<br />Conclusión:<br />La página se adapta un poco más a los requerimientos académicos de la asignatura pero no totalmente lo que será utilizada como material de consulta para el profesor. <br />Ejemplo de página 3:<br />Previo: HYPERLINK " http://www.fismat.umich.mx/mn1/manual/manual.html" Manual de C Arriba: HYPERLINK " http://www.fismat.umich.mx/mn1/manual/manual.html" Manual de C Siguiente: HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node2.html" 1. Compilación de un programa <br />Regresar <br />Índice General <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node2.html" 1. Compilación de un programa en C/C++ <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node2.html" l " SECTION00210000000000000000" 1.1 Creación, compilación y ejecución de un programa <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node2.html" l " SECTION00211000000000000000" 1.1.1 Creación del programa <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node2.html" l " SECTION00212000000000000000" 1.1.2 Compilación <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node2.html" l " SECTION00213000000000000000" 1.1.3 Ejecución del programa <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node2.html" l " SECTION00220000000000000000" 1.2 El modelo de compilación de C <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node2.html" l " SECTION00230000000000000000" 1.3 El preprocesador <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node2.html" l " SECTION00240000000000000000" 1.4 Compilador de C <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node2.html" l " SECTION00250000000000000000" 1.5 Ensamblador <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node2.html" l " SECTION00260000000000000000" 1.6 Ligador <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node2.html" l " SECTION00270000000000000000" 1.7 Algunas opciones útiles del compilador <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node2.html" l " SECTION00280000000000000000" 1.8 Uso de las bibliotecas <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node2.html" l " SECTION00290000000000000000" 1.9 Ejemplos <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node2.html" l " SECTION00291000000000000000" 1.9.1 Creación de una biblioteca estática <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node2.html" l " SECTION00292000000000000000" 1.9.2 Creación de una biblioteca compartida <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node2.html" l " SECTION002100000000000000000" 1.10 Funciones de la biblioteca de UNIX <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node2.html" l " SECTION002101000000000000000" 1.10.1 Encontrando información acerca de las bibliotecas. <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node2.html" l " SECTION002110000000000000000" 1.11 Ejercicios <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node3.html" 2. Principios de C <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node3.html" l " SECTION00310000000000000000" 2.1 Orígenes del C <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node3.html" l " SECTION00320000000000000000" 2.2 Características de C <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node3.html" l " SECTION00330000000000000000" 2.3 Estructura de un programa en C <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node3.html" l " SECTION00340000000000000000" 2.4 Variables <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node3.html" l " SECTION00341000000000000000" 2.4.1 Definición de variables globales <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node3.html" l " SECTION00342000000000000000" 2.4.2 Lectura y escritura de variables <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node3.html" l " SECTION00350000000000000000" 2.5 Constantes <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node3.html" l " SECTION00360000000000000000" 2.6 Operadores Aritméticos <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node3.html" l " SECTION00370000000000000000" 2.7 Operadores de Comparación <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node3.html" l " SECTION00380000000000000000" 2.8 Operadores lógicos <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node3.html" l " SECTION00390000000000000000" 2.9 Orden de precedencia <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node3.html" l " SECTION003100000000000000000" 2.10 Ejercicios <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node4.html" 3. Estructuras Condicionales <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node4.html" l " SECTION00410000000000000000" 3.1 La sentencia if <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node4.html" l " SECTION00420000000000000000" 3.2 El operador ? <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node4.html" l " SECTION00430000000000000000" 3.3 La sentencia switch <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node4.html" l " SECTION00440000000000000000" 3.4 Ejercicios <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node5.html" 4. Iteración <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node5.html" l " SECTION00510000000000000000" 4.1 La sentencia for <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node5.html" l " SECTION00520000000000000000" 4.2 La sentencia while <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node5.html" l " SECTION00530000000000000000" 4.3 La sentencia do-while <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node5.html" l " SECTION00540000000000000000" 4.4 Uso de break y continue <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node5.html" l " SECTION00550000000000000000" 4.5 Ejercicios <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node6.html" 5. Arreglos y cadenas <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node6.html" l " SECTION00610000000000000000" 5.1 Arreglos unidimensionales y multidimensionales <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node6.html" l " SECTION00620000000000000000" 5.2 Cadenas <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node6.html" l " SECTION00630000000000000000" 5.3 Ejercicios <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node7.html" 6. Funciones <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node7.html" l " SECTION00710000000000000000" 6.1 Funciones void <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node7.html" l " SECTION00720000000000000000" 6.2 Funciones y arreglos <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node7.html" l " SECTION00730000000000000000" 6.3 Prototipos de funciones <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node7.html" l " SECTION00740000000000000000" 6.4 Ejercicios <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node8.html" 7. Más tipos de datos <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node8.html" l " SECTION00810000000000000000" 7.1 Estructuras <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node8.html" l " SECTION00811000000000000000" 7.1.1 Definición de nuevos tipos de datos <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node8.html" l " SECTION00820000000000000000" 7.2 Uniones <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node8.html" l " SECTION00830000000000000000" 7.3 Conversión de tipos (casts) <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node8.html" l " SECTION00840000000000000000" 7.4 Enumeraciones <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node8.html" l " SECTION00850000000000000000" 7.5 Variables estáticas <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node8.html" l " SECTION00860000000000000000" 7.6 Ejercicios <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node9.html" 8. Apuntadores <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node9.html" l " SECTION00910000000000000000" 8.1 Definición de un apuntador <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node9.html" l " SECTION00920000000000000000" 8.2 Apuntadores y Funciones <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node9.html" l " SECTION00930000000000000000" 8.3 Apuntadores y arreglos <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node9.html" l " SECTION00940000000000000000" 8.4 Arreglos de apuntadores <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node9.html" l " SECTION00950000000000000000" 8.5 Arreglos multidimensionales y apuntadores <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node9.html" l " SECTION00960000000000000000" 8.6 Inicialización estática de arreglos de apuntadores <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node9.html" l " SECTION00970000000000000000" 8.7 Apuntadores y estructuras <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node9.html" l " SECTION00980000000000000000" 8.8 Fallas comunes con apuntadores <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node9.html" l " SECTION00990000000000000000" 8.9 Ejercicios <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node10.html" 9. Asignación dinámica de memoria y Estructuras dinámicas <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node10.html" l " SECTION001010000000000000000" 9.1 Uso de malloc, sizeof y free <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node10.html" l " SECTION001020000000000000000" 9.2 calloc y realloc <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node10.html" l " SECTION001030000000000000000" 9.3 Listas ligadas <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node10.html" l " SECTION001040000000000000000" 9.4 Programa de revisión <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node10.html" l " SECTION001050000000000000000" 9.5 Ejercicios <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node11.html" 10. Tópicos avanzados con apuntadores <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node11.html" l " SECTION001110000000000000000" 10.1 Apuntadores a apuntadores <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node11.html" l " SECTION001120000000000000000" 10.2 Entrada en la línea de comandos <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node11.html" l " SECTION001130000000000000000" 10.3 Apuntadores a funciones <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node11.html" l " SECTION001140000000000000000" 10.4 Ejercicios <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node12.html" 11. Operadores de bajo nivel y campos de bit <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node12.html" l " SECTION001210000000000000000" 11.1 Operadores sobre bits <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node12.html" l " SECTION001220000000000000000" 11.2 Campos de bit <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node12.html" l " SECTION001221000000000000000" 11.2.1 Portabilidad <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node12.html" l " SECTION001230000000000000000" 11.3 Ejercicios <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node13.html" 12. El preprocesador de C <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node13.html" l " SECTION001310000000000000000" 12.1 Directivas del preprocesador <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node13.html" l " SECTION001311000000000000000" 12.1.1 #define <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node13.html" l " SECTION001312000000000000000" 12.1.2 #undef <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node13.html" l " SECTION001313000000000000000" 12.1.3 #include <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node13.html" l " SECTION001314000000000000000" 12.1.4 #if Inclusión condicional <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node13.html" l " SECTION001320000000000000000" 12.2 Control del preprocesador del compilador <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node13.html" l " SECTION001330000000000000000" 12.3 Otras directivas del preprocesador <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node13.html" l " SECTION001340000000000000000" 12.4 Ejercicios <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node14.html" 13. C, UNIX y las bibliotecas estándar <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node14.html" l " SECTION001410000000000000000" 13.1 Ventajas del usar UNIX con C <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node14.html" l " SECTION001420000000000000000" 13.2 Uso de funciones de bibliotecas y llamadas del sistema <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node15.html" 14. Biblioteca <stdlib.h> <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node15.html" l " SECTION001510000000000000000" 14.1 Funciones aritméticas <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node15.html" l " SECTION001520000000000000000" 14.2 Números aleatorios <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node15.html" l " SECTION001530000000000000000" 14.3 Conversión de cadenas <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node15.html" l " SECTION001540000000000000000" 14.4 Búsqueda y ordenamiento <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node15.html" l " SECTION001550000000000000000" 14.5 Ejercicios <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node16.html" 15. Biblioteca <math.h> <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node16.html" l " SECTION001610000000000000000" 15.1 Funciones matemáticas <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node16.html" l " SECTION001620000000000000000" 15.2 Constantes matemáticas <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node17.html" 16. Entrada y salida (E/S) stdio.h <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node17.html" l " SECTION001710000000000000000" 16.1 Reportando errores <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node17.html" l " SECTION001711000000000000000" 16.1.1 perror() <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node17.html" l " SECTION001712000000000000000" 16.1.2 errno <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node17.html" l " SECTION001713000000000000000" 16.1.3 exit <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node17.html" l " SECTION001720000000000000000" 16.2 Flujos <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node17.html" l " SECTION001721000000000000000" 16.2.1 Flujos predefinidos <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node17.html" l " SECTION001730000000000000000" 16.3 E/S Basica <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node17.html" l " SECTION001740000000000000000" 16.4 E/S formateada <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node17.html" l " SECTION001741000000000000000" 16.4.1 printf <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node17.html" l " SECTION001742000000000000000" 16.4.2 scanf <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node17.html" l " SECTION001750000000000000000" 16.5 Archivos <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node17.html" l " SECTION001751000000000000000" 16.5.1 Lectura y escritura de archivos <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node17.html" l " SECTION001760000000000000000" 16.6 sprintf y sscanf <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node17.html" l " SECTION001761000000000000000" 16.6.1 Petición del estado del flujo <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node17.html" l " SECTION001770000000000000000" 16.7 E/S de bajo nivel o sin almacenamiento intermedio <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node17.html" l " SECTION001780000000000000000" 16.8 Ejercicios <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node18.html" 17. Manejo de cadenas <string.h> <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node18.html" l " SECTION001810000000000000000" 17.1 Funciones básicas para el manejo de cadenas <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node18.html" l " SECTION001811000000000000000" 17.1.1 Búsqueda en cadenas <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node18.html" l " SECTION001820000000000000000" 17.2 Prueba y conversión de caracteres <ctype.h> <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node18.html" l " SECTION001830000000000000000" 17.3 Operaciones con la memoria <memory.h> <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node18.html" l " SECTION001840000000000000000" 17.4 Ejercicios <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node19.html" 18. Acceso de Archivos y llamadas al sistema de directorios <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node19.html" l " SECTION001910000000000000000" 18.1 Funciones para el manejo de directorios <unistd.h> <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node19.html" l " SECTION001911000000000000000" 18.1.1 Busqueda y ordenamiento de directorios: sys/types.h,sys/dir.h <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node19.html" l " SECTION001920000000000000000" 18.2 Rutinas de manipulación de archivos: unistd.h, sys/types.h, sys/stat.h <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node19.html" l " SECTION001921000000000000000" 18.2.1 Permisos de accesos a archivos <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node19.html" l " SECTION001922000000000000000" 18.2.2 Estado de un archivo <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node19.html" l " SECTION001923000000000000000" 18.2.3 Manipulación de archivos: stdio.h, unistd.h <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node19.html" l " SECTION001924000000000000000" 18.2.4 Creación de archivos temporales: <stdio.h> <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node19.html" l " SECTION001930000000000000000" 18.3 Ejercicios <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node20.html" 19. Funciones para el tiempo <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node20.html" l " SECTION002010000000000000000" 19.1 Funciones básicas para el tiempo <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node20.html" l " SECTION002020000000000000000" 19.2 Ejemplos de aplicaciones de funciones del tiempo. <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node20.html" l " SECTION002021000000000000000" 19.2.1 Ejemplo 1: Tiempo (en segundos) para hacer algún cálculo. <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node20.html" l " SECTION002022000000000000000" 19.2.2 Ejemplo 2: Inicializar la semilla de un número aleatorio. <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node20.html" l " SECTION002030000000000000000" 19.3 Ejercicios <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node21.html" 20. Control de procesos: <stdlib.h>, <unistd.h> <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node21.html" l " SECTION002110000000000000000" 20.1 Ejecutando comandos de UNIX desde C <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node21.html" l " SECTION002120000000000000000" 20.2 execl() <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node21.html" l " SECTION002130000000000000000" 20.3 fork() <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node21.html" l " SECTION002140000000000000000" 20.4 wait() <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node21.html" l " SECTION002150000000000000000" 20.5 exit() <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node21.html" l " SECTION002160000000000000000" 20.6 Ejercicios <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node22.html" 21. Compilación de Programas con Archivos Múltiples <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node22.html" l " SECTION002210000000000000000" 21.1 Archivos Cabezera <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node22.html" l " SECTION002220000000000000000" 21.2 Variables y Funciones Externas <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node22.html" l " SECTION002221000000000000000" 21.2.1 Alcance de las variables externas <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node22.html" l " SECTION002230000000000000000" 21.3 Ventajas de Usar Varios Archivos <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node22.html" l " SECTION002240000000000000000" 21.4 Como dividir un programa en varios archivos <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node22.html" l " SECTION002250000000000000000" 21.5 Organización de los Datos en cada Archivo <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node22.html" l " SECTION002260000000000000000" 21.6 La utilería Make <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node22.html" l " SECTION002261000000000000000" 21.6.1 Programando Make <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node22.html" l " SECTION002270000000000000000" 21.7 Creación de un Archivo Make (Makefile) <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node22.html" l " SECTION002280000000000000000" 21.8 Uso de macros con Make <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node22.html" l " SECTION002290000000000000000" 21.9 Ejecución de Make <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node23.html" 22. Comunicación entre procesos (IPC Interprocess Communication), PIPES <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node23.html" l " SECTION002310000000000000000" 22.1 Entubando en un programa de C <stdio.h> <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node23.html" l " SECTION002311000000000000000" 22.1.1 popen() Tubería formateada <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node23.html" l " SECTION002312000000000000000" 22.1.2 pipe() Tubería de bajo nivel <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node24.html" 23. Sockets <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node24.html" l " SECTION002410000000000000000" 23.1 Creación y nombrado de sockets <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node24.html" l " SECTION002420000000000000000" 23.2 Conectando sockets de flujo <br /> HYPERLINK " http://www.fismat.umich.mx/mn1/manual/node24.html" l " SECTION002421000000000000000" 23.2.1 Transferencia de datos en un flujo y cerrado <br />Última modificación : 2005-08-12Héctor Tejeda Vhtejeda@fismat.umich.mx <br />Aspectos Generales:<br />URL: http://www.fismat.umich.mx/mn1/manual/node1.html<br />Utilización en el Aula:<br />Tipología: <br />Hecha por : Héctor Tejeda V. No especifica su cargo o grado de Instrucción.<br />Destinatario: La página fue pensada para ser usada por alumnos de niveles avanzados, especialistas e investigadores y estudiantes.<br />Nivel: usuarios de nivel superior, estudiantes y profesionales.<br />Actividades: El sitio no incluye actividades para realizar con los alumnos.<br />La página no cuenta con diversos recursos y herramientas que permiten la interacción, más no la descarga de materiales y suscripción a revistas. Está destinada principalmente a profesionales de la educación, siendo el nivel académico de sus contenidos en el área de educación profesional o superior. La página fue hecha en ciudad de México.<br />Aspectos Curriculares:<br />Interés para el Profesorado y Estudiantil: La página sirve para uso del docente, y usuario común o estudiantil. <br />La página no permite descarga de materiales, libros digitales y si hay vínculos hacia otras páginas.<br />Aspectos Gráficos:<br />El entorno estático está diseñado con una fuente de tamaño normal para su lectura, los colores son suaves lo cual hace agradable la interfaz y no posee imágenes.<br />En relación al entorno dinámico, no posee ningún elemento animado.<br />No tiene elementos multimedia, tales como videos, archivos de imágenes o sonidos.<br />Aspectos Técnicos: <br />Libertad de Acceso: El acceso a la página es gratis y los usuarios no pueden suscribir a un envío de noticias vía correo electrónico para enterarse de las novedades de allí descritas.<br />Publicidad: no cuenta con enlaces a cursos pagos y promoción de eventos ni posee spam de publicidad.<br />Navegabilidad: si posee hipervínculos o enlaces dentro de la página. La navegabilidad en la página se hace ligera y no tarda en cargar, los vínculos están correctamente activos.<br />Interactividad: No posee, foros, chat, si posee posibilidad de envío de mensajes, no cuenta con cuestionarios. No tiene un blog y si posee un correo de contacto.<br />Conclusión:<br />La página se adapta un poco más a los requerimientos académicos de la asignatura pero no totalmente por lo que será utilizada solo como material de consulta para el profesor.<br />

×