Diseño de Ensamblador

Iniciado por m@o_614, 9 Diciembre 2013, 16:56 PM

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

m@o_614

Saludos

tengo que crear un programa que identifique las partes de una línea en lenguaje ensamblador, y para esto me dicen que necesito tener un archivo de texto creado previamente y

Leer línea a línea el archivo, pudiendo:
a. Leer cada línea directamente del archivo, de una por una y procesar cada línea que se va leyendo.
b. Leer todo el archivo con un ciclo y conforme se lee el archivo almacenarlo en una estructura de datos temporal, posteriormente leer de esta estructura de datos

Me dice que en ambos casos hay ventajas y desventajas. Deberás elegir la que sea más conveniente, recuerda que el  programa debe de irse completando con las siguientes practicas.

¿cuales son estas ventajas y desventajas?,¿Cuál de estas opciones es la mejor y la más fácil de implementar?, No quiero que me hagan la tarea solo que me den una ligera idea de como seria

gracias

amchacon

#1
La primera le llamo yo "streaming" y tiene la ventaja que te sirve para cualquier tamaño de archivo.

La segunda es más rápida, ya que vuelcas el archivo en la memoria y trabajas todo el tiempo desde allí. Claro que esto funciona si el archivo es de unos kb, no vas a volcar un archivo de 2gb en la memoria.

Las dos tienen la misma dificultad de implementación, yo me quedaría con la primera.
Por favor, no me manden MP con dudas. Usen el foro, gracias.

¡Visita mi programa estrella!

Rar File Missing: Esteganografía en un Rar

m@o_614

#2
Muchas gracias amchacon por tu respuesta, otra duda:

en la segunda opción me dice que lea todo el archivo en un solo ciclo, y que lo guarde  en una estructura, ¿con esto se refiere a que ya no voy a leer el archivo línea por línea?, o sea voy a tener que almacenar el archivo completo en la estructura y en la primera opción trabajo línea con línea sin almacenar nada?

Es que yo pensé que la mejor opción sería ir guardando línea por línea en un arreglo, y después hacer las validaciones de las palabras que están en los arreglos.

de antemano gracias

amchacon

#3
Cita de: m@o_614 en 10 Diciembre 2013, 02:03 AMEs que yo pensé que la mejor opción sería ir guardando línea por línea en un arreglo, y después hacer las validaciones de las palabras que están en los arreglos.
Pero entonces pierdes la ventaja de la velocidad al leerlo línea a línea, para eso usas el primer método y te ahorras el gasto de memoria.

Hay muchas formas de volcar un archivo, te lo pongo como lo haría yo (volcandolo en un stringstream y listo):

Código (cpp) [Seleccionar]
#include <iostream>
#include <fstream>
#include <sstream>
using namespace std;

int main()
{
   ifstream archivo("main.cpp");
   stringstream archivo2;

   archivo2<<archivo.rdbuf(); // volcar contenido en stream

   cout<<archivo2.str(); // .str() devuelve el string que se encuentra almacenado
   return 0;
}


http://imageshack.us/photo/my-images/801/f04f.png/

Como veras en la imagen, he volcado el archivo del código en el stringstream.

La ventaja que tiene usar un stringstream, esque puedes seguir usando las funciones de getline() y el operador <<, lo que te hace el trabajo más comodo. Si lo volcases en un char*/string a secas tendrías que detectar los saltos de línea a mano.
Por favor, no me manden MP con dudas. Usen el foro, gracias.

¡Visita mi programa estrella!

Rar File Missing: Esteganografía en un Rar

m@o_614

 :o nunca se me hubiera ocurrido hacerlo de esa manera, de hecho no sabía ni que era un stringstream y tampoco había visto las funciones rdbuf()... yo pense que iba a ser más fácil la implementación de la segunda opción, ir leyendo el archivo linea por linea e ir guardando en un buffer el tamaño(num de caracteres) de cada línea del archivo, y despues volver a leer el archivo pero esta vez dando brincos del tamaño de cada línea con el fseek(),para guardalos en otro buffer,pero el problema es que en la segunda función se cicla y no me hace lo que le pido, no entiendo por qué??

#include <stdio.h>
#include <stdlib.h>
#define MAX 100

void verificarLineas(FILE *fd,int buffer[],int renglon);

int main()
{
    FILE *fd;
    int car,tam,renglon = 0,buffer[MAX];
    if((fd = fopen("P1ASM.txt","r"))!= NULL)
    {
        while((car = fgetc(fd))!= EOF)
        {
            tam = 0;
            fseek(fd,-1,SEEK_CUR);
            while((car = fgetc(fd))!= '\n'&&(!feof(fd)))
            {
                tam++;
                printf("%c",car);
            }
            printf("*%d\n",tam+1);
            buffer[renglon++] = tam;
        }
        verificarLineas(fd,buffer,renglon);
    }
    else
       printf("No se pudo abrir el archivo");
    return 0;
}

void verificarLineas(FILE *fd,int buffer[],int renglon)
{
    int i = 0;
    char *linea;
    fseek(fd,0,SEEK_SET);
    while(!feof(fd))
    {
        linea = (char*)malloc(buffer[i]*sizeof(char));
        fgets(linea,buffer[i]+1,fd);
        printf("%s\n",linea);
        fseek(fd,buffer[i]+1,SEEK_CUR);
        free(linea);
        i++;
    }
}


gracias

amchacon

Ah usas C, creía que usabas C++. Entonces no he hecho más que confudirte  :silbar:

En C lo haría tal que así:

FILE* archivo = fopen("PLASM.txt","r");

fseek(archivo,0,SEEK_END);
long tamanyo = ftell(archivo);
fseek(archivo,0,SEEK_SET);

char* cadena = malloc(tamanyo);
fread (cadena,tamanyo,1,archivo);
fclose(archivo);


El método que tú dices es rizar el rizo, y tampoco es eficiente ni nada. Quizás lo más cómodo para ti sea la primera opción:

FILE* archivo = fopen("PLASM.txt","r");
char cadena[256];

while (!feof(archivo))
{
     fgets(cadena,255,archivo); // lee una línea del archivo, máximo a leer 255 caracteres

    // haz lo que quieras con esta linea

}

fclose(archivo);
Por favor, no me manden MP con dudas. Usen el foro, gracias.

¡Visita mi programa estrella!

Rar File Missing: Esteganografía en un Rar

m@o_614

muchas gracias amchacon yo creo que si voy a intentar hacerlo de la primera manera, solo que como en las especificaciones del programa venia que tengo que verificar si la línea es comentario, ETIQUETA, CODIGO DE OPERACION Y OPERANDOS. y para cada uno son como 6 especificaciones pense que seria más fácil si lo guardaba en una estructura, de la segunda manera ya vi cual era mi problema y lo corregi solo que me queda una duda:

#include <stdio.h>
#include <stdlib.h>
#define MAX 100

void verificarLineas(FILE *fd,int buffer[],int renglon);

int main()
{
    FILE *fd;
    int car,tam,renglon = 0,buffer[MAX];
    if((fd = fopen("P1ASM.txt","r"))!= NULL)
    {
        while((car = fgetc(fd))!= EOF)
        {
            tam = 0;
            fseek(fd,-1,SEEK_CUR);
            while((car = fgetc(fd))!= '\n'&&(!feof(fd)))
            {
                tam++;
                printf("%c",car);
            }
            printf("\n");
            buffer[renglon++] = tam;
        }
        verificarLineas(fd,buffer,renglon);
    }
    else
       printf("No se pudo abrir el archivo");
    return 0;
}

void verificarLineas(FILE *fd,int buffer[],int renglon)
{
    int i = 0,lon;
    char *linea;
    fseek(fd,0,SEEK_SET);
    printf("\n");
    while(!feof(fd))
    {
        lon = buffer[i]+1;//tamaño de buffer mas el salto de linea
        linea = (char*)malloc((lon+1)*sizeof(char));//lon mas el caracter '\0'
        fgets(linea,lon,fd);
        printf("%s",linea);
        free(linea);
        i++;
    }
}


de esta manera me imprime algunas  lineas con basura pero si esta linea de codigo la cambio y le pongo lon+1, ya me imprime correctamente, por que es esto??

lon = buffer[i]+1;//tamaño de buffer mas el salto de linea
        linea = (char*)malloc((lon+1)*sizeof(char));//lon mas el caracter '\0'
        fgets(linea,lon+1,fd);
        printf("%s",linea);
        free(linea);
        i++;

amchacon

Pero si has puesto tú mismo la explicación:
linea = (char*)malloc((lon+1)*sizeof(char));//lon mas el caracter '\0'

¿?
Por favor, no me manden MP con dudas. Usen el foro, gracias.

¡Visita mi programa estrella!

Rar File Missing: Esteganografía en un Rar

m@o_614

jaja cierto no me fije bien, ahora ya estoy empezando a hacer de nuevo el código como me dijiste con la primera opción, pero tengo una duda, por ejemplo si tengo una línea que es un comentario

;comentario numero1

y las instrucciones me dicen:
Las líneas de comentarios tienen las siguientes reglas:
a. empiezan con el caracter ;
b. ese caracter solo se puede encontrar en la primera posicion
c. Después del carácter ; puede seguir cualquier caracter, letras,digitos,etc..

pero si tengo la función de verificación asi:

int esComentario(FILE *fd)
{
    int car,continuar = 1;
    while((car = fgetc(fd))!= '\n')
    {
        if(car == ';')
           return 0;
    }
    return 1;
}


el programa no me va a recorrer todo la línea de código en caso de que se encuentre un ; intermedio y me returne inmediatamente que no es comentario, pero como le puedo hacer para que me lea todaaa la línea y que no solo se regrese con el return en los casos en que no es línea de comentario?? esto lo quiero hacer para que me vaya leyendo línea por línea desde el principio y para esto el while tiene que hacer completo el ciclo hasta que se encuentre el '\n'

gracias de nuevo