Защо rmdir премахва папка след излизане от програмата? (Използване на Dev C++ в Win7)


Опитвам се да напиша функция с име myremoved. Искам да премахне непразна папка.
Но сега имам проблем, когато използвам функцията (код по-долу), за да премахна всички файлове и папка, "rmdir" казва, че папката е премахната, но когато отворя Windows Explorer Видях папки, за които е съобщено, че са премахнати, все още съществуват там (опитвам се да осъществя достъп, но отказа.).

Това е кодът на функцията "myremove":

int myremove(char *dirname){
    /*
      myremove(Folder name):Remove all files and folders in that. 
    */
    DIR  *folder;  
    struct _finddata_t c_file; 
    char str[256]; 
    long hasfile; 
    int a,result=0;

    _chdir(dirname); 
    hasfile =_findfirst("*",&c_file);
    if(hasfile!=-1){
        do{
            str[0]='\0';
            strcat(str,c_file.name);
            if((strcmp(str,".")!=0)&&(strcmp(str,"..")!=0)) {
                //Is it a folder or not 
                if ((folder = opendir(c_file.name)) == NULL)    {         
                    //Not a folder,using remove to delete it
                    if((a=remove(c_file.name))==0){
                        printf("Remove: %s OK.\n",c_file.name);
                }else{
                        result=-1;
                        printf("Remove: %s Failed.\n",c_file.name);
                    }       
                }else{
                    closedir(folder);
                    if((a=myremove(c_file.name))!=0){result=-1;}
                }
            }
        }while( _findnext( hasfile, &c_file )==0 );
    }
    _chdir("..");
    if ((folder = opendir(dirname)) != NULL){
        if((a=rmdir(dirname))!=0){
            result=-1;
        printf("Remove: %s Failed.\n",c_file.name);
        }else{
            printf("Remove: %s OK.\n",c_file.name);
        }
    }
    return result;
}

int main()
{
    char dirname[256],ch;
    printf("Please enter the folder name which you want to remove:");
    gets(dirname);
    if (strlen(dirname)!=0){
        printf("Notice:It will remove %s folder and all things in this folder,sure to continue[Y/N]?",dirname);
        scanf("%c",&ch);
        if(ch=='Y'){
            if (myremove(dirname)==0){
                printf("Folder %s Removed.\n",dirname);
            }else{
                if (rmdir(dirname)==0){
                    printf("Folder %s Removed.\n",dirname);
                }else{
                    printf("Folder %s couldn't be removed.\n",dirname);
                }

            }
        }else if (ch=='N'){
            printf("User cancel, program will exit.\n");    
        }
}else{
        printf("Nothing input,program will exit.\n");
    }
    system("pause");
    return 0;
}

person UnciaX    schedule 10.05.2014    source източник
comment
Всъщност не отговарям на въпроса ви, но наистина ли е необходимо второто opendir обаждане? Мисля, че е излишно. Освен това, ако го премахнете, това може да реши проблема ви.   -  person anatolyg    schedule 10.05.2014
comment
Просто го пробвах, но пак не успя.   -  person UnciaX    schedule 10.05.2014
comment
Изглежда имате изтичане на ресурси във вашия клон if ((folder = opendir(c_file.name)) == NULL) . В истинския клон никога не затваряте директорията, отворена с opendir. Освен това операторът if не е добър начин да видите дали даден файл е директория или не. opendir ще се провали поради много причини, неуспехът, защото името на файла, което му давате, всъщност е директория, е само една възможност   -  person Brandin    schedule 10.05.2014
comment
И така, трябва да добавя израз в истинския клон, за да избегна, че наистина е папка?   -  person UnciaX    schedule 11.05.2014


Отговори (1)


Е, аз реших този проблем сам.
Защото използвам _findfirst и _findnext, но забравих да използвам _findclose.
Така че папката беше заключена до края на програмата.
Благодаря за помощ.

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


int myremove(char *dirname){
    DIR  *folder; 
    struct _finddata_t c_file; 
    char str[256];
    long hasfile; 
    int a,result=0;

    _chdir(dirname);
    hasfile =_findfirst("*",&c_file);
    if(hasfile!=-1){
        do{
            str[0]='\0';
            strcat(str,c_file.name);
            if((strcmp(str,".")!=0)&&(strcmp(str,"..")!=0)) { 
                if ((folder = opendir(c_file.name)) == NULL)    {         
                    if((a=remove(c_file.name))==0){
                        printf("Remove: %s OK.\n",c_file.name);
                    }else{
                        result=-1;
                        printf("Remove: %s Failed.\n",c_file.name);
                    }       
                }else{
                    closedir(folder);
                    if((a=myremove(c_file.name))!=0){result=-1;}
                }
            }
        }while( _findnext( hasfile, &c_file )==0 );
        _findclose(hasfile);
    } 
    _chdir("..");
    if((a=rmdir(dirname))!=0){
        result=-1;
        printf("Remove: %s Failed.\n",dirname);
    }else{
        printf("Remove: %s OK.\n",dirname);
    }
    return result;
}

int main( int argc, char *argv[])
{
    char dirname[256],cmmd[20],ch;
    printf("Please enter folder name which you want to remove:");
    gets(dirname);
    if (strlen(dirname)!=0){
        printf("Notice:Now start to %s delete action, sure to continue[Y/N]?",dirname);
        scanf("%c",&ch);
        if(ch=='Y'){
            if (myremove(dirname)==0){
                printf("Folder %s Removed.\n",dirname);
            }else{
                printf("Folder %s Remove failed.\n",dirname);           
            }
        }else if (ch=='N'){
            printf("User cancel, program will exit...\n");  
        }
    }else{
        printf("Input empty, program will exit...\n");
    }
    system("pause");
    return 0;
}
person UnciaX    schedule 12.05.2014