Video: CHATANGO FLAG USING C++ & PYTHON 2025
Når du åbner en fil ved at opbygge enten en upstream eller ifstream-instans, kan du ændre den måde, filen vil åbne ved at levere, hvad der kaldes flag. I computerbetingelser er et flag simpelthen et lille element, hvis tilstedeværelse eller mangel på tilstedeværelse fortæller en funktion, hvordan man gør noget. Med opstrøms- og omstrømsklasserne er den pågældende funktion konstruktøren.
Et flag ligner ios:: app, hvis du bruger en compiler, der ikke er fuldt ANSI-kompatibel, eller ligner ios_base:: app, hvis du bruger en, der er fuldt ANSI-kompatibel. Dette bestemte flag betyder, at du vil skrive til en fil, men du vil tilføje til eksisterende data, der allerede findes i en fil. Du leverer dette flag som et argument fra konstruktøren for upstream, som i et af følgende eksempler:
ofstream outfile ("AppendableFile.txt", ios:: app); ofstream outfile ("AppendableFile. txt", ios_base:: app);
Du kan se, at flagget tilføjes som en anden parameter til konstruktøren. Andre flag findes ud over app, og du kan kombinere dem ved at bruge eller operatøren, |. For eksempel er et flag iOS:: nocreate (som ikke er inkluderet i nyere kompilatorer).
Denne betyder "kun åbne filen, hvis den allerede eksisterer. "Det vil sige, opret ikke filen, hvis den ikke findes. (Husk, at upstream opretter en fil, hvis den ikke allerede eksisterer.) Hvis filen ikke eksisterer, vil den åbne mislykkes, og når du ringer fejler, får du en sand tilbage.
Ios:: nocreate flag er praktisk med ios:: app. Sammen betyder dette, at åbner en eksisterende fil og tilføjer den . Det vil sige, de to sammen vil kun fungere, hvis filen allerede eksisterer, og opkaldet åbner filen for en tilføjelsesoperation. Hvis filen ikke allerede eksisterer, oprettes filen ikke. Her er et eksempelopkald:
ofstream outfile ("… / MyFile.txt", ios:: app | ios:: nocreate); hvis (outfile. fail ()) {cout << "kunne ikke åbne filen!" << endl; return 0;} outfile << "hej" << endl; outfile. tæt();
Hvis MyFile. txt eksisterer ikke, når du kører denne kode, får du beskeden Kunne ikke åbne filen! Men hvis MyFile. txt eksisterer, applikationen åbner den, tilføjer strengen hej til den og endelig lukker den.
Det viser sig, at det nocreate flag ikke er tilgængeligt i det nye standardbibliotek. Øv bøv. Koden fungerer derfor kun, hvis du bruger en tidligere version af biblioteket. Når du bruger koden:: Bloker compiler, ser du følgende fejlmeddelelse:
fejl: 'nocreate' er ikke medlem af '; std:: ios '
Du vil dog gerne teste om din kompilator indeholder et bibliotek, der understøtter ios:: nocreate.Din kompilator kan alligevel understøtte det, selvom det indeholder det nye standardbibliotek. Som et alternativ til ios:: nocreate kan du bruge følgende kode (findes i FileOutput02 eksempelet):
ifstream infile ("… / MyFile. Txt"); hvis (infile. fail ()) {cout << "ikke kunne åbne filen!" << endl; returner 0;} infile. tæt(); ofstream outfile ("… / MyFile. txt", ios:: app); outfile << "hej" << endl; outfile. tæt();
I dette tilfælde begynder du ved at forsøge at åbne filen til læsning. Hvis filen ikke findes, kan du ikke læse fra den, og koden går ud med en fejlmeddelelse. Hvis koden kan læse fra filen, genåbnes filen for at skrive. Dette er en besværlig løsning, men det virker.
Følgende er en liste over de tilgængelige flag. For det første er her de for ios, hvis du bruger en compiler, der ikke er helt ANSI-kompatibel:
-
ios:: app: Dette flag betyder, at du vil åbne en fil og tilføje den.
-
ios:: in: Inkluder dette flag, hvis du vil læse fra en fil.
-
ios:: ud : Inkluder dette flag, hvis du vil skrive til en fil.
-
ios:: trunc : Inkluder dette flag, hvis du vil slette indholdet af filen, før du skriver til det. Det er det modsatte af at tilføje, og det er også standard, hvis du ikke specifikt indeholder iOS:: app.
-
ios:: nocreate : Brug dette flag, hvis du vil sikre, at filen ikke oprettes, hvis den ikke findes, hvilket resulterer i, at filen ikke åbnes.
-
ios:: noreplace : Dette flag er det modsatte af nocreate. Brug dette flag, hvis du kun vil oprette en ny fil. Hvis du bruger dette flag og filen allerede eksisterer, åbnes filen ikke, og den fejl vil returnere ægte .
ANSI-kompatible compilere understøtter heller ikke ios:: noreplace-flag. I dette tilfælde kan du bruge det modsatte af rettelsen til ios: nocreate flag, som vist her (og fundet i FileOutput03 eksempel):
ifstream infile ("… / MyFile. Txt"); hvis (! infile. fail ()) {cout << "filen eksisterer allerede!" << endl; returner 0;} infile. tæt(); ofstream outfile ("… / MyFile. txt"); outfile << "hej" << endl; outfile. tæt();
I dette tilfælde forsøger koden at åbne filen til læsning. Hvis filen findes, viser koden en fejlmeddelelse og udgange. Ellers opretter koden en ny fil og skriver til den.
Følgende flag er tilgængelige i en complier, der er absolut ANSI-kompatibel!
-
ios:: spiste: Brug dette flag til at gå til slutningen af filen, efter du har åbnet den. Normalt bruger du dette flag, når du vil tilføje data til filen.
-
ios_base:: binær: Brug dette flag til at angive, at filen du åbner vil holde binære data - det vil sige data, der ikke repræsenterer tegnstrenger.
-
ios_base:: in: Angiv dette flag, når du vil læse fra en fil.
-
ios_base:: out: Inkluder dette flag, når du vil skrive til en fil.
-
ios_base:: trunc: Inkluder dette flag, hvis du vil slette indholdet af en fil, før du skriver til det.
-
ios_base:: app: Inkluder dette flag, hvis du vil føje til filen. Det er det modsatte af trunc - det vil sige, de oplysninger, der allerede er i filen, når du åbner det, forbliver der.
Hvorfor har du brug for et flag og et udeflag? Det ser ud til, at computeren skal vide, om du skriver til en fil eller læser fra den, afhængigt (henholdsvis) om du bruger streamstream eller ifstream. Svaret på hvorfor du har et flag og et udeflag er, at andre klasser er tilgængelige udover stream og ifstre.
Kompilerne, der endnu ikke fuldt ud understøtter ANSI-standarden, har en generisk klasse i deres biblioteker kaldet fstream. De ANSI-kompatible kompilatorer har i deres biblioteker en skabelonklasse kaldet basic_filebuf og en klasse kaldet filebuf. Hvis du bruger disse klasser, kan du bruge ind og ud-flag.