1 00:00:07,060 --> 00:00:08,420 [Powered by Google Translate] TOMMY: In diesem Video werden wir kennen lernen 2 00:00:08,420 --> 00:00:10,140 Umleitung und Rohre. 3 00:00:10,140 --> 00:00:12,780 Bisher haben wir schon mit Funktionen wie printf 4 00:00:12,780 --> 00:00:15,590 Ausgabedaten an das Endgerät und Funktionen wie GetString 5 00:00:15,590 --> 00:00:17,520 um dem Benutzer die Eingabe in unseren bereitzustellen 6 00:00:17,520 --> 00:00:19,490 Programm mit der Tastatur. 7 00:00:19,490 --> 00:00:21,880 Lassen Sie uns schnell einen Blick auf ein Programm, das eine Reihe von erhält 8 00:00:21,880 --> 00:00:25,960 Eingabe von dem Benutzer und gibt es dann. 9 00:00:25,960 --> 00:00:28,990 >> In Zeile 7, wir den Benutzer zur Eingabe einer Zeichenfolge, und 10 00:00:28,990 --> 00:00:31,680 dann on line 8, wir drucken es wieder heraus. 11 00:00:31,680 --> 00:00:35,220 Lassen Sie kompilieren und ausführen unserem Programm. 12 00:00:35,220 --> 00:00:35,900 Great. 13 00:00:35,900 --> 00:00:37,620 Der String wir bereitgestellt wird zurückgesendet 14 00:00:37,620 --> 00:00:39,170 uns auf dem Terminal. 15 00:00:39,170 --> 00:00:42,110 Dies geschah, weil die Funktion printf schrieb ein 16 00:00:42,110 --> 00:00:46,220 Datenstrom genannt Standard aus, oder s-t-d-out. 17 00:00:46,220 --> 00:00:49,230 Wenn etwas auf die Standardausgabe geschrieben wird, ist es standardmäßig 18 00:00:49,230 --> 00:00:51,110 angezeigt durch das Endgerät. 19 00:00:51,110 --> 00:00:53,720 >> Also das ist alles schön und gut, aber was, wenn, statt einfach 20 00:00:53,720 --> 00:00:57,700 Anzeige der Saite, wollten wir es in einer Datei speichern? 21 00:00:57,700 --> 00:01:00,470 Zum Beispiel könnten wir erinnern wollen, was unsere 22 00:01:00,470 --> 00:01:04,450 Programm hat, wenn wir es gab eine bestimmte Eingabe später. 23 00:01:04,450 --> 00:01:07,270 Ein Ansatz wäre, diese in unser C-Programm zu tun, mit 24 00:01:07,270 --> 00:01:09,680 einige spezielle Funktionen zum Schreiben von Dateien, dass wir 25 00:01:09,680 --> 00:01:11,270 sehen in einem anderen Video. 26 00:01:11,270 --> 00:01:13,260 Noch einfacher, aber wäre irgendwie 27 00:01:13,260 --> 00:01:16,090 redirect stdout in eine Datei. 28 00:01:16,090 --> 00:01:19,780 So, wenn printf schreibt stdout, wird der Inhalt 29 00:01:19,780 --> 00:01:21,720 in einer Datei anstatt geschrieben werden 30 00:01:21,720 --> 00:01:23,410 angezeigt durch das Endgerät. 31 00:01:23,410 --> 00:01:26,690 Wir können nur so, dass durch Zugabe eines Größer-als-Zeichen zu tun, gefolgt 32 00:01:26,690 --> 00:01:30,820 von einem Dateinamen, der Befehl, den wir verwenden, um unser Programm auszuführen. 33 00:01:30,820 --> 00:01:34,730 >> So, anstatt einfach ausführen. / Redirect, können wir 34 00:01:34,730 --> 00:01:38,880 laufen. / umzuleiten, gefolgt von einem Größer-Zeichen, gefolgt von 35 00:01:38,880 --> 00:01:41,530 Dateinamen, wie file.txt. 36 00:01:41,530 --> 00:01:44,290 Mal sehen, was passiert. 37 00:01:44,290 --> 00:01:45,130 OK. 38 00:01:45,130 --> 00:01:48,470 Beachten Sie, dass dieses Mal nichts am Terminal angezeigt wurde, 39 00:01:48,470 --> 00:01:50,290 aber wir haben nicht die Inhalte unserer modifiziert 40 00:01:50,290 --> 00:01:52,040 C-Programm überhaupt. 41 00:01:52,040 --> 00:01:56,090 Lassen Sie uns nun untersuchen die Inhalte dieses Verzeichnisses mit ls. 42 00:01:56,090 --> 00:01:56,630 >> Gut. 43 00:01:56,630 --> 00:02:00,840 Wir haben jetzt eine neue Datei in unserem Verzeichnis namens file.txt, 44 00:02:00,840 --> 00:02:03,640 das ist der Name der Datei lieferten wir, wenn wir unsere rannte 45 00:02:03,640 --> 00:02:05,050 Redirect-Programm. 46 00:02:05,050 --> 00:02:08,020 Lasst uns eröffnen file.txt. 47 00:02:08,020 --> 00:02:11,840 Und hier können wir sehen, dass die stdout aus umzuleiten war 48 00:02:11,840 --> 00:02:15,550 geschrieben, um die Datei mit dem Namen file.txt. 49 00:02:15,550 --> 00:02:18,470 Also lasst uns laufen den vorherigen Befehl wieder, aber Zuführen eines 50 00:02:18,470 --> 00:02:20,075 anderen Eingang dieser Zeit. 51 00:02:25,140 --> 00:02:25,900 Okay. 52 00:02:25,900 --> 00:02:28,205 Werfen wir einen Blick auf file.txt jetzt. 53 00:02:31,070 --> 00:02:34,580 >> Wir können hier sehen, dass die Datei überschrieben wurde, so dass unsere 54 00:02:34,580 --> 00:02:37,120 Original-Eingang ist nicht mehr da. 55 00:02:37,120 --> 00:02:40,280 Wenn wir stattdessen wollen diese Datei anzuhängen, Inbetriebnahme der neuen 56 00:02:40,280 --> 00:02:43,600 Eingang unter den vorhandenen Inhalt der Datei, können wir 57 00:02:43,600 --> 00:02:46,800 mit zwei Größer-als-Zeichen anstelle von nur einem. 58 00:02:46,800 --> 00:02:48,050 Lasst uns versuchen. 59 00:02:52,160 --> 00:02:57,910 Nun, wenn wir file.txt wieder zu öffnen, können wir sehen, unsere beiden 60 00:02:57,910 --> 00:02:59,580 Eingangsleitungen. 61 00:02:59,580 --> 00:03:02,180 In einigen Fällen möchten wir vielleicht zu einem entsorgen 62 00:03:02,180 --> 00:03:03,850 Ausgabe unseres Programms. 63 00:03:03,850 --> 00:03:06,450 Vielmehr als das Schreiben der Ausgabe in eine Datei und dann löschen 64 00:03:06,450 --> 00:03:09,310 die Datei, wenn wir damit fertig sind, können wir eine besondere schreiben 65 00:03:09,310 --> 00:03:12,360 Datei mit dem Namen / dev / null. 66 00:03:12,360 --> 00:03:15,160 Wenn etwas an / geschrieben dev/null-- 67 00:03:15,160 --> 00:03:16,960 oder kurz devnull - 68 00:03:16,960 --> 00:03:18,950 es wird automatisch verworfen. 69 00:03:18,950 --> 00:03:23,290 So der devnull denken, wie ein schwarzes Loch für Ihre Daten. 70 00:03:23,290 --> 00:03:26,070 >> So, jetzt haben wir gesehen, wie die Größer-Zeichen umleiten 71 00:03:26,070 --> 00:03:29,610 stdout, lasst uns sehen, wie wir das Umleiten der Standardeingabe in - 72 00:03:29,610 --> 00:03:31,250 oder s-t-d-in - 73 00:03:31,250 --> 00:03:33,550 das Analogon von stdout. 74 00:03:33,550 --> 00:03:36,010 Während Funktionen wie printf in den Stream genannt schreiben 75 00:03:36,010 --> 00:03:40,500 stdout, GetString und ähnliche Funktionen aus dem Stream gelesen 76 00:03:40,500 --> 00:03:43,770 als stdin, die standardmäßig ist der Strom der 77 00:03:43,770 --> 00:03:46,290 Zeichen an der Tastatur eingegeben. 78 00:03:46,290 --> 00:03:50,010 Wir können stdin mit dem weniger als Zeichen umzuleiten, gefolgt 79 00:03:50,010 --> 00:03:51,370 von einem Dateinamen. 80 00:03:51,370 --> 00:03:54,000 Nun anstatt Aufforderung des Benutzers zur Eingabe an die 81 00:03:54,000 --> 00:03:57,870 Anschluss wird ein Programm öffnen Sie die Datei, die wir angegeben und verwenden 82 00:03:57,870 --> 00:03:59,790 seine Linien als Eingabe. 83 00:03:59,790 --> 00:04:02,620 >> Mal sehen, was passiert. 84 00:04:02,620 --> 00:04:03,280 Great. 85 00:04:03,280 --> 00:04:07,590 Die erste Zeile hat file.txt zum Endgerät gedruckt 86 00:04:07,590 --> 00:04:10,160 weil wir fordern GetString einmal. 87 00:04:10,160 --> 00:04:13,170 Wenn wir einen weiteren Anruf musste GetString in unserem Programm, die 88 00:04:13,170 --> 00:04:16,149 nächste Zeile file.txt würde als benutzt worden 89 00:04:16,149 --> 00:04:17,990 Ein auf diesen Ruf. 90 00:04:17,990 --> 00:04:21,050 Auch hier haben wir nicht unser C-Programm modifiziert überhaupt. 91 00:04:21,050 --> 00:04:23,620 Wir sind nur verändern, wie wir es laufen. 92 00:04:23,620 --> 00:04:27,080 Und auch daran erinnern, haben wir nicht weitergeleitet stdout dieses Mal, 93 00:04:27,080 --> 00:04:28,970 so dass die Ausgabe des Programms noch 94 00:04:28,970 --> 00:04:31,040 erscheint am Terminal. 95 00:04:31,040 --> 00:04:33,500 Wir können natürlich umzuleiten sowohl stdin 96 00:04:33,500 --> 00:04:37,320 und stdout wie diese. 97 00:04:37,320 --> 00:04:43,550 Nun enthält file2.txt die erste Zeile des file.txt. 98 00:04:43,550 --> 00:04:46,140 >> Also, mit dieser Operatoren, waren wir in der Lage zu lesen und 99 00:04:46,140 --> 00:04:48,130 Schreiben von Textdateien. 100 00:04:48,130 --> 00:04:51,890 Jetzt wollen wir sehen, wie wir die Ausgabe eines Programms verwenden 101 00:04:51,890 --> 00:04:54,710 der Eingang zu einem anderen Programm. 102 00:04:54,710 --> 00:04:56,650 Also hier ist ein weiteres einfaches C-Programm I 103 00:04:56,650 --> 00:05:00,190 hier hello.c genannt. 104 00:05:00,190 --> 00:05:02,617 Wie Sie sehen können, ist dies gibt einfach "Hallo 105 00:05:02,617 --> 00:05:04,430 da! "an den Benutzer. 106 00:05:04,430 --> 00:05:08,890 Wenn ich will redirect als Eingabe verwenden Sie die Ausgabe von hallo - 107 00:05:08,890 --> 00:05:10,190 ein anderes Programm - 108 00:05:10,190 --> 00:05:13,920 Ich konnte erste umleiten stdout hallo zu einer Datei namens 109 00:05:13,920 --> 00:05:18,960 input.txt, dann leiten Sie den stdin umleiten selben 110 00:05:18,960 --> 00:05:21,190 Datei - input.txt. 111 00:05:21,190 --> 00:05:26,730 So ich tun kann. / Hallo> input.txt. 112 00:05:26,730 --> 00:05:28,810 Drücken Sie die Eingabetaste, um diese auszuführen. 113 00:05:28,810 --> 00:05:31,910 Gefolgt von. / Redirect < 114 00:05:31,910 --> 00:05:35,270 input.txt und auszuführen, dass. 115 00:05:35,270 --> 00:05:38,290 So können wir verkürzen diese ein wenig mit einem Semikolon, das ermöglicht 116 00:05:38,290 --> 00:05:41,360 uns, zwei oder mehrere Befehle auf der gleichen Linie verlaufen. 117 00:05:41,360 --> 00:05:47,920 So kann ich sagen,. / Hallo> input.txt, Semikolon, 118 00:05:47,920 --> 00:05:50,580 . / Redirect 00:05:56,740 >> So funktioniert das, aber es fühlt sich ziemlich unelegant. 120 00:05:56,740 --> 00:05:59,530 Ich meine, brauchen wir wirklich diese Vermittler Textdatei, ist 121 00:05:59,530 --> 00:06:02,520 nicht mehr notwendig, nachdem Umleitung läuft? 122 00:06:02,520 --> 00:06:05,780 Glücklicherweise können wir es vermeiden, diese zusätzliche Text-Datei mit, was 123 00:06:05,780 --> 00:06:07,220 als ein Rohr. 124 00:06:07,220 --> 00:06:13,740 Wenn ich sage, / hallo |.. / Redirect, dann die stdout 125 00:06:13,740 --> 00:06:15,310 das Programm auf der linken Seite - 126 00:06:15,310 --> 00:06:16,740 in diesem Fall, hallo - 127 00:06:16,740 --> 00:06:18,970 wird als Standard-Eingang für die verwendet werden 128 00:06:18,970 --> 00:06:20,370 Programm auf der rechten Seite. 129 00:06:20,370 --> 00:06:24,850 In diesem Fall umzuleiten. Also lasst uns laufen diese. 130 00:06:24,850 --> 00:06:25,930 >> Dort gehen wir. 131 00:06:25,930 --> 00:06:30,080 Wir sehen, dass der Ausgang des Hallo wurde verwendet als Input 132 00:06:30,080 --> 00:06:31,520 für umzuleiten. 133 00:06:31,520 --> 00:06:34,890 Durch Bespannen Befehle zusammen mit Rohren bilden wir, was 134 00:06:34,890 --> 00:06:38,120 als eine Pipeline, da unsere Leistung im Wesentlichen bewegt 135 00:06:38,120 --> 00:06:40,590 durch eine Folge von Befehlen. 136 00:06:40,590 --> 00:06:43,570 Mit Pfeifen, können wir ein paar coole Sachen ohne zu tun 137 00:06:43,570 --> 00:06:45,870 Code schreiben, überhaupt. 138 00:06:45,870 --> 00:06:48,760 Zum Beispiel, sagen wir mal wir wollen wissen, wie viele Dateien 139 00:06:48,760 --> 00:06:50,630 Innere dieses Verzeichnis. 140 00:06:50,630 --> 00:06:55,200 Mit einem Rohr, können wir den Befehl ls mit dem WC zu verbinden - 141 00:06:55,200 --> 00:06:56,460 oder wordcount - 142 00:06:56,460 --> 00:06:57,850 Befehl. 143 00:06:57,850 --> 00:07:02,230 Ls wird jede Datei in dem Verzeichnis stdout auszugeben und 144 00:07:02,230 --> 00:07:08,040 wc wird uns sagen, wie viele Zeilen wurden sie über stdin angegeben. 145 00:07:08,040 --> 00:07:12,440 Also, wenn wir sagen, ls | wc-l - 146 00:07:12,440 --> 00:07:16,800 Versorgung der Option-l zum WC, sie zu erzählen, um Linien zu zählen - 147 00:07:16,800 --> 00:07:19,260 können wir genau sehen, wie viele Dateien 148 00:07:19,260 --> 00:07:21,940 im aktuellen Verzeichnis. 149 00:07:21,940 --> 00:07:24,570 >> Werfen wir also einen Blick auf ein weiteres Beispiel. 150 00:07:24,570 --> 00:07:27,740 Ich habe hier eine Datei namens students.txt, 151 00:07:27,740 --> 00:07:29,600 mit einer Liste von Namen. 152 00:07:29,600 --> 00:07:32,730 Allerdings sind diese Namen nicht in beliebiger Reihenfolge sie alle, und es sieht 153 00:07:32,730 --> 00:07:34,850 wie ein paar Namen wiederholt werden. 154 00:07:34,850 --> 00:07:38,510 Was wir wollen, ist eine Liste von eindeutigen Namen in alphabetischer 155 00:07:38,510 --> 00:07:42,550 Reihenfolge gespeichert in einer Datei namens final.txt. 156 00:07:42,550 --> 00:07:45,210 Wir könnten natürlich, schreiben Sie ein C-Programm, dies für uns zu tun. 157 00:07:45,210 --> 00:07:46,560 Aber es wird nicht unnötig zu 158 00:07:46,560 --> 00:07:48,560 komplexe ziemlich schnell. 159 00:07:48,560 --> 00:07:51,740 Lasst uns stattdessen Rohre und einige built-in-Werkzeugen zu lösen 160 00:07:51,740 --> 00:07:53,300 Dieses Problem. 161 00:07:53,300 --> 00:07:57,760 >> Das erste, was wir tun müssen, ist die Datei lesen students.txt. 162 00:07:57,760 --> 00:08:00,530 Die Katze Befehl wird genau das tun. 163 00:08:00,530 --> 00:08:03,230 Es wird in der angegebenen Datei zu lesen und zu schreiben 164 00:08:03,230 --> 00:08:05,750 dessen Inhalt auf die Standardausgabe. 165 00:08:05,750 --> 00:08:07,570 Nachdem wir die Textdatei gelesen haben, werden wir 166 00:08:07,570 --> 00:08:09,490 möchten die Namen zu sortieren. 167 00:08:09,490 --> 00:08:12,510 Der Befehl sort kann dies für uns erledigen. 168 00:08:12,510 --> 00:08:16,830 Sortieren wird ausgeben die Zeile über stdin an stdout versorgt 169 00:08:16,830 --> 00:08:19,310 in sortierter Reihenfolge. 170 00:08:19,310 --> 00:08:23,450 Zur Versorgung der Inhalt students.txt um 171 00:08:23,450 --> 00:08:29,600 sort stdin, könnten wir eine Pfeife zu Katze und sortieren zu kombinieren. 172 00:08:29,600 --> 00:08:34,440 So kann ich ausführen cat students.txt | sort-und 173 00:08:34,440 --> 00:08:35,640 drücken Sie die Eingabetaste. 174 00:08:35,640 --> 00:08:39,309 Und nun sehen wir den Inhalt der students.txt in 175 00:08:39,309 --> 00:08:40,909 alphabetischer Reihenfolge. 176 00:08:40,909 --> 00:08:42,860 >> So fügen wir einen weiteren Befehl - 177 00:08:42,860 --> 00:08:44,730 uniq oder einzigartig - 178 00:08:44,730 --> 00:08:46,230 unsere Pipeline. 179 00:08:46,230 --> 00:08:49,810 Wie Sie sich vorstellen können, uniq, wenn lieferte eine sortierte Sequenz von 180 00:08:49,810 --> 00:08:53,650 Linien über stdin, wird der Ausgang die einzigartigen Linien. 181 00:08:53,650 --> 00:08:56,910 Deshalb haben wir jetzt cat students.txt 182 00:08:56,910 --> 00:09:00,040 | Sort | uniq. 183 00:09:00,040 --> 00:09:03,330 Schließlich kann man den Ausgang der Pipeline zu Schuß 184 00:09:03,330 --> 00:09:09,090 Datei über cat students.txt | sort | uniq 185 00:09:09,090 --> 00:09:12,440 > Final.txt. 186 00:09:12,440 --> 00:09:16,260 Also, wenn wir final.txt öffnen, haben wir genau das, was wir waren 187 00:09:16,260 --> 00:09:17,270 Suche nach: 188 00:09:17,270 --> 00:09:20,180 eine Liste der eindeutigen Namen in alphabetischer Reihenfolge, 189 00:09:20,180 --> 00:09:22,150 gespeichert in einer Textdatei. 190 00:09:22,150 --> 00:09:26,020 By the way, konnten wir auch gesagt haben sort < 191 00:09:26,020 --> 00:09:32,290 students.txt | uniq> final.txt genau das zu tun 192 00:09:32,290 --> 00:09:35,400 dasselbe, mit jedem der Operatoren wir gesehen haben 193 00:09:35,400 --> 00:09:36,580 Dieses Video. 194 00:09:36,580 --> 00:09:39,540 >> Mein Name ist Tommy, und dies ist CS50.