Vim oder Emacs



  • Badestrand schrieb:

    vim_fan schrieb:

    ...

    Die Klicki-Buntis haben halt den Vorteil, dass vieles (pseudo-)standardisiert ist, z.B. F1 um die Hilfe aufzurufen, Strg+S zum speichern, Alt+F4 zum Beenden usw. Da braucht man keine Einarbeitungs- und/oder Umgewöhnungsphase, man ist eben sofort "drin". Ich weiß nicht, was vi(m) so alles kann, aber einige der Befehle, wie deine aufgelisteten, erleichtern nix wenn sie standard-fremd sind.

    Was du ansprichst ist aber nur das bearbeiten von Dateien an für sich. Eine IDE macht aber noch vieles mehr aus als nur das eingeben von Text.
    Klar die GUIs sind auch einigermaßen standardisiert, aber bei den Einstellungen für die Projekte, das Aussehen der IDE, etc. unterscheiden sie sich dann doch und dann bei den fortgeschritteneren Funktionen dann auf jeden Fall und man kommt auch hier nicht um das Einarbeiten herum.

    Bei vim muss man auf jeden Fall ersteinmal lernen wie man damit arbeitet, da stimme ich dir zu.
    Aber nur weil die Bedienung anders ist als bei 99% der anderen Texteditoren muss das nicht heißen, dass die Bedienung schlechter ist und das ist sie nämlich nicht.

    Es wundert mich, dass in einem Programmierforum so viel Widerstand gegen eine anfangs höhere Lernkurve kommt, und das auch noch in einem C++-Forum und vllt. sogar von Leuten die Latex über die Klikibunti-Office-Pakete stellen (hab ich jetzt nicht nachgeprüft, deswegen steht da auch vielleicht!).



  • Badestrand schrieb:

    vim_fan schrieb:

    ...

    [...]Ich weiß nicht, was vi(m) so alles kann, aber einige der Befehle, wie deine aufgelisteten, erleichtern nix wenn sie standard-fremd sind.

    Das habe ich vorhin falsch gelesen, deswegen noch ein Nachtrag:
    willst du damit sagen, dass du dir nicht zwei oder mehr verschiedene Bedienführungen merken kannst?
    Das tust du doch im täglichen Leben ständig und bei all den verschiedenen Programmen musst du dir doch auch verschiedene Arten der Bedienung merken.
    Warum denn nicht auch bei einem Texteditor? Das ist ja jetzt kein Texteditor der absolut Mainstream ist und du unabdingbar auf diesen angewiesen bist und völlig aufgeschmissen wärst, wenn du ihn nicht bedienen kannst.
    Du kannst ja jederzeit auf einen standardiesierten 0815 Editor zurückwechseln bis du mit diesem umgehen kannst.



  • vim_fan schrieb:

    Es wundert mich, dass in einem Programmierforum so viel Widerstand gegen eine anfangs höhere Lernkurve kommt...

    hohe lernkurven machen nur dann sinn, wenn sich daraus ein vorteil ergibt. das lernen wie man einen vim oder emacs bedient, ist aber in der heutigen zeit total hinfällig.
    🙂



  • warum sollte ich einen veralteten, schlecht bedienbaren editor nehmen, wenn ich einen editor benutzen kann, der sich an bestehende standards hält (siehe F1, STRG+C, STRG+X, STRG+V, usw)?

    nenn mir doch mal ein konkretes beispiel wie ich mit vim schneller arbeiten kann als mit notepad++.



  • Ich meine ja nicht, dass vi(m) schlecht ist, ich kenn's ja auch einfach nicht. Und du hast natürlich recht, bei so ziemlich jeder IDE muss man sich einarbeiten.
    Vi(m) mag viele Vorteile haben, kann ich wie gesagt nicht beurteilen, aber in anderen Editoren kann man auch effizient arbeiten und eben auch viel mit der Tastatur machen. Da finde ich es falsch zu sagen, alles andere wäre ineffizient und nur in vi(m) wäre man fix, wobei eben wahrscheinlich nur einige Sachen fixer gehen, die dann aber auch die höhere Einarbeitungszeit rechtfertigen.
    Ich persönlich habe weder was gegen "Guru"-Programme wie vi(m) noch gegen Klicki-Bunti-Sachen. Beide haben ihre Stärken und Schwächen, Bildbearbeitung per Konsole ist ebenso unsinnig wie eine Klicki-Anwendung ohne abkürzende Tastenbefehle (und sei es nur TAB zum navigieren in den Feldern).
    Dabei müssen beide Anwendungsarten aufpassen, dass sie ihre Schwächen größtmöglichst überdecken können, etwa Einarbeitungszeit bei Guru-Programmen oder Effizienz bei Klicki-Programmen.
    Generell denke ich, dass ein Mittelmaß ein guter Kompromiss ist. Das wäre dann wohl eine Anwendung, wo man prinzipiell alles nach einem einfachen Klicki-Bunti-Prinzip erledigen kann oder eben alternativ die meist-gebräuchlisten Dinge per Tastatur hinkriegt.

    Trotz allem ist es aber natürlich auch eine Sache des persönlichen Bedarfs, wenn ich einmal pro Jahr eine Präsentation ohne Anspruch auf Perfektion produzieren will, werde ich dafür gewiss nicht dutzende LaTeX-Befehle auswendig lernen sondern mir getrost und leicht alles zusammenklicken. Wenn Präsentationen oder wissenschaftliche Texte aber zu meinem Alltag gehören würden, würde ich gewiss den Einarbeitungsaufwand in Kauf nehmen.

    vim-fan schrieb:

    willst du damit sagen, dass du dir nicht zwei oder mehr verschiedene Bedienführungen merken kannst?
    Das tust du doch im täglichen Leben ständig und bei all den verschiedenen Programmen musst du dir doch auch verschiedene Arten der Bedienung merken.

    Kann ich mir merken, muss ich aber nicht 😉 Gerade weil vi(m) bei Dingen mit ":help" vs "F1" vom quasi-Standard abweicht, muss ich mir mehr merken, als nötig, worauf ich keine Lust habe, gerade weil es auch vermeidbar ist. Also bleibe ich für kurze Texte beim Windows-Editor, der hat für mich das beste Zeit/Leisungs-Verhältnis.



  • Wenn ich Standard-Funktionen erst lernen muß, dann kann ich das nicht gerade als Vorteil ansehen. Sorry. Leistung hin oder her. Wenn ich in ein fremdes Auto einsteige, weiß ich wie ich die Standard-Funktionen zu bedienen habe. Ich will das nicht anders haben, als es bei allen anderen Autos der Welt ist. Schon alleine das coole Lenkrad von Knight Rider bzw. KITT wird sich nie durchsetzen, weil es nicht standard ist. Das kommt in einer TV-Serie cool. Genauso wie Emacs in einem Hacker-Film vielleicht cool kommt. Aber im realen Leben völlig vorbei.

    Funktionen in einem Auto, die ich nicht zum Fahren brauche, können meinet wegen anders funktionieren. Wenn ich die nicht finde oder verstehe, macht das erstmal nichts, weil ich trotzdem mit dem Auto erstmal von A nach B komme.

    Ich selber habe ja schon Umgewöhnungsprobleme, wenn ich mich in eine Automatik-Auto setze (ist keine Bewertung!). Klar, nach ein paar Minuten habe ich mich umgewöhnt. Aber es ist ätzend die ersten Minuten, weil ich mich unsicher fühle. Weil ganz einfach die Kupplung fehlt und ich jedesmal die Kupplung treten will, obwohl keine da ist (beim ersten Mal habe ich sogar voll auf die Bremse getreten, hat sich mein Hintermann gefreut!). Danach habe ich es auch gerafft, bin ja nicht doof. 😉 Aber ist nervig und habe zum Glück sonst nur meinen Handschalter. Kenne Leute, die fahren immer nur Automatikgetriebe, die haben halt Probs Handschalter zu fahren.

    Der Mensch ist ein Gewohnheitstier. Ich will Strg+S drücken um eine Datei zu speichern. Punkt!

    Wer Emacs oder Vim gewohnt ist, wird damit besser fahren. So ist das halt.



  • Wo gibts eigentlich dieses legendäre Vim 30min howto? Google verweist auf diesen Thread.



  • Wir reden gerade aneinander vorbei, ich behaupte überhaupt nicht, dass die Klickibunti Editoren ineffizient wären.

    Ich habe nur behauptet, dass vim (sehr) effizient ist.

    Schon alleine das coole Lenkrad von Knight Rider bzw. KITT wird sich nie durchsetzen, weil es nicht standard ist. Das kommt in einer TV-Serie cool. Genauso wie Emacs in einem Hacker-Film vielleicht cool kommt. Aber im realen Leben völlig vorbei.

    Naja ich hab ja selbst gesagt, dass vim nicht für den 0815 gebrauch geeignet ist, zumindest vom heutigen Standpunkt aus.
    Aber wenn man damit umgehen kann, so hat man wie bei KITT, etwas sehr mächtiges zur Hand.

    Wo gibts eigentlich dieses legendäre Vim 30min howto? Google verweist auf diesen Thread.

    Das 30min Tutorial kannst du nach deiner vim Installation mit "vimtutor" aufrufen. Unter Windows mit findest du das im vim Menü bzw. mit vimtutor.bat.



  • wiczer schrieb:

    nenn mir doch mal ein konkretes beispiel wie ich mit vim schneller arbeiten kann als mit notepad++.

    Hab ich vorhin genannt.

    "3dd"

    Okay, anderes einfaches Beispiel: Suchen und ersetzen. Bis du den Suchendialog geöffnet hast, hab ichs schon ersetzt 😉 (perl-style)



  • Ich verstehe die von euch genannten Vorteile von vim/emacs nicht. Könntet ihr vielleicht mal ein paar von diesen Befehlen beschreiben? Ich meine, 3 Zeilen löschen geht wie gesagt in einer IDE auch sehr fix per Tastatur. Und ich kann mir irgendwie keine sinnvollen Befehle vorstellen, die einem die Arbeit so erleichtern sollen.
    Außerdem würde ich gerne noch wissen, ob vim/emacs wirklich nur Editoren sind und wie sie mit IDEs konkurrien können. Ihr wollt mir doch nicht erzählen, dass ihr nur mit einem Editor programmiert, bei dem man auch noch Befehle eintippen muss um 3 Zeilen zu löschen?!



  • vim _fan schrieb:

    Wir reden gerade aneinander vorbei, ich behaupte überhaupt nicht, dass die Klickibunti Editoren ineffizient wären.

    Ich habe nur behauptet, dass vim (sehr) effizient ist.

    Es geht ja darum, dass vim einen Mehrwert haben muss, der den Mehraufwand der Bedienung rechtfertigt.

    gfdgdfgdfg schrieb:

    Okay, anderes einfaches Beispiel: Suchen und ersetzen. Bis du den Suchendialog geöffnet hast, hab ichs schon ersetzt (perl-style)

    Wie lautet denn der Befehl dazu? Ich meine STRG+H Test Tab NeuerText Enter ist schon recht schnell.



  • Hazzel schrieb:

    Wie lautet denn der Befehl dazu? Ich meine STRG+H Test Tab NeuerText Enter ist schon recht schnell.

    :s/gesucht/ersetzt/g



  • ok, geht mit einem gui-editor also genau so schnell.

    irgendwelche vorteile von vim?



  • wiczer schrieb:

    ok, geht mit einem gui-editor also genau so schnell.

    irgendwelche vorteile von vim?

    Selektion. (Selektionskriterium: Vernunft)



  • kurven-freak schrieb:

    vim_fan schrieb:

    Es wundert mich, dass in einem Programmierforum so viel Widerstand gegen eine anfangs höhere Lernkurve kommt...

    hohe lernkurven machen nur dann sinn, wenn sich daraus ein vorteil ergibt. das lernen wie man einen vim oder emacs bedient, ist aber in der heutigen zeit total hinfällig.
    🙂

    Ich wünsche dir viel spass über ssh mit nano oder ed 😃



  • gfdgdfgdfg schrieb:

    Okay, anderes einfaches Beispiel: Suchen und ersetzen. Bis du den Suchendialog geöffnet hast, hab ichs schon ersetzt 😉 (perl-style)

    Du meinst die gewohnte Tastenkombi Strg+F? Das dauert natürlich länger, als eine andere Tastenkombi in Vim oder emacs?



  • Artchi schrieb:

    gfdgdfgdfg schrieb:

    Okay, anderes einfaches Beispiel: Suchen und ersetzen. Bis du den Suchendialog geöffnet hast, hab ichs schon ersetzt 😉 (perl-style)

    Du meinst die gewohnte Tastenkombi Strg+F? Das dauert natürlich länger, als eine andere Tastenkombi in Vim oder emacs?

    richtig.



  • Hazzel schrieb:

    Ich verstehe die von euch genannten Vorteile von vim/emacs nicht. Könntet ihr vielleicht mal ein paar von diesen Befehlen beschreiben? Ich meine, 3 Zeilen löschen geht wie gesagt in einer IDE auch sehr fix per Tastatur. Und ich kann mir irgendwie keine sinnvollen Befehle vorstellen, die einem die Arbeit so erleichtern sollen.
    Außerdem würde ich gerne noch wissen, ob vim/emacs wirklich nur Editoren sind und wie sie mit IDEs konkurrien können. Ihr wollt mir doch nicht erzählen, dass ihr nur mit einem Editor programmiert, bei dem man auch noch Befehle eintippen muss um 3 Zeilen zu löschen?!

    Das löschen von drei Zeilen ist ein ziemlich gutes Beispiel, viel andere wie ein ganzes Wort löschen mehrere ganze Wörte löschen, x Wörter überspringen, x Zeilen überspring, sind andere ganz praktische Befehle. Du kannst natürlich auch einfach mit der Maus den Cursor verschieben, aber dafür musst du die Tastatur verlassen und das kannst du übrigens auch in vim.
    Den Cursor verschiebt man mit hjkl (alternativ gehen auch die Pfeiltasten), das ist unheimlich praktisch wenn man es ersteinmal gewohnt ist, da man die Finger die ganze Zeit bei den Tasten lassen kann, ohne die Hände immer hin und her bewegen zu müssen.

    Wenn man zuvor search highlight und incremental search gesetzt hat, dann kann man mit einem einfachen
    /meinesuche<ENTER>
    sich alle Vorkommen des Wortes im Dokument farbig hervorheben lassen
    und mit
    /meinMuster/meineErsetzung/g<ENTER>
    kann man global ersetzen (perl style wie oben schon angemerkt)
    Mit % kann man von einer Klammer zur zugehörigen Klammer springen.

    Syntaxhighlighting kann man per Syntax-Datei nach belieben konfigurieren (oder man greift auf was fertiges zurück) und Skripting gibts natürlich auch.

    mit STRG+U kann man sämtliche Änderungen auf einer Zeile rückgängig machen
    mit dd löscht man eine ganze Zeile
    mit J (großes J) kann man das Newline entfernen und zwei Zeilen verbinden
    nach einem dd kann man mit einem einfachen p die eben gelöscht Zeile unterhalb der aktuellen Zeile einfügen und mit P oberhalb
    mit o wird eine Zeile unterhalb der aktuellen eingefügt, mit O oberhalb
    mit A wird an das Ende der aktuellen Zeile angehängt
    mit a nach dem Cursor
    mit i vor dem Cursor
    mit R ersetzt man beim Schreiben
    mit G kommt man ans Dateiende
    mit gg an den Dateianfang

    gibt noch viele mehr, die Effizienz hängt halt maßgeblich davon ab wieviele man beherrscht, damit man immer den effizientesten wählt.

    Imho gibt die Liste auch nicht die Tatsache wieder, dass es schnell(er) ist, dazu muss man schon selbst mal hand angelegt haben oder jemandem über die Schulter gesehen haben.



  • Wie gesagt, nur ein Idiot denkt, dass irgendwelche Mikroschritte wie :wq!wtf oder 2 Klicks irgendwie die Effizienz ändern.
    Es ist Fakt, dass prof. Entwickler die meiste Zeit überlegen und das eigentliche Schreiben einen Bruchteil ausmacht.
    Eine Effizientsteigerung innerhalb eines Tools erreicht man nur durch gute (keine Modes!), konsistente und intuitive (das wichtigste muss OHNE Tutorial klar sein!) Bedienung und High Level Hilfen wie Refactoring, Debugger, Templates usw.



  • Ok, wie es aussieht hat man mit vim nach einer längeren Lern- und Übungsphase einige mehr oder weniger große Vorteile beim Eingeben von Text.
    Aber wie sieht es mit anderen Funktionen einer IDE aus? Wie debuggt man im Textmodus? Wie wechselt man innerhalb eines Projekts zwischen den Dateien?

    Du redest offenbar von vim. Ich nehme mal an, bei emacs verhält es sich ähnlich?


Anmelden zum Antworten