Anfänger ?



  • @biter sagte in Anfänger ?:

    Es geht momentan nur darum, ob man _fcloseall() verwenden soll oder nicht.

    Alle Bezeichner mit einem oder zwei "_" sind proprietäre Internas des Compilers, und man sollte sie in der Regel gar nicht nutzen. Ausnahmen bestätigen auch hier die Regel. Mir erscheint das so zu sein, dass hier eine interne Schnittstelle der Laufzeitumgebung genutzt wird. Das ist zwar technisch möglich, aber nicht unbedingt die sauberste Art und Weise vorzugehen. Wenn man auf C Niveau Error Handling macht – sprich exit(EXIT_ERROR) aufruft, dann mag so etwas normal erscheinen.



  • Interessant, dass die beiden Threads mittlerweile sehr weit oben bei Google auftauchen (zumindest bei mir), wenn man fcloseall bzw. _fcloseall sucht.
    Die Diskussion an sich ist aber völlig sinnlos...



  • @john-0 sagte in Anfänger ?:

    Alle Bezeichner mit einem oder zwei "_" sind proprietäre Internas des Compilers, und man sollte sie in der Regel gar nicht nutzen. Ausnahmen bestätigen auch hier die Regel. Mir erscheint das so zu sein, dass hier eine interne Schnittstelle der Laufzeitumgebung genutzt wird. Das ist zwar technisch möglich, aber nicht unbedingt die sauberste Art und Weise vorzugehen.

    Die Funktionen der ms-crt wurden umbenannt um nicht mit POSIX-Funktionen zu kollidieren, die zwar meist ein ähnliches, aber doch hin und wieder ein für POSIX-Gewöhnte überraschendes Verhalten haben. Es spricht nichts dagegen diese Funktionen (die, deren Verwendung nicht per se total Banane ist) zu verwenden wenn es nicht auf Platformunabhängigkeit ankommt. Ob die jetzt mit _ beginnen oder nicht. Mit _-Prefix ist eben sichergestellt, daß sie nicht mit anderen Bezeichnern kollidieren.

    @Mechanics sagte in Anfänger ?:

    Interessant, dass die beiden Threads mittlerweile sehr weit oben bei Google auftauchen (zumindest bei mir), wenn man fcloseall bzw. _fcloseall sucht.
    Die Diskussion an sich ist aber völlig sinnlos...

    Ka*** schwimmt doch immer oben? ^^



  • @Mechanics sagte in Anfänger ?:

    Interessant, dass die beiden Threads mittlerweile sehr weit oben bei Google auftauchen (zumindest bei mir), wenn man fcloseall bzw. _fcloseall sucht.
    Die Diskussion an sich ist aber völlig sinnlos...

    Lässt vermuten, dass sonst niemand wirklich über diese Befehle redet....



  • normalerweise benutzt sie ja auch keiner, wozu auch?



  • was ich mich grad so frage: warum gibt es eigentlich keine funktion _fopenall()? das wäre doch bestimmt total bequem, alle dateien auf einmal öffnen zu können.😀



  • @Wade1234 sagte in Anfänger ?:

    was ich mich grad so frage: warum gibt es eigentlich keine funktion _fopenall()? das wäre doch bestimmt total bequem, alle dateien auf einmal öffnen zu können.😀

    Stimmt. Man gibt ein Verzeichnis an und dann fängt die Party an. Was ist nochmal die maximale Anzahl an möglichen Handles? Ist das noch 1024? 😀



  • @It0101 sagte in Anfänger ?:

    Was ist nochmal die maximale Anzahl an möglichen Handles? Ist das noch 1024?

    Europäische oder afrikanische Handles?



  • das ist ganz schön wenig, oder? also meine zweite festplatte hat mindestens 150000 dateien (ich habs dann abgebrochen). wenn ich die jetzt alle mit 1 und 0 überschreiben möchte, kann ich ja gleich fopen nehmen.🙁



  • @Swordfish sagte in Anfänger ?:

    Ob die jetzt mit _ beginnen oder nicht. Mit _-Prefix ist eben sichergestellt, daß sie nicht mit anderen Bezeichnern kollidieren.

    Das ist eine ganz ganz schlechte Wahl der Bezeichner. msrt_ o.ä. wäre mit Sicherheit sinnvoller gewesen, als einen Bezeichner mit einem _ am Anfang, denn solche Bezeichner sind laut Norm explizit für den Compiler und dessen Laufzeitumgebung reserviert.



  • "das ist genormt" bedeutet doch so viel wie "da hat jemand einen vorschlag gemacht, wie man es machen könnte, falls man lust haben sollte, sich an die norm zu halten", oder irre ich da?



  • @Wade1234 sagte in Anfänger ?:

    "das ist genormt" bedeutet doch so viel wie "da hat jemand einen vorschlag gemacht, wie man es machen könnte, falls man lust haben sollte, sich an die norm zu halten", oder irre ich da?

    Naja kein Compilerhersteller wird verklagt, weil er diese oder jene Funktion so oder so genannt hat...



  • @Wade1234 Da können wir ja froh sein, daß so viele Lust haben ^^

    @john-0 Daß es für die Runtime reservierte bezeichner sind heißt doch nicht, daß man sie nicht aufrufen darf.

    @john-0 sagte in Anfänger ?:

    msrt_ o.ä. wäre mit Sicherheit sinnvoller gewesen

    Nein, weil da wären im Gegensatz zu Bezeichnert die mit _ beginnen Kollisionen mit Usercode /* NICHT */ per Standard ausgeschlossen.



  • @Swordfish sagte in Anfänger ?:

    Nein, weil da wären im Gegensatz zu Bezeichnert die mit _ beginnen kollisionen mit Usercode mit per Standard ausgeschlossen.

    Das würde für jede Bibliothek gelten. Insofern ist das Argument nicht wirklich stichhaltig.



  • @john-0 sagte in Anfänger ?:

    Das würde für jede Bibliothek gelten.

    Ne, wieso soll das für jede Bibliothek gelten, bei der es einem völlig frei steht, sie zu verwenden? Um Einbinden von Standardheadern und linken gegen eine Standardlibrary kommt man aber nicht herum. (Komm mir jetzt nicht mit Freestanding Environments.)



  • @Swordfish sagte in Anfänger ?:

    Ne, wieso soll das für jede Bibliothek gelten, bei der es einem völlig frei steht, sie zu verwenden?

    Es geht um das grundsätzliche Problem von Namenskollisionen, und die explizite Definition der ISO Norm, dass nur Compiler- und Laufzeit-Internas in den Namensräumen _ bzw. __ existieren dürfen. Das wird durch normale Funktionen konterkariert. Ergo, wäre es besser gewesen sie nicht dort unterzubringen. Spezielle UNIX bzw. Linux Eigenheiten werden ja auch nicht in die privaten Namensräume der Compiler verschoben, sondern existieren explizit im normalen Namensraum. Weshalb weicht Microsoft so von der Gepflogenheiten der C Programmierung ab?



  • @john-0 sagte in Anfänger ?:

    Es geht um das grundsätzliche Problem von Namenskollisionen, und die explizite Definition der ISO Norm, dass nur Compiler- und Laufzeit-Internas in den Namensräumen _ bzw. __ existieren dürfen.

    Wer sagt das? Du darfst Bezeichner in Deinem Usercode nicht einführen. Wo ist irgendwo verboten, eine Funktion _foobar() aufzurufen?

    @john-0 sagte in Anfänger ?:

    Bezeichner mit einem _ am Anfang, denn solche Bezeichner sind laut Norm explizit für den Compiler und dessen Laufzeitumgebung reserviert.

    Du widersprichst Dir selbst. _fcloseall() ist bei MS Teil der Runtime.

    Ich sehe das genau andersrum: GNU packt irgendwelche Bezeichner ("This function is a GNU extension.") wie fcloseall() in einen Standardheader und kein Standard garantiert, daß der nicht auch von Usercode verwendet (=eingeführt) werden dürfte.

    @john-0 sagte in Anfänger ?:

    die explizite Definition der ISO Norm, dass nur Compiler- und Laufzeit-Internas in den Namensräumen _ bzw. __ existieren dürfen. Das wird durch normale Funktionen konterkariert. Ergo, wäre es besser gewesen sie nicht dort unterzubringen. Spezielle UNIX bzw. Linux Eigenheiten werden ja auch nicht in die privaten Namensräume der Compiler verschoben, sondern existieren explizit im normalen Namensraum.

    C++ (latest draf) [lex.name]/3.2:

    Each identifier that begins with an underscore is reserved to the implementation for use as a name in the global namespace.

    C11 §7.1.3.1:

    [...]

    • All identifiers that begin with an underscore and either an uppercase letter or another underscore are always reserved for any use.

    • All identifiers that begin with an underscore are always reserved for use as identifiers with file scope in both the ordinary and tag name spaces.

    Also Du redest ein bisschen Topfen.


  • Gesperrt

    @Wade1234 sagte in Anfänger ?:

    aber dann taut der gefrierschrank ab

    Bis dahin ist der Schlüsseldienst längst da und hat dein Schloß aufgeknackt. 🐱


  • Gesperrt

    @Wade1234 sagte in Anfänger ?:

    was ich mich grad so frage: warum gibt es eigentlich keine funktion _fopenall()? das wäre doch bestimmt total bequem, alle dateien auf einmal öffnen zu können.😀

    Der würde eine Liste aus Pfaden bekommen und eine gleich lange Liste von FILE* zurückgeben, oder NULL, wenn eine der Dateien nicht geöffnet werden kann. Bestimmt gibt es auch den einen oder anderen Anwendungsfall dafür. Allerdings ist das schon sehr speziell.



  • @RBS2 sagte in Anfänger ?:

    Bis dahin ist der Schlüsseldienst längst da und hat dein Schloß aufgeknackt. 🐱

    ja da hast du natürlich recht. am sichersten ist es aber, im trafohäuschen die ganze straße abzuschalten.

    @RBS2 sagte in Anfänger ?:

    Der würde eine Liste aus Pfaden bekommen und eine gleich lange Liste von FILE* zurückgeben, oder NULL, wenn eine der Dateien nicht geöffnet werden kann. Bestimmt gibt es auch den einen oder anderen Anwendungsfall dafür. Allerdings ist das schon sehr speziell.

    naja wenn du gemäß obiger idee alle dateien mit 1 und 0 überschreiben willst, könnte das programm dann doch ungefähr so aussehen:

    int main()
    {
         int i;
    
         _fopenall("f:\\");
    
         for(i = 0; i < 5; i++)
         {
              _fwriteall(0xFFFFFFFF, 4, _fsizeall());
              _fwriteall(0x00000000, 4, _fsizeall());
         }
    
         _fcloseall();
    }
    

Anmelden zum Antworten