www.mikrocontroller.net

Forum: PC-Programmierung schon einmal was von Quines gehört?


Autor: wanderameise (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
bin gerade zufällig über folgendes gestolpert: International Obfuscated 
C Code Contest, in welchem es darum geht, code möglichst füchterlich 
aussehen zu lassen. als beispiel ist folgendes angegeben:
#define _ -F<00||--F-OO--;
 int F=00,OO=00;main(){F_OO();printf("%1.3f\n",4.*-F/OO/OO);}F_OO()
 {
             _-_-_-_
        _-_-_-_-_-_-_-_-_
     _-_-_-_-_-_-_-_-_-_-_-_
   _-_-_-_-_-_-_-_-_-_-_-_-_-_
  _-_-_-_-_-_-_-_-_-_-_-_-_-_-_
  _-_-_-_-_-_-_-_-_-_-_-_-_-_-_
 _-_-_-_-_-_-_-_-_-_-_-_-_-_-_-_
 _-_-_-_-_-_-_-_-_-_-_-_-_-_-_-_
 _-_-_-_-_-_-_-_-_-_-_-_-_-_-_-_
 _-_-_-_-_-_-_-_-_-_-_-_-_-_-_-_
  _-_-_-_-_-_-_-_-_-_-_-_-_-_-_
  _-_-_-_-_-_-_-_-_-_-_-_-_-_-_
   _-_-_-_-_-_-_-_-_-_-_-_-_-_
     _-_-_-_-_-_-_-_-_-_-_-_
         _-_-_-_-_-_-_-_
             _-_-_-_
 }

kann mir jemand erklären was hier passiert, bzw wie es funktioniert?

mehr infos:
http://de.wikipedia.org/wiki/IOCCC

Autor: Rolf Magnus (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
> kann mir jemand erklären was hier passiert, bzw wie es funktioniert?

Ist doch eigentlich nicht so schwer. Der Anfang, vor diesem hübschen 
Ball mal etwas übersichtlicher geschrieben:
#define _  -F < 0 || --F - OO--;

int F=0, OO=0;

main()
{
    F_OO();
    printf("%1.3f\n",4.0 * -F / OO / OO);
}

F_OO()
{

Also macht main eigentlich nichts weiter, als die Funktion F_OO 
aufzurufen, dann das Ergebnis von 4.0 * -F   / OO   / OO auszugeben.
Der Ball wird durch Makro-Auflösung zu Code.
Schauen wir uns mal die erste Zeile an:
             _-_-_-_

Also, _ wird durch '-F<00||--F-OO--;' ersetzt. Damit wird daraus:
-F<00||--F-OO--;
--F<00||--F-OO--;
-F<00||--F-OO--;
--F<00||--F-OO--;
-F<00||--F-OO--;
--F<00||--F-OO--;
-F<00||--F-OO--;

Die erste Zeile davon mal etwas übersichtlicher

-F < 0 || --F - OO--;

Der Operator || arbeitet hier als Ersatz für if, da der Ausdruck 
dahinter nur dann ausgewertet wird, wenn der davor nicht 0 ist. Der Wert 
des ganzen wird hier einfach ignoriert. Dadurch wird auch das Ergebnis 
der  Subtraktion ignoriert. Also könnte man das auch noch lesbarer 
schreiben:
if (F > 0)
{
    F--;
    OO--;
}

Das
--F<00||--F-OO--;

funktioniert dann genaus, nur eben mit umgekehrtem Vorzeichen. Diese 
Operationen werden dann eben entsprechend oft ausgeführt (nachzählen 
darfst du selber).

Autor: Uwe ... (uwegw)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Ein Quine ist das übrigens nicht. Sonst müsste das Programm seinen 
eigenen Quelltext ausgeben.

Und zur Analyse solcher Programme lässt man sie zuerst mal durch den 
Präprozessor und einen Quelltextformatierer laufen...

Autor: wanderameise (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
danke habs sogar verstanden!

Autor: Mark Brandis (markbrandis)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Ja der IOCCC... ist wohl leider 'defunct'. :(

Autor: Olaf (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
> Ja der IOCCC... ist wohl leider 'defunct'. :(

Wieso? Programmiert ihr nicht jeden Tag selber so? :-D

Olaf

Autor: Klaus Wachtler (mfgkw)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
jeden Tag nicht, aber um Studenten zu quälen schon mal gelegentlich...
Zum Beispiel mit der Frage, was dieses Programm ausgibt und vor allem 
warum:
http://www.wachtler.de/obfus.c

Autor: Mark Brandis (markbrandis)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Olaf schrieb:
> Wieso? Programmiert ihr nicht jeden Tag selber so? :-D

Nein! :-)
Hätte durchaus mal am IOCCC teilnehmen wollen, aber nachdem sie es seit 
über drei Jahren nicht schaffen den Sourcecode der letzten Gewinner zu 
veröffentlichen, ist das Ganze wohl gestorben.

Autor: ameise (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
gibts dafür gründe?

Autor: J. S. (Firma: Telekomunikation Darmstadt) (juergenffm) Benutzerseite
Datum:

Bewertung
0 lesenswert
nicht lesenswert
> C Code Contest, in welchem es darum geht, code möglichst füchterlich
> aussehen zu lassen. als beispiel ist folgendes angegeben:

Sowas programmieren wir hier jeden Tag, ganz regulär.

Autor: Karl (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Oo, Bosch...

Antwort schreiben

Die Angabe einer E-Mail-Adresse ist freiwillig. Wenn Sie automatisch per E-Mail über Antworten auf Ihren Beitrag informiert werden möchten, melden Sie sich bitte an.

Wichtige Regeln - erst lesen, dann posten!

  • Groß- und Kleinschreibung verwenden
  • Längeren Sourcecode nicht im Text einfügen, sondern als Dateianhang

Formatierung (mehr Informationen...)

  • [c]C-Code[/c]
  • [avrasm]AVR-Assembler-Code[/avrasm]
  • [code]Code in anderen Sprachen, ASCII-Zeichnungen[/code]
  • [math]Formel in LaTeX-Syntax[/math]
  • [[Titel]] - Link zu Artikel
  • Verweis auf anderen Beitrag einfügen: Rechtsklick auf Beitragstitel,
    "Adresse kopieren", und in den Text einfügen




Bild automatisch verkleinern, falls nötig
Bitte das JPG-Format nur für Fotos und Scans verwenden!
Zeichnungen und Screenshots im PNG- oder
GIF-Format hochladen. Siehe Bildformate.
Hinweis: der ursprüngliche Beitrag ist mehr als 6 Monate alt.
Bitte hier nur auf die ursprüngliche Frage antworten,
für neue Fragen einen neuen Beitrag erstellen.

Mit dem Abschicken bestätigst du, die Nutzungsbedingungen anzuerkennen.