fopen函数将垃圾放在文件路径名上

时间:2015-09-11 00:47:06

标签: c arrays string fopen garbage

我正在用C.做练习。

程序接收文件名作为参数,不带扩展名(“p01”或“p02”等)。 程序必须打开三个名为(在输入“p01”的情况下)“p01_c.txt”,“p01_w.txt”和“p01_p.txt”的文件。 我将文件路径保留到p01进入字符串ruta“,然后在使用strcat()打开文件之前,将{_c.txt”,“_ w.txt”附加到fopen(ruta, "rb")

现在我的问题开始了:

1)在fopen()之后,ruta中出现了一些垃圾。

2)我无法剪切字符串,将\0放在我要剪切字符串的位置。

我在互联网上搜索了一个答案,但我没有找到任何答案,所以我第一次在这里询问。

这是我的代码:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

int main(int argc, char *argv[])
{
    if(argc<2) {
        printf("\nNo se ha introducido un fichero válido\n");
        return -1;
    } else {
        char ruta [] = "";
        strncat(ruta,argv[0],strlen(argv[0])-14);
        strcat(ruta,"knapsack\\");                    // knapsack is the folder containing th files
        strcat(ruta,argv[1]);                         //  now ruta is:  ...\knapsack\p01

        FILE * fCapacidad;
        strcat(ruta,"_c.txt");                        // ruta is: ... \knapsack\p01_c.txt
        printf("1- ruta is: %s\n",ruta);               // ruta is OK
        fCapacidad = fopen(ruta , "rb");
        if(fCapacidad == NULL){
            fputs ("\nNo se ha introducido un fichero válido de capacidad\n",stderr); exit(1);
        }

        FILE * fPesos;
        printf("2- ruta is: %s\n",ruta);                // ruta HAS GARBAGE!!!
        ruta[strlen(ruta-6)] = '\0';
        printf("3- ruta is: %s\n",ruta);               // ruta IS NOT CROPPED!!!
        strcat(ruta,"_w.txt");
        printf("4- ruta is: %s\n",ruta);             //_w.txt is appended to ruta (OK)
        fPesos = fopen(ruta, "rb");

输出是:

1- ruta is: E:\C Projects\MochilaEnC\bin\Debug\knapsack\p01_c.txt
2- ruta is: E:\C Projh>w\MochilaEnC\bin\Debug\knapsack\p01_c.txt
3- ruta is: E:\C Projh>w\MochilaEnC\bin\Debug\knapsack\p01_c.txt
4- ruta is: E:\C Projh>w\MochilaEnC\bin\Debug\knapsack\p01_c.txt_w.txt
No se ha introducido un fichero vßlido de pesos

1 个答案:

答案 0 :(得分:2)

char ruta[] = "";只为数组分配一个char。它与char ruta[1] = "";相同。连接到数组时,超出了数组的边界 使用char ruta[200] = "";将为数组分配200个字符并将数组初始化为空字符串。最多可将199个字符连接到阵列。您可以使用任何可满足您的内存需求的值,我只使用200作为示例。

'\0'分配给数组中的索引的另一个问题可以使用ruta[strlen(ruta) - 6] = '\0';来完成。最好验证ruta的长度至少为6,否则可能会得到负的索引。
在发布的代码中,6位于括号内ruta。这将取ruta的地址并减去6.然后strlen()将从该地址开始并尝试确定字符串的长度。任何结果都不是ruta的正确长度。