1 00:00:00,000 --> 00:00:07,810 2 00:00:07,810 --> 00:00:09,840 >> JASON Hirschhorn: Selamat datang, semua orang, untuk Minggu 6. 3 00:00:09,840 --> 00:00:14,790 Saya senang melihat Anda semua hidup dan sehat setelah Quiz 0, karena saya tahu bahwa 4 00:00:14,790 --> 00:00:15,810 agak kasar. 5 00:00:15,810 --> 00:00:18,370 Tapi untungnya, kalian semua memang sangat luar biasa. 6 00:00:18,370 --> 00:00:21,680 Dan sehingga indah. 7 00:00:21,680 --> 00:00:25,840 Jika Anda berada di bagian saya, saya telah diberikan sebagian Anda kembali kuis Anda sudah. 8 00:00:25,840 --> 00:00:28,050 >> Beberapa dari kalian, aku bertemu setelah kelas. 9 00:00:28,050 --> 00:00:32,360 Dan jika Anda seorang mahasiswa ekstensi dan Anda belum menerima kuis Anda kembali 10 00:00:32,360 --> 00:00:35,490 Namun, TF Anda mungkin bekerja di atasnya dan grading, dan akan mendapatkannya kembali 11 00:00:35,490 --> 00:00:36,490 Anda segera. 12 00:00:36,490 --> 00:00:39,650 Jadi mahasiswa ekstensi saya yang menonton sekarang - mudah-mudahan hidup - 13 00:00:39,650 --> 00:00:42,880 Aku akan mendapatkan kuis Anda lama juga. 14 00:00:42,880 --> 00:00:45,670 >> Agenda kami untuk hari ini adalah sebagai berikut. 15 00:00:45,670 --> 00:00:50,170 Pertama, kita akan membahas beberapa sumber daya yang CS50 memberikan kepada Anda. 16 00:00:50,170 --> 00:00:54,590 Kita akan pergi ke Quiz 0 berikutnya, dan Saya akan menjawab pertanyaan siapa pun 17 00:00:54,590 --> 00:00:57,360 memiliki sekitar masalah tertentu. 18 00:00:57,360 --> 00:01:02,050 Dan kemudian, kita akan lebih file I / O dan masalah set 5. 19 00:01:02,050 --> 00:01:07,360 Kedua topik terakhir akan mengambil merupakan bagian terbesar dari bagian hari ini. 20 00:01:07,360 --> 00:01:11,680 >> Aku meletakkan daftar ini setiap minggu sebagai pengingat untuk Anda semua, tapi inti 21 00:01:11,680 --> 00:01:14,650 bagian, kita hanya memiliki 90 menit - kami tidak mampu menutupi segala sesuatu yang saya 22 00:01:14,650 --> 00:01:16,280 akan senang untuk menutupi kalian. 23 00:01:16,280 --> 00:01:21,170 Tapi kita memiliki satu ton sumber daya untuk Anda untuk memanfaatkan saat Anda mengenal 24 00:01:21,170 --> 00:01:24,000 materi dan bekerja melalui masalah Anda set. 25 00:01:24,000 --> 00:01:30,810 >> Sebuah pengingat bahwa saya memiliki online teks kotak, diatur untuk Anda untuk mengisi jika Anda 26 00:01:30,810 --> 00:01:33,250 memiliki umpan balik bagi saya, baik positif maupun 27 00:01:33,250 --> 00:01:35,180 konstruktif, tentang bagian. 28 00:01:35,180 --> 00:01:38,600 URL yang terletak tepat di sini. 29 00:01:38,600 --> 00:01:43,250 Jadi tolong, luangkan waktu jika Anda memiliki umpan balik, baik pada saat bagian, 30 00:01:43,250 --> 00:01:48,030 atau setelah, atau setelah Anda menonton video online, untuk memberikan tanggapan Anda. 31 00:01:48,030 --> 00:01:52,100 Saya sangat menghargai setiap dan semua itu. 32 00:01:52,100 --> 00:01:55,730 >> Jadi saya sudah memiliki percakapan kecil dengan banyak saya 33 00:01:55,730 --> 00:01:59,350 siswa sepanjang minggu - seperti yang saya tangan kuis kembali, berbicara tentang 34 00:01:59,350 --> 00:02:01,480 Tentu saja, melihat bagaimana Anda lakukan. 35 00:02:01,480 --> 00:02:05,120 Dan salah satu tema telah datang atas dan lebih dalam berbicara tentang - di 36 00:02:05,120 --> 00:02:05,660 tertentu - 37 00:02:05,660 --> 00:02:07,710 masalah set. 38 00:02:07,710 --> 00:02:13,090 Dan saya telah dikemas tema yang di papan sekarang. 39 00:02:13,090 --> 00:02:16,630 >> Pada dasarnya, ada perbedaan antara balik dalam sesuatu yang 40 00:02:16,630 --> 00:02:19,590 dilakukan dengan benar dan sesuatu yang dilakukan dengan baik. 41 00:02:19,590 --> 00:02:22,920 Kebanyakan orang telah melakukan fantastis dalam hal kebenaran - 42 00:02:22,920 --> 00:02:25,460 5 atau 4 pada semua psets. 43 00:02:25,460 --> 00:02:27,930 Kebanyakan orang yang mendapatkan mereka sepanjang waktu. 44 00:02:27,930 --> 00:02:31,150 >> Namun, hanya karena Anda telah melakukan sesuatu yang benar tidak berarti Anda sudah 45 00:02:31,150 --> 00:02:34,450 melakukan sesuatu yang elegan, atau efisien, atau sebersih Anda 46 00:02:34,450 --> 00:02:35,270 bisa melakukannya. 47 00:02:35,270 --> 00:02:36,790 Dan itulah yang desain - 48 00:02:36,790 --> 00:02:39,230 dan yang lebih rendah derajat, gaya - 49 00:02:39,230 --> 00:02:40,450 sumbu adalah untuk. 50 00:02:40,450 --> 00:02:45,130 Jadi saya mendorong Anda semua, dan TF lainnya mendorong kalian, tidak hanya turn 51 00:02:45,130 --> 00:02:48,320 dalam hal-hal yang benar, tapi giliran dalam hal-hal yang dikodekan dengan baik. 52 00:02:48,320 --> 00:02:53,060 >> Tidak melakukan yang tidak perlu FOR loop, tidak menghitung ulang variabel jika 53 00:02:53,060 --> 00:02:53,800 Anda tidak perlu. 54 00:02:53,800 --> 00:02:58,520 Misalnya, melihat kembali ke permasalahan yang 4, ketika menempatkan batu bata di 55 00:02:58,520 --> 00:03:03,070 layar, setiap baris - setiap bata dalam diberikan baris memiliki sama y-koordinat - 56 00:03:03,070 --> 00:03:04,390 ketinggian koordinat yang sama. 57 00:03:04,390 --> 00:03:07,930 >> Sehingga y-koordinat tidak perlu dihitung dalam interior 58 00:03:07,930 --> 00:03:11,070 bersarang UNTUK loop yang mungkin Anda gunakan untuk menempatkan orang-bata di layar. 59 00:03:11,070 --> 00:03:14,030 Hanya perlu dihitung setiap kali Anda beralih berturut-turut, atau 60 00:03:14,030 --> 00:03:15,200 bergerak turun berturut-turut. 61 00:03:15,200 --> 00:03:19,760 Jadi mengatakan jika ada 10 batu bata di baris, masing-masing batu bata dapat memiliki yang sama 62 00:03:19,760 --> 00:03:22,260 y-koordinat, dan bahwa y-koordinat hanya dapat dihitung 63 00:03:22,260 --> 00:03:23,550 sekali untuk semua orang. 64 00:03:23,550 --> 00:03:27,810 >> Tidak perlu dihitung 10 kali, juga tidak bahwa perhitungan kebutuhan 65 00:03:27,810 --> 00:03:30,220 terjadi di aktual fungsi panggilan - 66 00:03:30,220 --> 00:03:33,020 fungsi panggilan gracked baru. 67 00:03:33,020 --> 00:03:37,820 Jadi jika itu sedikit membingungkan untuk Anda, lebih umum, hal-hal yang 68 00:03:37,820 --> 00:03:40,730 tidak perlu terjadi setiap saat Anda pergi melalui loop FOR tidak boleh 69 00:03:40,730 --> 00:03:42,900 masukkan ke dalam loop FOR, dan seharusnya tidak terjadi setiap kali Anda pergi 70 00:03:42,900 --> 00:03:44,080 melalui loop FOR. 71 00:03:44,080 --> 00:03:49,270 >> Desain Contoh lain yang baik kita melihat dalam Minggu 3 untuk 15, Anda bisa menjaga 72 00:03:49,270 --> 00:03:50,500 track dari nol. 73 00:03:50,500 --> 00:03:53,600 Jadi, ketika Anda menginisialisasi papan, Anda menyimpan - dalam sebuah variabel global, mungkin - 74 00:03:53,600 --> 00:03:56,140 x dan y-koordinat nol. 75 00:03:56,140 --> 00:03:57,520 Dan kemudian setiap kali Anda - 76 00:03:57,520 --> 00:04:00,310 dalam fungsi gerakan Anda, setiap kali Anda membuat langkah sukses, Anda memperbarui 77 00:04:00,310 --> 00:04:02,040 lokasi nol. 78 00:04:02,040 --> 00:04:06,240 >> Itu akan menyelamatkan Anda dari keharusan untuk melakukan bersarang UNTUK loop untuk melihat melalui 79 00:04:06,240 --> 00:04:10,700 naik setiap kali Anda bergerak dalam fungsi dan menemukan nol, atau menemukan ubin, 80 00:04:10,700 --> 00:04:12,460 dan kemudian memeriksa apa sebelahnya. 81 00:04:12,460 --> 00:04:16,329 Sebaliknya, Anda harus lokasi nol, Anda hanya dapat melihat atas, di bawah, 82 00:04:16,329 --> 00:04:21,160 dan ke kiri dan kanan itu, untuk menemukan ubin yang Anda cari. 83 00:04:21,160 --> 00:04:24,970 >> Jadi dalam hal program kami menulis, mereka tidak pernah cukup besar 84 00:04:24,970 --> 00:04:28,580 bahwa beberapa keputusan desain ini benar-benar akan menghambat Anda 85 00:04:28,580 --> 00:04:31,670 program, atau membuatnya berjalan lebih lambat, atau bahkan kehabisan memori. 86 00:04:31,670 --> 00:04:35,030 Tapi kami masih mendorong kalian menulis sebagai elegan dan 87 00:04:35,030 --> 00:04:36,450 kode seefisien mungkin. 88 00:04:36,450 --> 00:04:39,910 >> Jadi, jika Anda berakhir menulis hal-hal yang memiliki signifikan lebih besar 89 00:04:39,910 --> 00:04:44,660 ruang lingkup, mereka akan ditulis dengan baik desain selain menjadi benar. 90 00:04:44,660 --> 00:04:46,300 Jadi sejumlah Anda memiliki membawa itu keluar. 91 00:04:46,300 --> 00:04:48,560 Itu sesuatu yang kita cari - sesuatu yang kita akan terus 92 00:04:48,560 --> 00:04:49,840 mendorong kalian pada. 93 00:04:49,840 --> 00:04:52,460 >> Jika Anda pernah memiliki pertanyaan tentang desain program Anda, jangan ragu 94 00:04:52,460 --> 00:04:56,870 untuk menjangkau saya, dan saya senang untuk berjalan melalui program Anda dengan Anda, 95 00:04:56,870 --> 00:05:01,320 dan menunjukkan beberapa desain keputusan yang Anda buat, dan memberikan beberapa 96 00:05:01,320 --> 00:05:06,240 saran tentang cara untuk membuat bahkan keputusan desain yang lebih baik. 97 00:05:06,240 --> 00:05:08,870 >> Jadi kita akan melanjutkan untuk berbicara tentang Quiz 0. 98 00:05:08,870 --> 00:05:11,300 Sebelum kita melakukan itu, apakah ada yang memiliki pertanyaan tentang apa yang 99 00:05:11,300 --> 00:05:14,252 Saya sudah pelajari sejauh ini? 100 00:05:14,252 --> 00:05:21,500 >> [Gemerisik NOISE] 101 00:05:21,500 --> 00:05:22,750 >> JASON Hirschhorn: Tujuh detik. 102 00:05:22,750 --> 00:05:23,250 OK. 103 00:05:23,250 --> 00:05:24,970 Mari kita bicara tentang Quiz 0 untuk sedikit. 104 00:05:24,970 --> 00:05:26,700 Sebagian besar dari Anda memiliki Quiz Anda 0 s kembali. 105 00:05:26,700 --> 00:05:29,820 Jika Anda tidak, mudah-mudahan Anda ingat sedikit. 106 00:05:29,820 --> 00:05:34,770 Tetapi jika Anda telah mengambil Kuis 0, maka Anda juga memiliki akses ke PDF secara online di 107 00:05:34,770 --> 00:05:35,890 solusi sampel. 108 00:05:35,890 --> 00:05:39,480 >> Apakah Ada yang punya pertanyaan sebelum kita melompat ke dalam bahan minggu tentang 109 00:05:39,480 --> 00:05:41,520 masalah khusus pada Quiz 0 - 110 00:05:41,520 --> 00:05:44,630 mengapa jawabannya adalah apa itu? 111 00:05:44,630 --> 00:05:47,255 Apakah ada orang bingung tentang apa pun? 112 00:05:47,255 --> 00:05:50,230 Bahkan jika Anda punya masalah yang tepat, tapi hanya ingin saya untuk menjelaskan sedikit 113 00:05:50,230 --> 00:05:52,640 lagi, saya senang untuk melakukannya sekarang. 114 00:05:52,640 --> 00:05:57,800 >> Jadi saya meminta kalian untuk datang siap dengan beberapa 115 00:05:57,800 --> 00:05:59,440 pikiran tentang Kuis 0. 116 00:05:59,440 --> 00:06:02,660 Jadi yang ingin mendapatkan kita dimulai dengan pertanyaan atau 117 00:06:02,660 --> 00:06:04,655 komentar mengenai Kuis 0? 118 00:06:04,655 --> 00:06:07,435 119 00:06:07,435 --> 00:06:10,410 >> [PAPER gemeresik] 120 00:06:10,410 --> 00:06:11,470 >> JASON Hirschhorn: Tidak semua orang lakukan dengan sempurna. 121 00:06:11,470 --> 00:06:12,720 Jadi saya tahu [TERTAWA] 122 00:06:12,720 --> 00:06:15,950 harus ada beberapa pertanyaan tentang Kuis 0. 123 00:06:15,950 --> 00:06:27,940 124 00:06:27,940 --> 00:06:28,590 OK. 125 00:06:28,590 --> 00:06:29,210 Ya. 126 00:06:29,210 --> 00:06:29,600 Ompica. 127 00:06:29,600 --> 00:06:30,520 >> OMPICA: Number 10. 128 00:06:30,520 --> 00:06:33,560 >> JASON Hirschhorn: Number 10. 129 00:06:33,560 --> 00:06:35,400 Yang satu adalah nomor 10? 130 00:06:35,400 --> 00:06:35,840 >> OMPICA: The - 131 00:06:35,840 --> 00:06:36,420 >> JASON Hirschhorn: I haven't - 132 00:06:36,420 --> 00:06:37,670 >> OMPICA: The meliputi - 133 00:06:37,670 --> 00:06:40,060 134 00:06:40,060 --> 00:06:42,180 >> JASON Hirschhorn: Nomor 10 adalah delapan untuk i - menulis delapan sampai i? 135 00:06:42,180 --> 00:06:42,980 >> OMPICA: Ya. 136 00:06:42,980 --> 00:06:43,630 >> JASON Hirschhorn: OK. 137 00:06:43,630 --> 00:06:47,390 Jadi pertanyaan lain Anda bisa memiliki bertanya adalah saya terus mata? 138 00:06:47,390 --> 00:06:48,630 Jawabannya adalah ya. 139 00:06:48,630 --> 00:06:52,060 Pada bagian sebelum kuis, saya bertanya kalian untuk kode kedua Sterling dan 140 00:06:52,060 --> 00:06:52,980 delapan sampai i. 141 00:06:52,980 --> 00:06:54,770 Keduanya terjadi muncul di kuis. 142 00:06:54,770 --> 00:06:57,510 Jadi mudah-mudahan, Anda dibayar memperhatikan itu. 143 00:06:57,510 --> 00:07:02,520 >> Dan jika Anda memiliki, maka Anda akan memiliki mungkin dilakukan dengan baik pada dua. 144 00:07:02,520 --> 00:07:06,030 Tapi delapan sampai i, kita tidak benar-benar kode di kelas, tapi itu, sekali lagi, 145 00:07:06,030 --> 00:07:07,500 tanya pada kuis. 146 00:07:07,500 --> 00:07:13,270 Jadi beberapa hal untuk mengambil diperhatikan ketika coding delapan sampai i. 147 00:07:13,270 --> 00:07:17,320 Hal pertama, per pertanyaan, adalah yang Anda butuhkan untuk memeriksa apakah string 148 00:07:17,320 --> 00:07:20,300 adalah sama dengan nol. 149 00:07:20,300 --> 00:07:28,060 >> Beberapa orang mencoba untuk memeriksa di kemudian hari dalam program jika s braket saya adalah - 150 00:07:28,060 --> 00:07:30,940 sehingga karakter tertentu dalam String - sama dengan nol. 151 00:07:30,940 --> 00:07:35,600 Tapi ingat, null yang pada dasarnya - ada baiknya untuk memikirkan 152 00:07:35,600 --> 00:07:39,100 null sebagai pointer nol - pointer ke nol - 153 00:07:39,100 --> 00:07:40,920 suatu tempat dalam memori di mana Anda tidak pernah bisa mengakses. 154 00:07:40,920 --> 00:07:44,730 >> Jadi jika ada sesuatu yang sama dengan nol, Anda tahu bahwa itu belum diinisialisasi, 155 00:07:44,730 --> 00:07:46,430 atau tidak ada di sana. 156 00:07:46,430 --> 00:07:50,950 Jadi s adalah bintang char, s braket i adalah char. 157 00:07:50,950 --> 00:07:57,410 Jadi masuk akal untuk membandingkan s untuk null, tapi tidak s braket i ke null. 158 00:07:57,410 --> 00:07:59,390 Tapi sekali lagi - jadi itu hal pertama bahwa Anda lakukan - 159 00:07:59,390 --> 00:08:03,510 periksa untuk memastikan bahwa Anda benar-benar mendapat string nyata. 160 00:08:03,510 --> 00:08:08,020 >> Selanjutnya, Anda ingin pergi melalui masing-masing karakter dalam string. 161 00:08:08,020 --> 00:08:12,500 Dan sehingga akan menjadi seperti s braket i, misalnya, jika saya adalah iterator Anda. 162 00:08:12,500 --> 00:08:17,250 Dan mengambil karakter itu, dan mendapatkan nilai yang sebenarnya. 163 00:08:17,250 --> 00:08:21,800 Anda telah itu disimpan sebagai char, tapi nilai ASCII nol - 164 00:08:21,800 --> 00:08:23,010 nol sebagai karakter - 165 00:08:23,010 --> 00:08:25,450 tidak benar-benar integer nol. 166 00:08:25,450 --> 00:08:28,700 Ini beberapa nomor lain yang dapat Anda mencari dalam tabel ASCII. 167 00:08:28,700 --> 00:08:30,790 >> Jadi salah satu cara untuk mengoreksi untuk itu - mungkin cara terbaik untuk mengoreksi 168 00:08:30,790 --> 00:08:33,760 bahwa - adalah mengurangi dari itu nilai karakter - 169 00:08:33,760 --> 00:08:35,140 nol sebagai karakter. 170 00:08:35,140 --> 00:08:38,490 Jadi dikurangi kutip tunggal, nol, kutip tunggal lain. 171 00:08:38,490 --> 00:08:44,620 Itu akan mengambil apa pun nomor yang Anda miliki sebagai char, dan mendapatkannya sama dengan 172 00:08:44,620 --> 00:08:46,720 jumlah sebagai integer yang sebenarnya. 173 00:08:46,720 --> 00:08:50,300 >> Dan yang sangat mirip dengan pendekatan banyak orang mengambil di 174 00:08:50,300 --> 00:08:52,800 masalah set 2, dengan Caesar dan Viginere - 175 00:08:52,800 --> 00:08:55,160 mereka cipher, ketika Anda yang berputar mereka. 176 00:08:55,160 --> 00:08:59,210 Jadi setelah Anda memilikinya sebagai nomor dari nol sampai sembilan, kemudian - tergantung pada 177 00:08:59,210 --> 00:09:02,750 di mana ia pergi dalam jumlah ultimate - Anda perlu kalikan 178 00:09:02,750 --> 00:09:04,120 oleh kekuatan dari 10. 179 00:09:04,120 --> 00:09:07,340 >> Beberapa orang pindah dari belakang ke depan, dan dikalikan individu 180 00:09:07,340 --> 00:09:08,940 nomor dengan kekuatan 10. 181 00:09:08,940 --> 00:09:11,160 Beberapa orang pindah dari depan ke belakang - 182 00:09:11,160 --> 00:09:14,430 dan begitu mengambil tertinggi memesan angka pertama - 183 00:09:14,430 --> 00:09:18,190 dan akan menyelamatkan mereka dalam variabel counter global. 184 00:09:18,190 --> 00:09:20,880 Dan kemudian setiap kali melalui FOR lingkaran, kalikan raksasa global yang 185 00:09:20,880 --> 00:09:25,640 melawan variabel sebesar 10, untuk membuat ruang untuk char berikutnya. 186 00:09:25,640 --> 00:09:28,750 >> Jadi itu sedikit membingungkan tanpa saya menulis di papan tulis. 187 00:09:28,750 --> 00:09:31,550 Tapi larutan sampel tersedia untuk Anda. 188 00:09:31,550 --> 00:09:32,870 Tetapi mereka adalah hal-hal besar kita cari. 189 00:09:32,870 --> 00:09:36,400 Juga cek untuk memastikan bahwa setiap karakter individu memang 190 00:09:36,400 --> 00:09:39,780 karakter antara nol dan sembilan, dan tidak beberapa karakter lain, seperti A, 191 00:09:39,780 --> 00:09:41,160 misalnya. 192 00:09:41,160 --> 00:09:43,150 >> Itulah hal-hal yang kita cari dalam pertanyaan itu. 193 00:09:43,150 --> 00:09:46,510 194 00:09:46,510 --> 00:09:47,980 Apakah itu menjawab pertanyaan Anda? 195 00:09:47,980 --> 00:09:49,320 >> OMPICA: Ya. 196 00:09:49,320 --> 00:09:50,240 >> JASON Hirschhorn: OK. 197 00:09:50,240 --> 00:09:53,940 Apakah ada pertanyaan lain tentang Kuis 0? 198 00:09:53,940 --> 00:09:55,440 Bagaimana dengan kompilasi? 199 00:09:55,440 --> 00:09:56,740 Semua orang kompilasi benar? 200 00:09:56,740 --> 00:09:58,370 Tidak. 201 00:09:58,370 --> 00:09:58,840 Ada - 202 00:09:58,840 --> 00:10:01,010 [TERTAWA] 203 00:10:01,010 --> 00:10:03,265 Pertanyaan tentang proses kompilasi? 204 00:10:03,265 --> 00:10:06,050 205 00:10:06,050 --> 00:10:06,966 Wow. 206 00:10:06,966 --> 00:10:11,090 >> [PAPER gemeresik] 207 00:10:11,090 --> 00:10:11,520 >> JASON Hirschhorn: Ya. 208 00:10:11,520 --> 00:10:11,700 Michael. 209 00:10:11,700 --> 00:10:14,140 >> MICHAEL: Apakah nomor 7 - random? 210 00:10:14,140 --> 00:10:16,500 >> JASON Hirschhorn: Nomor 7. 211 00:10:16,500 --> 00:10:20,670 Nomor 7 adalah mendapatkan integer acak. 212 00:10:20,670 --> 00:10:21,110 Excellent. 213 00:10:21,110 --> 00:10:25,630 Jadi Anda diberi sebuah integer a dan b bilangan bulat, dan Anda ingin acak 214 00:10:25,630 --> 00:10:28,710 integer antara a dan b. 215 00:10:28,710 --> 00:10:31,740 Kami benar-benar bisa menulis satu ini pada papan, karena yang satu ini 216 00:10:31,740 --> 00:10:33,320 adalah satu baris kode - 217 00:10:33,320 --> 00:10:34,390 salah satu cara untuk melakukannya. 218 00:10:34,390 --> 00:10:37,810 >> Jadi kita diberikan drand sebagai fungsi yang bisa kita gunakan. 219 00:10:37,810 --> 00:10:38,820 Dan apa drand - 220 00:10:38,820 --> 00:10:40,290 dengan asumsi itu sudah diunggulkan - 221 00:10:40,290 --> 00:10:42,316 apa drand kembali? 222 00:10:42,316 --> 00:10:44,840 >> MICHAEL: Sebuah float antara 0,0 dan 1,0. 223 00:10:44,840 --> 00:10:45,530 >> JASON Hirschhorn: Sejumlah - ya. 224 00:10:45,530 --> 00:10:47,910 Sejumlah antara 0 dan 1. 225 00:10:47,910 --> 00:10:51,760 Dan kami telah b dan. 226 00:10:51,760 --> 00:10:55,480 Dan kemudian kita memiliki nomor acak kami antara 0 dan 1 diberikan kepada kita oleh drand. 227 00:10:55,480 --> 00:11:01,480 228 00:11:01,480 --> 00:11:06,630 Beberapa orang mencoba untuk menempatkan b, atau b dikurangi , atau sesuatu di dalam mereka 229 00:11:06,630 --> 00:11:07,960 kurung. 230 00:11:07,960 --> 00:11:11,210 Itu berarti bahwa mereka argumen untuk fungsi ini. 231 00:11:11,210 --> 00:11:13,450 >> drand tidak mengambil argumen - seperti getString tidak 232 00:11:13,450 --> 00:11:14,330 tidak mengambil argumen. 233 00:11:14,330 --> 00:11:16,600 Jadi itu hanya terbuka paren, dekat Paren - dan bahwa, itu sendiri, adalah 234 00:11:16,600 --> 00:11:17,330 fungsi panggil. 235 00:11:17,330 --> 00:11:19,770 Dan yang memberikan nomor antara 0 dan 1. 236 00:11:19,770 --> 00:11:22,820 Tentu saja, kami memiliki berbagai macam bahwa angka-angka bisa masuk 237 00:11:22,820 --> 00:11:28,470 >> Katakanlah, jika b adalah 10 dan 5 adalah, kita benar-benar ingin nomor dengan kisaran 5. 238 00:11:28,470 --> 00:11:36,940 Jadi hal berikutnya yang perlu kita lakukan adalah kalikan ini dengan kisaran b minus. 239 00:11:36,940 --> 00:11:40,380 Jadi asumsi yang dikalikan. 240 00:11:40,380 --> 00:11:42,590 Dan itu akan memberi kita nomor dalam kisaran tertentu. 241 00:11:42,590 --> 00:11:46,610 Dan kisaran tertentu menjadi perbedaan antara b minus. 242 00:11:46,610 --> 00:11:50,030 >> Dan akhirnya, itu hanya akan memberikannya dari - mengatakan kisaran antara b minus 243 00:11:50,030 --> 00:11:52,520 adalah 5, yang akan memberi kita angka dari 0 sampai 5. 244 00:11:52,520 --> 00:11:56,000 Tetapi jika pada kenyataannya 5, kita perlu meningkatkan kisaran ini sampai ke tempat itu 245 00:11:56,000 --> 00:12:01,380 sebenarnya seharusnya, dengan menambahkan. 246 00:12:01,380 --> 00:12:02,580 Sehingga mendapat logika yang tepat. 247 00:12:02,580 --> 00:12:03,745 Dan kemudian, Anda akan memiliki pertanyaan lain? 248 00:12:03,745 --> 00:12:04,547 >> MICHAEL: No 249 00:12:04,547 --> 00:12:06,010 Aku hanya merasa benar-benar bodoh sekarang. 250 00:12:06,010 --> 00:12:06,405 [TERTAWA] 251 00:12:06,405 --> 00:12:06,730 >> JASON Hirschhorn: No 252 00:12:06,730 --> 00:12:08,640 Jangan merasa benar-benar bodoh. 253 00:12:08,640 --> 00:12:10,560 Sejumlah orang berjuang dengan pertanyaan ini. 254 00:12:10,560 --> 00:12:13,920 Dan kemudian, pertanyaan lain adalah, drand, Anda katakan, memberikan pelampung - 255 00:12:13,920 --> 00:12:14,940 kembali pelampung. 256 00:12:14,940 --> 00:12:18,020 Tetapi fungsi ini benar-benar meminta untuk integer dikembalikan. 257 00:12:18,020 --> 00:12:23,700 >> Anda tidak perlu membuang ini secara eksplisit ke integer, karena ini 258 00:12:23,700 --> 00:12:29,090 operasi akan memperlakukannya sebagai semua mengapung - sebagai angka floating point. 259 00:12:29,090 --> 00:12:31,570 Seperti keinginan ini - bahkan jika hal ini adalah bilangan bulat, hal ini akan 260 00:12:31,570 --> 00:12:32,890 dikalikan dengan benar. 261 00:12:32,890 --> 00:12:34,000 Semua perkalian akan bekerja. 262 00:12:34,000 --> 00:12:35,060 Anda tidak perlu membuang sini. 263 00:12:35,060 --> 00:12:36,480 Bahkan, Anda tidak harus membuangnya. 264 00:12:36,480 --> 00:12:37,310 >> Itu akan - 265 00:12:37,310 --> 00:12:40,750 jika Anda akan melemparkan nomor itu antara 0 dan 1 - 266 00:12:40,750 --> 00:12:42,680 nomor acak, floating point - 267 00:12:42,680 --> 00:12:47,850 maka itu baik akan hanya 0 atau 1 menjadi, jadi Anda akan kehilangan semua presisi itu. 268 00:12:47,850 --> 00:12:50,120 Tetapi pada akhirnya, ketika Anda kembali, maka secara otomatis akan 269 00:12:50,120 --> 00:12:51,620 dikirim kembali sebagai integer. 270 00:12:51,620 --> 00:12:56,870 Jadi Anda tidak perlu melakukan bahwa casting sendiri. 271 00:12:56,870 --> 00:13:00,810 >> Jadi ini adalah jawaban untuk pertanyaan itu, nomor 7. 272 00:13:00,810 --> 00:13:02,190 Ada pertanyaan lain pada Quiz 0? 273 00:13:02,190 --> 00:13:03,300 Ya, Annie. 274 00:13:03,300 --> 00:13:05,050 >> ANNIE: Kapan kita menggunakan rekursif - 275 00:13:05,050 --> 00:13:07,850 kapan kita menggunakan loop berulang? 276 00:13:07,850 --> 00:13:10,210 >> JASON Hirschhorn: Kapan Anda menggunakan recursive - jadi lebih umum, 277 00:13:10,210 --> 00:13:14,110 pro dan kontra dari rekursi dibandingkan pendekatan iteratif. 278 00:13:14,110 --> 00:13:17,110 Ada yang bisa menawarkan pro atau con? 279 00:13:17,110 --> 00:13:19,460 Silahkan? 280 00:13:19,460 --> 00:13:20,140 Tidak bisa siapa pun. 281 00:13:20,140 --> 00:13:22,526 Siapa yang bisa menawarkan pro atau con? 282 00:13:22,526 --> 00:13:26,963 >> [PAPER gemeresik] 283 00:13:26,963 --> 00:13:29,730 >> SISWA 1: Rekursif kurang coding - mengetik kurang? 284 00:13:29,730 --> 00:13:33,170 >> JASON Hirschhorn: Jadi secara umum, rekursi khususnya, fungsi - 285 00:13:33,170 --> 00:13:35,750 atau algoritma seperti merge sort - yang cocok 286 00:13:35,750 --> 00:13:37,300 untuk pendekatan rekursif - 287 00:13:37,300 --> 00:13:40,710 mungkin akan lebih mudah kode rekursif. 288 00:13:40,710 --> 00:13:43,940 Dan hanya lebih masuk akal untuk melakukannya secara rekursif. 289 00:13:43,940 --> 00:13:46,230 Sehingga akan menjadi pro dengan rekursi. 290 00:13:46,230 --> 00:13:46,610 Lainnya? 291 00:13:46,610 --> 00:13:47,467 Ya? 292 00:13:47,467 --> 00:13:49,240 >> SISWA 2: Con ke rekursi - 293 00:13:49,240 --> 00:13:50,940 Menggunakan lebih banyak memori. 294 00:13:50,940 --> 00:13:52,200 >> JASON Hirschhorn: Jadi tepat. 295 00:13:52,200 --> 00:13:55,720 Sebuah fungsi rekursif akan terus menambahkan tumpukan frame ke stack. 296 00:13:55,720 --> 00:13:59,690 Jadi jika Anda beroperasi pada banyak angka, dan harus memanggil ini 297 00:13:59,690 --> 00:14:02,560 berfungsi banyak, maka Anda tentu akan mengambil lebih banyak memori, sementara 298 00:14:02,560 --> 00:14:05,810 pendekatan iteratif hanya akan menempatkan satu tumpukan bingkai di stack, karena 299 00:14:05,810 --> 00:14:08,420 itu semua terjadi dalam satu fungsi. 300 00:14:08,420 --> 00:14:11,010 >> Setiap pro dan kontra lainnya? 301 00:14:11,010 --> 00:14:11,500 Ya. 302 00:14:11,500 --> 00:14:12,550 >> SISWA 3: Pro untuk rekursi. 303 00:14:12,550 --> 00:14:15,950 Anda tidak harus menentukan di memajukan berapa kali 304 00:14:15,950 --> 00:14:17,660 kode harus diulang. 305 00:14:17,660 --> 00:14:22,810 Anda dapat memiliki jumlah yang telah ditetapkan kali bahwa Anda harus iterate, kemudian 306 00:14:22,810 --> 00:14:26,420 rekursi lebih baik, karena dibutuhkan hasil tersebut. 307 00:14:26,420 --> 00:14:27,780 >> JASON Hirschhorn: Saya pikir itu benar. 308 00:14:27,780 --> 00:14:30,770 Tapi saya pikir dalam kedua kasus Anda tidak akan pernah - 309 00:14:30,770 --> 00:14:33,290 Anda mungkin akan mendapatkan beberapa masukan dari pengguna. 310 00:14:33,290 --> 00:14:35,990 Atau fungsi ini akan memiliki beberapa masukan yang akan menentukan berapa kali 311 00:14:35,990 --> 00:14:36,730 harus dijalankan. 312 00:14:36,730 --> 00:14:39,520 Jadi secara umum, Anda tidak akan kode keras - bahkan dalam pendekatan berulang - bagaimana 313 00:14:39,520 --> 00:14:40,940 berkali-kali loop yang harus dijalankan. 314 00:14:40,940 --> 00:14:46,100 315 00:14:46,100 --> 00:14:48,670 >> Apakah Anda memiliki lain Anda memikirkan, Annie? 316 00:14:48,670 --> 00:14:49,330 OK. 317 00:14:49,330 --> 00:14:51,650 Jadi mereka mungkin dua - 318 00:14:51,650 --> 00:14:54,370 pro terbesar dan terbesar con ke rekursif dibandingkan 319 00:14:54,370 --> 00:14:57,080 pendekatan iteratif. 320 00:14:57,080 --> 00:14:57,690 OK. 321 00:14:57,690 --> 00:14:59,465 Apa pun di Quiz 0? 322 00:14:59,465 --> 00:15:08,940 323 00:15:08,940 --> 00:15:09,920 >> Mari kita lanjutkan. 324 00:15:09,920 --> 00:15:15,260 File I / O. Ada singkat indah minggu ini pada file I / O yang diharapkan 325 00:15:15,260 --> 00:15:19,270 Anda telah menyaksikan beberapa kali, dan dikagumi. 326 00:15:19,270 --> 00:15:22,910 Banyak pekerjaan yang masuk ke itu, dan saya sudah mendengar itu gila-gilaan membantu. 327 00:15:22,910 --> 00:15:25,740 Saya juga termasuk link pada slide ini, jika anda belum punya 328 00:15:25,740 --> 00:15:29,160 kesempatan untuk menonton 10 kali. 329 00:15:29,160 --> 00:15:35,280 >> Jadi, kita akan pergi sebentar selama langkah utama untuk membuka dan bekerja 330 00:15:35,280 --> 00:15:38,400 dengan file, dan kemudian kita akan menyelam ke masalah coding sebelum 331 00:15:38,400 --> 00:15:40,400 memeriksa set masalah. 332 00:15:40,400 --> 00:15:44,330 Jadi sekali lagi, aku akan menempatkan ini pada layar, tapi aku akan bicara untuk 333 00:15:44,330 --> 00:15:47,630 hanya satu menit tentang apa yang kita lakukan di sini dengan berkas I/O-- 334 00:15:47,630 --> 00:15:49,090 apa artinya? 335 00:15:49,090 --> 00:15:55,280 >> Itu berarti bahwa kita dapat membuat kita program, dan kemudian memiliki program kami 336 00:15:55,280 --> 00:16:00,370 keluar, dan tidak membuat dampak apapun pada dunia luar program kami. 337 00:16:00,370 --> 00:16:04,630 Tapi ketika kita mulai bekerja dengan file - baik membaca mereka dan menciptakan 338 00:16:04,630 --> 00:16:10,460 mereka - kita dapat memiliki beberapa efek pada dunia luar program kami. 339 00:16:10,460 --> 00:16:15,440 >> Sama seperti jika Microsoft Word tidak bisa untuk membuat dokumen Word, kemudian 340 00:16:15,440 --> 00:16:18,710 sekali Microsoft Word berhenti, semua Anda pekerjaan akan hilang, dan itu akan 341 00:16:18,710 --> 00:16:19,740 benar-benar sia-sia. 342 00:16:19,740 --> 00:16:23,620 Kami akhirnya ingin dapat menulis program yang dapat mempengaruhi 343 00:16:23,620 --> 00:16:31,350 dunia di sekitar mereka, baik dengan mengambil input kompleks - dalam hal file dan 344 00:16:31,350 --> 00:16:37,080 melalui file, dan juga menciptakan menarik dan output menarik - 345 00:16:37,080 --> 00:16:39,520 dalam hal jenis file yang berbeda. 346 00:16:39,520 --> 00:16:43,730 >> Jadi itulah sebabnya kami mulai belajar bagaimana bekerja dengan file. 347 00:16:43,730 --> 00:16:47,080 Lebih khusus lagi, apa kita lakukan adalah sebagai berikut. 348 00:16:47,080 --> 00:16:47,680 Ini sangat sederhana. 349 00:16:47,680 --> 00:16:51,530 Hanya ada beberapa langkah, dan mereka tercantum di sini pada kode ini. 350 00:16:51,530 --> 00:16:55,130 Jadi kita akan pergi melalui ini kode baris demi baris. 351 00:16:55,130 --> 00:16:57,630 >> Pertama, Anda lihat disorot - 352 00:16:57,630 --> 00:17:01,330 ketika Anda bekerja dengan sebuah file, terlepas dari jenis file itu, 353 00:17:01,330 --> 00:17:02,670 Anda harus membukanya. 354 00:17:02,670 --> 00:17:05,130 Dan itu adalah dengan panggilan untuk fopen - 355 00:17:05,130 --> 00:17:05,950 di sini. 356 00:17:05,950 --> 00:17:07,980 Anda termasuk nama file. 357 00:17:07,980 --> 00:17:11,930 Jika file tidak dalam direktori Anda, atau folder di mana program ini 358 00:17:11,930 --> 00:17:15,910 kehidupan, maka Anda juga harus menyertakan jalan ke tempat file yang. 359 00:17:15,910 --> 00:17:19,099 >> Kita akan berasumsi bahwa ini file yang bernama "text.txt" - 360 00:17:19,099 --> 00:17:24,220 dokumen teks sederhana - dalam folder yang sama dengan program ini. 361 00:17:24,220 --> 00:17:26,859 Jadi itu hal lain yang perlu pikiran - bahwa jika Anda ingin membuka file 362 00:17:26,859 --> 00:17:30,050 di tempat lain, Anda benar-benar perlu untuk memasukkan lokasi. 363 00:17:30,050 --> 00:17:33,520 >> Kedua, Anda dapat melewati argumen untuk fopen, dan itulah apa yang ingin Anda lakukan 364 00:17:33,520 --> 00:17:34,620 dengan file tersebut. 365 00:17:34,620 --> 00:17:38,450 Ada tiga argumen utama yang Anda akan lolos ke fopen. 366 00:17:38,450 --> 00:17:40,060 Siapa yang bisa memberi saya tiga? 367 00:17:40,060 --> 00:17:44,960 368 00:17:44,960 --> 00:17:47,130 Siapa yang bisa memberi saya salah satu dari mereka? 369 00:17:47,130 --> 00:17:48,130 Ya. 370 00:17:48,130 --> 00:17:50,010 >> SISWA 4: Nama file? 371 00:17:50,010 --> 00:17:50,440 >> JASON Hirschhorn: Maaf. 372 00:17:50,440 --> 00:17:55,490 Tiga argumen utama Anda dapat melewati sebagai argumen kedua untuk fopen. 373 00:17:55,490 --> 00:17:57,060 Kau benar - nama file adalah argumen pertama. 374 00:17:57,060 --> 00:18:01,620 Tapi argumen kedua untuk fopen adalah umumnya tiga senar, dan - ya. 375 00:18:01,620 --> 00:18:02,210 Aleja. 376 00:18:02,210 --> 00:18:03,490 >> Aleja: A untuk append. 377 00:18:03,490 --> 00:18:06,840 >> JASON Hirschhorn: A, jika Anda ingin menambahkan ke file yang sudah ada. 378 00:18:06,840 --> 00:18:07,810 >> SISWA 5: R untuk membaca. 379 00:18:07,810 --> 00:18:09,930 >> JASON Hirschhorn: R, jika Anda ingin membaca dari file. 380 00:18:09,930 --> 00:18:10,670 >> SISWA 6: W untuk menulis. 381 00:18:10,670 --> 00:18:12,840 >> JASON Hirschhorn: Dan w, jika Anda ingin menulis ke file. 382 00:18:12,840 --> 00:18:17,570 Jadi dalam hal ini, kita sedang menulis ke file tersebut, jadi kita harus w. 383 00:18:17,570 --> 00:18:22,360 Anda membukanya, Anda juga harus menyimpan mengajukan suatu tempat, dan itu dengan 384 00:18:22,360 --> 00:18:26,000 kode ke sisi kiri operator penugasan - 385 00:18:26,000 --> 00:18:31,220 Aku menciptakan pointer ke file disebut, dalam hal ini, berkas. 386 00:18:31,220 --> 00:18:36,070 >> Kami tidak akan khawatir apa ini semua topi hal FILE adalah. 387 00:18:36,070 --> 00:18:40,600 Cukuplah untuk mengatakan, itu adalah panjang aliran nol dan satu. 388 00:18:40,600 --> 00:18:44,970 Dan itulah bagaimana kita akan mengoperasikannya dan memahaminya. 389 00:18:44,970 --> 00:18:47,300 >> Hal berikutnya yang perlu kita lakukan - dan ini sangat penting - 390 00:18:47,300 --> 00:18:49,070 setiap kali Anda membuka file - 391 00:18:49,070 --> 00:18:54,250 pada kenyataannya, setiap kali Anda memanggil malloc, untuk misalnya, dan mendapatkan beberapa memori dan coba 392 00:18:54,250 --> 00:18:57,980 dan menyimpannya dalam pointer, Anda selalu ingin memeriksa untuk memastikan bahwa 393 00:18:57,980 --> 00:19:00,230 Fungsi tidak mengembalikan null. 394 00:19:00,230 --> 00:19:05,230 >> Jadi dalam hal ini, kami memeriksa untuk membuat yakin bahwa kita benar-benar membuka 395 00:19:05,230 --> 00:19:10,230 mengajukan dengan benar, dan ada ada kesalahan dalam program kami. 396 00:19:10,230 --> 00:19:15,160 Selanjutnya, setelah kami diperiksa untuk memastikan bahwa kita memiliki file bekerja, kita bisa 397 00:19:15,160 --> 00:19:18,520 menulis, atau membaca dari, atau menambahkan ke file. 398 00:19:18,520 --> 00:19:24,270 Dalam hal ini, saya hanya mencetak satu baris ke file ini. 399 00:19:24,270 --> 00:19:25,450 >> Bagaimana saya tahu itu? 400 00:19:25,450 --> 00:19:27,990 Yah, saya menggunakan fungsi ini disebut fprintf. 401 00:19:27,990 --> 00:19:30,970 Semua fungsi yang akan Anda gunakan saat menulis, atau membaca dari, atau 402 00:19:30,970 --> 00:19:34,950 memanipulasi file akan mirip dengan fungsi yang telah Anda lihat sebelumnya, namun 403 00:19:34,950 --> 00:19:38,420 dimulai dengan huruf F, berdiri file. 404 00:19:38,420 --> 00:19:43,440 Dan fprintf, seperti cetak normal kita app, mengambil satu argumen tambahan, 405 00:19:43,440 --> 00:19:47,800 dan itu adalah file di mana Anda ingin mencetak baris ini untuk. 406 00:19:47,800 --> 00:19:50,640 >> Saya tidak punya apa-apa untuk hak ohai. 407 00:19:50,640 --> 00:19:52,860 Saya tidak memiliki ketiga argumen ke printf - 408 00:19:52,860 --> 00:19:57,030 atau argumen kedua untuk printf, yang Argumen ketiga untuk fprintf, karena saya 409 00:19:57,030 --> 00:19:59,480 tidak memiliki penampung di sini. 410 00:19:59,480 --> 00:20:01,070 Aku tidak termasuk variabel apapun. 411 00:20:01,070 --> 00:20:06,070 Tetapi sekali lagi, fprintf dan semua file ini fungsi yang beroperasi dengan file 412 00:20:06,070 --> 00:20:09,820 umumnya akan membutuhkan file di mana mereka beroperasi. 413 00:20:09,820 --> 00:20:15,960 >> Akhirnya, hal penting terakhir untuk lakukan adalah untuk menutup file, seperti 414 00:20:15,960 --> 00:20:19,530 dengan - setiap kali kita malloc sesuatu, kita ingin membebaskan sesuatu, jangan sampai kita 415 00:20:19,530 --> 00:20:22,730 memiliki kebocoran memori - kami ingin untuk menutup file kami. 416 00:20:22,730 --> 00:20:28,180 Jika program ini keluar tanpa menutup file, kemungkinan besar tidak akan pergi 417 00:20:28,180 --> 00:20:30,050 salah, terutama jika adalah file kecil. 418 00:20:30,050 --> 00:20:35,020 >> Tapi hal ini tentunya coding gaya yang baik dan berlatih untuk selalu menutup file Anda 419 00:20:35,020 --> 00:20:38,050 ketika Anda selesai menggunakannya. 420 00:20:38,050 --> 00:20:43,630 Jadi itu adalah dasar-dasar file I / O. Anda mungkin pernah melihat itu sebelumnya, atau 421 00:20:43,630 --> 00:20:45,710 menyaksikannya dalam sejenak fantastis. 422 00:20:45,710 --> 00:20:48,410 Apakah Ada yang punya pertanyaan, sebelum kami pergi ke beberapa praktek coding 423 00:20:48,410 --> 00:20:51,800 masalah, tentang file I / O atau langkah Aku hanya pergi? 424 00:20:51,800 --> 00:21:00,198 425 00:21:00,198 --> 00:21:03,162 >> [Mengetik SOUNDS] 426 00:21:03,162 --> 00:21:04,150 >> JASON Hirschhorn: Apakah Anda punya pertanyaan, Avi? 427 00:21:04,150 --> 00:21:04,660 >> AVI: No 428 00:21:04,660 --> 00:21:04,740 >> JASON Hirschhorn: OK. 429 00:21:04,740 --> 00:21:06,746 Aku akan menunggu tujuh detik. 430 00:21:06,746 --> 00:21:07,590 [TERTAWA] 431 00:21:07,590 --> 00:21:08,620 Itu tip benar-benar baik. 432 00:21:08,620 --> 00:21:10,750 Kalian hanya tidak suka mengajukan pertanyaan. 433 00:21:10,750 --> 00:21:11,660 Itu baik-baik saja. 434 00:21:11,660 --> 00:21:12,330 OK. 435 00:21:12,330 --> 00:21:17,620 Jadi masalah latihan pertama kita adalah, kita akan menduplikasi fungsi 436 00:21:17,620 --> 00:21:22,330 alat baris perintah yang Anda mungkin digunakan sebelumnya - copy - 437 00:21:22,330 --> 00:21:23,500 alat copy. 438 00:21:23,500 --> 00:21:28,050 Jika Anda mengetik cp dan kemudian menyebarkannya dua argumen ke terminal Anda, Anda dapat 439 00:21:28,050 --> 00:21:28,980 menyalin file. 440 00:21:28,980 --> 00:21:31,220 Dan itulah yang kita akan untuk menulis sekarang. 441 00:21:31,220 --> 00:21:35,830 >> Jadi sekali lagi, membaca off slide ini, saya akan Anda untuk menulis sebuah program yang mengambil 442 00:21:35,830 --> 00:21:38,130 dua dan hanya dua baris perintah argumen - 443 00:21:38,130 --> 00:21:40,750 file sumber dan file tujuan - 444 00:21:40,750 --> 00:21:44,590 dan salinan isi dari sumber file ke file tujuan 445 00:21:44,590 --> 00:21:46,960 satu byte pada suatu waktu. 446 00:21:46,960 --> 00:21:48,510 Jadi itulah banyak untuk meminta. 447 00:21:48,510 --> 00:21:52,200 >> Sekali lagi, pendekatan yang baik untuk ini adalah untuk tidak pergi langsung ke kode C, tapi 448 00:21:52,200 --> 00:21:54,280 memecahnya menjadi beberapa langkah. 449 00:21:54,280 --> 00:21:58,400 Pertama, pikirkan tentang logika - persis apa yang saya minta Anda lakukan - 450 00:21:58,400 --> 00:22:00,620 dan memahami semua langkah-langkah untuk masalah ini. 451 00:22:00,620 --> 00:22:04,410 Tidak dalam C, hanya dalam beberapa pseudocode, atau bahkan model mental 452 00:22:04,410 --> 00:22:06,030 apa yang terjadi. 453 00:22:06,030 --> 00:22:10,050 >> Selanjutnya, setelah Anda memiliki pseudocode bawah, mencari tahu bagaimana pseudocode 454 00:22:10,050 --> 00:22:14,600 peta ke alat dan hal yang kita sudah belajar untuk digunakan dalam C. 455 00:22:14,600 --> 00:22:19,070 >> Dan akhirnya, setelah Anda memiliki semua yang bersama-sama, Anda dapat kode masalah. 456 00:22:19,070 --> 00:22:23,370 Ambil 5 sampai 10 menit untuk bekerja pada masalah ini. 457 00:22:23,370 --> 00:22:25,800 Aku akan menaruh instruksi kembali dalam detik. 458 00:22:25,800 --> 00:22:27,990 Dan kemudian kita akan pergi ke pseudocode, dan kode 459 00:22:27,990 --> 00:22:29,230 itu hidup sebagai sebuah kelompok. 460 00:22:29,230 --> 00:22:31,640 >> Jika Anda memiliki pertanyaan saat Anda sedang bekerja pada ini, jangan ragu untuk meningkatkan 461 00:22:31,640 --> 00:22:34,260 tangan Anda, dan saya akan datang sekitar dan jawaban mereka. 462 00:22:34,260 --> 00:22:37,020 463 00:22:37,020 --> 00:22:39,330 >> SISWA 7: Dapatkah saya menggesek selembar kertas? 464 00:22:39,330 --> 00:22:41,537 >> JASON Hirschhorn: Ada apa? 465 00:22:41,537 --> 00:26:46,047 466 00:26:46,047 --> 00:26:48,043 >> [Mengetik SOUNDS] 467 00:26:48,043 --> 00:26:48,730 >> JASON Hirschhorn: OK. 468 00:26:48,730 --> 00:26:51,710 Mari kita pseudocode pertama, dan maka saya akan memberikan beberapa lebih 469 00:26:51,710 --> 00:26:52,960 menit untuk menyelesaikan coding. 470 00:26:52,960 --> 00:26:55,540 471 00:26:55,540 --> 00:26:58,650 >> Siapa yang ingin memulai me off dengan baris pertama 472 00:26:58,650 --> 00:27:00,030 pseudocode untuk fungsi ini? 473 00:27:00,030 --> 00:27:03,330 474 00:27:03,330 --> 00:27:05,740 >> SISWA 8: Periksa untuk memastikan bahwa Anda diberi dua file. 475 00:27:05,740 --> 00:27:06,990 >> JASON Hirschhorn: OK. 476 00:27:06,990 --> 00:27:21,270 477 00:27:21,270 --> 00:27:22,990 Dan jika kita tidak? 478 00:27:22,990 --> 00:27:25,974 >> SISWA 8: Aku akan kembali 0. 479 00:27:25,974 --> 00:27:27,872 >> JASON Hirschhorn: Haruskah kita kembali 0? 480 00:27:27,872 --> 00:27:30,182 >> SISWA 8: Mengembalikan - 481 00:27:30,182 --> 00:27:30,650 blanking. 482 00:27:30,650 --> 00:27:30,850 Maaf. 483 00:27:30,850 --> 00:27:31,210 >> JASON Hirschhorn: Ya. 484 00:27:31,210 --> 00:27:32,710 Mungkin tidak 0. 485 00:27:32,710 --> 00:27:34,680 Karena 0 berarti semuanya itu baik. 486 00:27:34,680 --> 00:27:35,030 OK. 487 00:27:35,030 --> 00:27:36,730 Jadi itulah baris pertama dari pseudocode. 488 00:27:36,730 --> 00:27:38,715 Siapa yang memiliki baris kedua pseudocode? 489 00:27:38,715 --> 00:27:40,630 >> SISWA 9: Buka kedua file? 490 00:27:40,630 --> 00:27:41,880 >> JASON Hirschhorn: Buka kedua file. 491 00:27:41,880 --> 00:27:49,970 492 00:27:49,970 --> 00:27:50,920 OK? 493 00:27:50,920 --> 00:27:52,850 >> SISWA 10: Periksa untuk melihat jika file tersebut adalah NULL? 494 00:27:52,850 --> 00:28:10,906 495 00:28:10,906 --> 00:28:12,580 >> JASON Hirschhorn: Periksa untuk memastikan Pastikan juga tidak NULL. 496 00:28:12,580 --> 00:28:15,800 Sebagai samping - 497 00:28:15,800 --> 00:28:17,540 slash 0 - 498 00:28:17,540 --> 00:28:18,887 adalah bahwa NULL? 499 00:28:18,887 --> 00:28:20,080 >> SISWA 11: No 500 00:28:20,080 --> 00:28:21,190 >> JASON Hirschhorn: Itu tidak NULL. 501 00:28:21,190 --> 00:28:23,400 Itu disebut terminator NULL. 502 00:28:23,400 --> 00:28:25,580 Ini sebenarnya dieja dengan hanya satu l. 503 00:28:25,580 --> 00:28:28,580 Jadi memeriksa sesuatu terhadap itu - itu sebenarnya karakter - 504 00:28:28,580 --> 00:28:31,710 jadi memeriksa sesuatu terhadap yang tidak sama dengan memeriksa untuk melihat apakah itu 505 00:28:31,710 --> 00:28:32,690 sama dengan NULL. 506 00:28:32,690 --> 00:28:34,100 >> Dan beberapa orang - 507 00:28:34,100 --> 00:28:36,040 pada kuis mereka dan masalah mereka set - telah mendapat 508 00:28:36,040 --> 00:28:36,890 dua dari mereka bingung. 509 00:28:36,890 --> 00:28:38,830 Tapi dua dari mereka adalah sebenarnya berbeda. 510 00:28:38,830 --> 00:28:40,220 Satu berakhir string - 511 00:28:40,220 --> 00:28:43,210 satu adalah pointer ke 0. 512 00:28:43,210 --> 00:28:46,490 >> SISWA 12: Mengapa tidak akan Anda memeriksa untuk memastikan bahwa file-file tersebut tidak NULL 513 00:28:46,490 --> 00:28:48,670 sebelum Anda membukanya? 514 00:28:48,670 --> 00:28:54,772 >> JASON Hirschhorn: Jadi terbuka menghemat sesuatu dalam file tersebut. 515 00:28:54,772 --> 00:28:57,780 Dan jika Anda kembali ke sini - 516 00:28:57,780 --> 00:28:59,520 sehingga baris ini - fopen - 517 00:28:59,520 --> 00:29:05,300 akan memberikan alamat dan toko alamat dalam file jika bekerja. 518 00:29:05,300 --> 00:29:07,650 Jika tidak bekerja, akan menyimpan NULL - 519 00:29:07,650 --> 00:29:08,020 >> SISWA 12: Oh. 520 00:29:08,020 --> 00:29:08,180 OK. 521 00:29:08,180 --> 00:29:08,500 Punya Anda. 522 00:29:08,500 --> 00:29:09,050 >> JASON Hirschhorn: Dalam file. 523 00:29:09,050 --> 00:29:11,990 Jadi Anda tidak dapat memeriksa NULL sebelum Anda membukanya. 524 00:29:11,990 --> 00:29:13,520 NULL berarti sesuatu tidak bekerja dengan benar. 525 00:29:13,520 --> 00:29:18,030 526 00:29:18,030 --> 00:29:18,740 OK. 527 00:29:18,740 --> 00:29:22,590 Jadi periksa untuk memastikan tidak yaitu? 528 00:29:22,590 --> 00:29:23,200 Atau apakah? 529 00:29:23,200 --> 00:29:23,770 Apa yang kita pikirkan? 530 00:29:23,770 --> 00:29:24,310 Kita akan pergi dengan itu. 531 00:29:24,310 --> 00:29:24,520 >> SISWA 13: Apakah. 532 00:29:24,520 --> 00:29:25,020 >> JASON Hirschhorn: Apakah? 533 00:29:25,020 --> 00:29:25,930 Baik itu? 534 00:29:25,930 --> 00:29:26,350 >> SISWA 13: Apakah. 535 00:29:26,350 --> 00:29:26,390 >> JASON Hirschhorn: OK. 536 00:29:26,390 --> 00:29:28,510 Kami tampaknya memiliki beberapa konsensus tentang itu. 537 00:29:28,510 --> 00:29:30,520 Baik adalah NULL. 538 00:29:30,520 --> 00:29:32,250 OK, baris berikutnya dari pseudocode. 539 00:29:32,250 --> 00:29:33,600 Siapa yang tidak memberi saya garis belum? 540 00:29:33,600 --> 00:29:37,350 541 00:29:37,350 --> 00:29:38,295 Kami akan menunggu untuk Anda. 542 00:29:38,295 --> 00:29:39,020 Ya. 543 00:29:39,020 --> 00:29:40,895 >> SISWA 14: Anda harus membaca dari file pertama? 544 00:29:40,895 --> 00:29:42,290 >> JASON Hirschhorn: OK. 545 00:29:42,290 --> 00:29:46,240 >> SISWA 14: Atau kita menggunakan fscanf atau sesuatu seperti itu file pertama? 546 00:29:46,240 --> 00:29:50,650 >> JASON Hirschhorn: Jadi kami ingin membaca dari file pertama dan - 547 00:29:50,650 --> 00:29:51,900 mari kita menempatkan bahwa di sini. 548 00:29:51,900 --> 00:30:00,600 549 00:30:00,600 --> 00:30:01,880 Baca dari file sumber. 550 00:30:01,880 --> 00:30:05,370 Dan kemudian, apa yang kita lakukan setelah kita membaca dari file sumber? 551 00:30:05,370 --> 00:30:06,620 Orang lain? 552 00:30:06,620 --> 00:30:09,150 553 00:30:09,150 --> 00:30:12,190 >> SISWA 15: Menulis ke file tujuan? 554 00:30:12,190 --> 00:30:22,080 555 00:30:22,080 --> 00:30:25,620 >> JASON Hirschhorn: Kami menulis untuk file tujuan, dan - 556 00:30:25,620 --> 00:30:26,210 OK. 557 00:30:26,210 --> 00:30:30,030 Apa lagi yang kita hilang? 558 00:30:30,030 --> 00:30:32,460 Orang lain yang tidak memberi saya baris kode belum - dari pseudocode. 559 00:30:32,460 --> 00:30:33,510 Ya. 560 00:30:33,510 --> 00:30:36,540 >> SISWA 16: Mungkin Anda selalu dapat memeriksa apakah ada sesuatu untuk dibaca untuk, 561 00:30:36,540 --> 00:30:37,970 seperti baris berikutnya? 562 00:30:37,970 --> 00:30:39,550 Yang seperti baris berikutnya, melihat apakah itu ada. 563 00:30:39,550 --> 00:30:40,660 >> [ELECTRONIC BEEP] 564 00:30:40,660 --> 00:30:41,095 >> JASON Hirschhorn: Oops. 565 00:30:41,095 --> 00:30:43,120 Itu software journal saya. 566 00:30:43,120 --> 00:30:43,580 Ya? 567 00:30:43,580 --> 00:30:44,960 >> SISWA 16: Ya. 568 00:30:44,960 --> 00:30:48,940 >> JASON Hirschhorn: Jadi memberikan kepada saya sekali lagi. 569 00:30:48,940 --> 00:30:51,640 >> SISWA 16: Periksa apakah ada masih baris berikutnya dari 570 00:30:51,640 --> 00:30:52,920 sumber berkas untuk membaca. 571 00:30:52,920 --> 00:30:53,500 >> JASON Hirschhorn: OK. 572 00:30:53,500 --> 00:30:56,060 Jadi kita tidak membaca garis - sedang membaca byte di sini - 573 00:30:56,060 --> 00:30:57,590 tapi kau benar. 574 00:30:57,590 --> 00:31:00,040 Kami ingin membaca dan menulis sampai tidak ada lagi byte. 575 00:31:00,040 --> 00:31:11,430 576 00:31:11,430 --> 00:31:11,735 OK. 577 00:31:11,735 --> 00:31:16,940 Dan ini benar-benar harus menjorok sedikit, karena mereka berada di bawah sana. 578 00:31:16,940 --> 00:31:17,470 Benar? 579 00:31:17,470 --> 00:31:20,620 Sampai kita keluar dari byte, kita akan membaca dari file sumber dan menulis 580 00:31:20,620 --> 00:31:22,160 ke file tujuan. 581 00:31:22,160 --> 00:31:24,510 >> Dan kemudian, apa yang terakhir garis pseudocode? 582 00:31:24,510 --> 00:31:26,380 Seseorang yang tidak diberikan saya sesuatu belum. 583 00:31:26,380 --> 00:31:29,270 584 00:31:29,270 --> 00:31:30,260 >> SISWA 17: Tutup file? 585 00:31:30,260 --> 00:31:31,510 >> JASON Hirschhorn: Tepat. 586 00:31:31,510 --> 00:31:36,370 587 00:31:36,370 --> 00:31:37,450 Tutup file. 588 00:31:37,450 --> 00:31:38,400 Jadi ada pseudocode kami. 589 00:31:38,400 --> 00:31:41,870 Aku akan menempatkan pseudocode ke gedit, dan dalam beberapa menit kami 590 00:31:41,870 --> 00:31:44,626 akan kode ini bersama-sama. 591 00:31:44,626 --> 00:33:55,280 592 00:33:55,280 --> 00:33:56,000 >> OK. 593 00:33:56,000 --> 00:33:58,290 Mari kita memulai sebagai sebuah kelompok. 594 00:33:58,290 --> 00:33:59,940 Nishant, saya memiliki file baru saya. 595 00:33:59,940 --> 00:34:01,130 Saya baru saja membuka hal ini. 596 00:34:01,130 --> 00:34:01,880 Dokumen Untitled 1. 597 00:34:01,880 --> 00:34:05,490 Apa hal pertama yang harus saya lakukan? 598 00:34:05,490 --> 00:34:07,040 >> Nishant: Sertakan perpustakaan? 599 00:34:07,040 --> 00:34:08,219 >> JASON Hirschhorn: OK. 600 00:34:08,219 --> 00:34:11,070 Perpustakaan apa? 601 00:34:11,070 --> 00:34:17,570 >> Nishant: stdio.h, stdlib.h, saya percaya? 602 00:34:17,570 --> 00:34:18,000 >> JASON Hirschhorn: OK. 603 00:34:18,000 --> 00:34:21,592 Apa stdlib untuk? 604 00:34:21,592 --> 00:34:23,010 >> Nishant: aku lupa. 605 00:34:23,010 --> 00:34:23,219 >> JASON Hirschhorn: OK. 606 00:34:23,219 --> 00:34:24,179 Jadi termasuk stdio. 607 00:34:24,179 --> 00:34:28,630 Apa yang harus saya lakukan bahkan sebelum Aku mulai coding? 608 00:34:28,630 --> 00:34:29,710 >> Nishant: Menulis header? 609 00:34:29,710 --> 00:34:31,830 >> JASON Hirschhorn: Bagaimana saya mendapatkannya berwarna? 610 00:34:31,830 --> 00:34:34,060 >> [Interposing SUARA] 611 00:34:34,060 --> 00:34:35,040 >> Nishant: Bagaimana Anda mendapatkannya berwarna? 612 00:34:35,040 --> 00:34:38,060 >> JASON Hirschhorn: Bagaimana saya warna coding? 613 00:34:38,060 --> 00:34:38,570 >> Nishant: Saya tidak tahu. 614 00:34:38,570 --> 00:34:38,830 Oh. 615 00:34:38,830 --> 00:34:39,389 Simpan. 616 00:34:39,389 --> 00:34:39,929 >> JASON Hirschhorn: Hemat. 617 00:34:39,929 --> 00:34:40,270 Ya. 618 00:34:40,270 --> 00:34:41,760 Aku harus menyimpannya sebagai. C. 619 00:34:41,760 --> 00:34:46,239 Jadi simpan di desktop sebagai cp.c. 620 00:34:46,239 --> 00:34:47,280 Manis. 621 00:34:47,280 --> 00:34:51,199 Dan jika saya ingin mendapatkan penuh gaya poin, apa yang harus saya 622 00:34:51,199 --> 00:34:53,085 termasuk di atas? 623 00:34:53,085 --> 00:34:58,390 >> Nishant: Anda bisa menulis nama Anda, nama program, dan tujuan 624 00:34:58,390 --> 00:34:59,640 program juga? 625 00:34:59,640 --> 00:35:08,400 626 00:35:08,400 --> 00:35:10,040 >> JASON Hirschhorn: Tampak baik. 627 00:35:10,040 --> 00:35:10,470 Excellent. 628 00:35:10,470 --> 00:35:12,940 Jadi Anda sudah mulai kita sempurna. 629 00:35:12,940 --> 00:35:13,720 # Include - 630 00:35:13,720 --> 00:35:15,365 kami juga akan menulis - 631 00:35:15,365 --> 00:35:30,050 632 00:35:30,050 --> 00:35:30,870 OK. 633 00:35:30,870 --> 00:35:33,520 Jadi saya pikir saya siap untuk pergi. 634 00:35:33,520 --> 00:35:38,003 Siapa yang memiliki baris pertama kode untuk saya - atau baris pertama dari kode yang 635 00:35:38,003 --> 00:35:41,280 yang diperlukan untuk memenuhi pertama kami komentar di pseudocode? 636 00:35:41,280 --> 00:35:41,985 Anda. 637 00:35:41,985 --> 00:35:48,780 >> SISWA 18: Bukankah seharusnya int argc, dan kemudian char * argv? 638 00:35:48,780 --> 00:35:49,490 >> JASON Hirschhorn: Saya pikir kau benar. 639 00:35:49,490 --> 00:35:56,270 Mari kita mengubahnya ke int utama, paren terbuka, int argc, koma, char * argv? 640 00:35:56,270 --> 00:35:57,150 Seperti itu? 641 00:35:57,150 --> 00:35:57,410 >> SISWA 18: Kurung. 642 00:35:57,410 --> 00:35:58,260 >> JASON Hirschhorn: Kurung. 643 00:35:58,260 --> 00:35:59,860 Buka braket, braket dekat, induk dekat. 644 00:35:59,860 --> 00:36:00,240 Sempurna. 645 00:36:00,240 --> 00:36:02,160 Sekarang saya bisa mengambil argumen command-line. 646 00:36:02,160 --> 00:36:02,430 OK. 647 00:36:02,430 --> 00:36:04,250 Pastikan kita diberi dua file. 648 00:36:04,250 --> 00:36:07,905 Anda dapat memberi saya itu juga. 649 00:36:07,905 --> 00:36:09,180 >> SISWA 18: Jika argc - 650 00:36:09,180 --> 00:36:11,060 yang satu ini tidak sama 3. 651 00:36:11,060 --> 00:36:14,360 >> JASON Hirschhorn: Jika paren terbuka argc tidak sama 3? 652 00:36:14,360 --> 00:36:16,970 >> SISWA 18: Ya, Anda kembali 1 atau apa pun. 653 00:36:16,970 --> 00:36:17,460 >> JASON Hirschhorn: Maaf. 654 00:36:17,460 --> 00:36:19,120 >> SISWA 18: Kembali 1 atau apa pun. 655 00:36:19,120 --> 00:36:20,270 >> JASON Hirschhorn: Kembali 1. 656 00:36:20,270 --> 00:36:22,230 OK? 657 00:36:22,230 --> 00:36:22,970 Besar. 658 00:36:22,970 --> 00:36:24,290 Buka kedua file. 659 00:36:24,290 --> 00:36:26,160 Siapa yang dapat membantu saya membuka kedua file? 660 00:36:26,160 --> 00:36:28,125 Siapa yang tidak memberi saya kode belum? 661 00:36:28,125 --> 00:36:31,510 662 00:36:31,510 --> 00:36:32,320 Kurt? 663 00:36:32,320 --> 00:36:36,145 >> KURT: Jadi semua caps F-I-L-E sumber star. 664 00:36:36,145 --> 00:36:39,390 665 00:36:39,390 --> 00:36:40,920 >> JASON Hirschhorn: Aku akan untuk mengambil vokal. 666 00:36:40,920 --> 00:36:41,570 Mereka adalah keren. 667 00:36:41,570 --> 00:36:42,716 Ini seperti Tumblr. 668 00:36:42,716 --> 00:36:44,610 >> SISWA 18: Setara fopen - 669 00:36:44,610 --> 00:36:46,612 >> JASON Hirschhorn: Setara fopen? 670 00:36:46,612 --> 00:36:49,870 >> SISWA 18: Buka paren, argv, braket terbuka. 671 00:36:49,870 --> 00:36:50,055 >> JASON Hirschhorn: Tunggu. 672 00:36:50,055 --> 00:36:50,240 Maaf. 673 00:36:50,240 --> 00:36:51,050 Buka paren. 674 00:36:51,050 --> 00:36:51,456 OK. 675 00:36:51,456 --> 00:36:53,080 >> SISWA 18: Ya. 676 00:36:53,080 --> 00:36:55,110 Sub argv 1. 677 00:36:55,110 --> 00:36:55,860 >> JASON Hirschhorn: Sub 1? 678 00:36:55,860 --> 00:36:56,140 >> SISWA 18: Ya. 679 00:36:56,140 --> 00:36:58,540 Argv braket terbuka 1 - 680 00:36:58,540 --> 00:36:59,730 ya. 681 00:36:59,730 --> 00:37:06,470 Dan kemudian koma, dan kemudian buka ganda quote, r, kutip ganda, 682 00:37:06,470 --> 00:37:08,250 paren dekat, titik koma. 683 00:37:08,250 --> 00:37:09,450 >> JASON Hirschhorn: Manis. 684 00:37:09,450 --> 00:37:10,950 Dan bagaimana dengan yang lain? 685 00:37:10,950 --> 00:37:16,030 >> SISWA 18: Sangat mirip, tapi malah S-R-C, Anda akan menyebutnya D-S-T. 686 00:37:16,030 --> 00:37:17,060 >> JASON Hirschhorn: Oo! 687 00:37:17,060 --> 00:37:17,772 Aku seperti itu. 688 00:37:17,772 --> 00:37:20,010 >> SISWA 18: Just D-S-T. Ya. 689 00:37:20,010 --> 00:37:23,057 Dan kemudian argv, braket terbuka, 2. 690 00:37:23,057 --> 00:37:23,200 Ya. 691 00:37:23,200 --> 00:37:26,720 Dan kemudian w bukannya r. 692 00:37:26,720 --> 00:37:27,620 Ya. 693 00:37:27,620 --> 00:37:29,630 >> JASON Hirschhorn: Great. 694 00:37:29,630 --> 00:37:31,360 Beberapa sebelah baris. 695 00:37:31,360 --> 00:37:34,040 Juga, jika ada yang memiliki hal-hal untuk menambah baris yang telah kami lakukan, merasa bebas untuk 696 00:37:34,040 --> 00:37:35,690 menambahkan mereka juga. 697 00:37:35,690 --> 00:37:37,520 Periksa untuk memastikan tidak adalah NULL. 698 00:37:37,520 --> 00:37:41,450 Siapa yang bisa memberi saya kode saya perlu memenuhi bahwa garis pseudocode? 699 00:37:41,450 --> 00:37:44,430 700 00:37:44,430 --> 00:37:45,870 Archer. 701 00:37:45,870 --> 00:37:58,645 >> ARCHER: Jika src sama equals NULL atau dst sama equals 702 00:37:58,645 --> 00:38:04,590 NULL, maka Anda kembali - 703 00:38:04,590 --> 00:38:07,130 704 00:38:07,130 --> 00:38:07,976 >> JASON Hirschhorn: Apa? 705 00:38:07,976 --> 00:38:08,890 >> ARCHER: Kembali 2? 706 00:38:08,890 --> 00:38:09,760 >> JASON Hirschhorn: Kembali 2. 707 00:38:09,760 --> 00:38:14,400 Jadi jika paren terbuka src sama sama dengan NULL, atau - 708 00:38:14,400 --> 00:38:15,590 apapun yang thing's - pipa? 709 00:38:15,590 --> 00:38:16,346 Pipa? 710 00:38:16,346 --> 00:38:17,140 Kita akan menyebutnya pipa. 711 00:38:17,140 --> 00:38:22,340 Pipa, pipa, dst sama equals NULL, kembali 2. 712 00:38:22,340 --> 00:38:23,900 OK? 713 00:38:23,900 --> 00:38:26,060 Sampai kita keluar dari byte - 714 00:38:26,060 --> 00:38:29,820 kita semacam melompati langkah ini dari pseudocode bagian untuk pergi ke sini. 715 00:38:29,820 --> 00:38:31,970 >> Tapi sampai kita keluar dari byte - apa itu terdengar seperti? 716 00:38:31,970 --> 00:38:34,680 Apa jenis struktur C - 717 00:38:34,680 --> 00:38:36,160 tapi saya tidak menggunakan struktur kata, karena kita akan mulai menggunakan 718 00:38:36,160 --> 00:38:37,350 bahwa dalam kasus lain - 719 00:38:37,350 --> 00:38:39,495 tetapi alat C apakah itu terdengar seperti? 720 00:38:39,495 --> 00:38:39,970 >> SISWA 19: Sebuah loop. 721 00:38:39,970 --> 00:38:40,980 >> JASON Hirschhorn: Sebuah loop. 722 00:38:40,980 --> 00:38:43,060 Kedengarannya seperti lingkaran. 723 00:38:43,060 --> 00:38:49,670 Jadi, siapa yang bisa memberi saya baris pertama kode lingkaran di sini? 724 00:38:49,670 --> 00:38:56,320 725 00:38:56,320 --> 00:39:01,980 Anda juga dapat memilih jenis lingkaran yang Anda inginkan, jika Anda memberi saya 726 00:39:01,980 --> 00:39:03,215 baris kode. 727 00:39:03,215 --> 00:39:04,150 Ada tiga macam. 728 00:39:04,150 --> 00:39:06,530 Anda bisa memilih. 729 00:39:06,530 --> 00:39:08,080 Saya akan menyarankan salah satu dari mereka. 730 00:39:08,080 --> 00:39:08,410 Avi. 731 00:39:08,410 --> 00:39:09,230 Yang mana yang Anda inginkan? 732 00:39:09,230 --> 00:39:09,960 >> AVI: FOR. 733 00:39:09,960 --> 00:39:11,460 >> JASON Hirschhorn: FOR. 734 00:39:11,460 --> 00:39:15,180 >> AVI: int i sama dengan nol. 735 00:39:15,180 --> 00:39:17,360 >> JASON Hirschhorn: OK. 736 00:39:17,360 --> 00:39:18,570 >> AVI: Bagian ini saya tidak yakin tentang. 737 00:39:18,570 --> 00:39:29,080 Tetapi saya kurang dari ukuran sumber star? 738 00:39:29,080 --> 00:39:31,128 Saya tidak yakin itu. 739 00:39:31,128 --> 00:39:32,580 >> JASON Hirschhorn: OK. 740 00:39:32,580 --> 00:39:35,870 >> AVI: Karena Anda ingin ukuran file, kan? 741 00:39:35,870 --> 00:39:41,090 >> JASON Hirschhorn: Jadi ini mungkin tidak akan memberi kita ukuran sebenarnya 742 00:39:41,090 --> 00:39:43,010 file dalam byte. 743 00:39:43,010 --> 00:39:47,680 Jadi apa lagi yang bisa kita lakukan? 744 00:39:47,680 --> 00:39:48,810 Apa jenis lain dari lingkaran? 745 00:39:48,810 --> 00:39:50,180 Atau haruskah kita tetap dengan loop FOR? 746 00:39:50,180 --> 00:39:55,350 747 00:39:55,350 --> 00:39:57,900 >> SISWA 20: Bisakah Anda melakukan loop WHILE? 748 00:39:57,900 --> 00:40:01,350 Dan kemudian, apa yang akan Anda lakukan adalah tersebut Anda akan - 749 00:40:01,350 --> 00:40:03,930 karena kami memiliki char * untuk file. 750 00:40:03,930 --> 00:40:07,950 Jadi, jika kita terus incrementing bahwa sampai kita akan menemukan karakter NULL di 751 00:40:07,950 --> 00:40:08,500 akhir itu? 752 00:40:08,500 --> 00:40:11,130 Atau tidak, adalah bahwa tidak bagaimana file bekerja? 753 00:40:11,130 --> 00:40:14,300 >> JASON Hirschhorn: Jadi kita bisa menjaga incrementing char * 754 00:40:14,300 --> 00:40:16,340 sampai kita menemukan NULL - 755 00:40:16,340 --> 00:40:18,580 >> SISWA 20: Pada dasarnya terus karakter demi karakter sampai kita memukul 756 00:40:18,580 --> 00:40:21,250 akhir file. 757 00:40:21,250 --> 00:40:21,600 >> JASON Hirschhorn: Ya. 758 00:40:21,600 --> 00:40:22,560 Jadi itulah yang ingin kita lakukan. 759 00:40:22,560 --> 00:40:24,545 Kami ingin terus membaca, karakter dengan karakter, sampai kita bisa 760 00:40:24,545 --> 00:40:25,080 akhir file. 761 00:40:25,080 --> 00:40:25,375 >> SISWA 20: Ya. 762 00:40:25,375 --> 00:40:25,860 Cari - 763 00:40:25,860 --> 00:40:28,540 apa akhir atau tanda berhenti pada akhir file teks. 764 00:40:28,540 --> 00:40:28,620 >> JASON Hirschhorn: OK. 765 00:40:28,620 --> 00:40:30,140 Jadi ketika kita sampai ke akhir file - bagaimana kita tahu bahwa kita telah mencapai 766 00:40:30,140 --> 00:40:33,200 akhir file? 767 00:40:33,200 --> 00:40:34,710 Jika saya menelepon - 768 00:40:34,710 --> 00:40:35,910 jadi mari kita mundur. 769 00:40:35,910 --> 00:40:37,550 Apa fungsi? 770 00:40:37,550 --> 00:40:39,360 Mari kita pergi ke baris ini di sini. 771 00:40:39,360 --> 00:40:40,630 Baca dari file sumber. 772 00:40:40,630 --> 00:40:41,880 Siapa yang bisa memberi saya bahwa baris kode? 773 00:40:41,880 --> 00:40:45,592 774 00:40:45,592 --> 00:40:47,590 >> SISWA 21: fscanf? 775 00:40:47,590 --> 00:40:49,110 >> JASON Hirschhorn: fscanf. 776 00:40:49,110 --> 00:40:49,510 OK. 777 00:40:49,510 --> 00:40:52,240 Bagaimana jika saya ingin membaca, sangat khusus, satu byte? 778 00:40:52,240 --> 00:40:55,012 779 00:40:55,012 --> 00:40:56,860 >> SISWA 21: Saya tidak tahu. 780 00:40:56,860 --> 00:40:57,110 >> JASON Hirschhorn: OK. 781 00:40:57,110 --> 00:40:59,380 Bahkan lebih sederhana daripada fscanf - apa itu - 782 00:40:59,380 --> 00:41:01,890 Saya ingin membaca dari file source? 783 00:41:01,890 --> 00:41:03,720 Baca dari file sumber. 784 00:41:03,720 --> 00:41:04,850 Apa fungsi - ya. 785 00:41:04,850 --> 00:41:05,380 >> SISWA 22: Ini fread? 786 00:41:05,380 --> 00:41:06,070 >> JASON Hirschhorn: fread. 787 00:41:06,070 --> 00:41:07,550 Saya pikir mari kita tetap dengan bahwa salah satu untuk saat ini. 788 00:41:07,550 --> 00:41:10,380 789 00:41:10,380 --> 00:41:13,650 Apa argumen tidak fread mengambil? 790 00:41:13,650 --> 00:41:17,410 >> SISWA 22: Mungkin jenis file, dan kemudian lokasi dalam file? 791 00:41:17,410 --> 00:41:19,550 >> JASON Hirschhorn: Apa yang bisa saya ketik di sini untuk mencari tahu apa jenis argumen 792 00:41:19,550 --> 00:41:20,950 fread mengambil? 793 00:41:20,950 --> 00:41:23,710 >> MAHASISWA GANDA: Man fread. 794 00:41:23,710 --> 00:41:24,740 >> JASON Hirschhorn: Man fread dan fwrite. 795 00:41:24,740 --> 00:41:25,980 Sepertinya mereka hang out bersama. 796 00:41:25,980 --> 00:41:29,589 Jadi fread mengambil berapa banyak argumen? 797 00:41:29,589 --> 00:41:30,920 >> SISWA 23: Empat. 798 00:41:30,920 --> 00:41:32,690 >> JASON Hirschhorn: Dibutuhkan empat argumen. 799 00:41:32,690 --> 00:41:41,100 Dibutuhkan pointer, ukuran, dan bahwa hal yang aneh, dan beberapa berkas. 800 00:41:41,100 --> 00:41:42,000 OK? 801 00:41:42,000 --> 00:41:43,990 Mari kita membaca tentang hal itu di sini. 802 00:41:43,990 --> 00:41:49,370 "Fungsi fread membaca n memb elemen data, masing-masing ukuran byte 803 00:41:49,370 --> 00:41:53,840 panjang, dari sungai yang ditunjukkan oleh streaming, menyimpannya di lokasi 804 00:41:53,840 --> 00:41:56,170 diberikan oleh pointer. " 805 00:41:56,170 --> 00:41:57,960 >> Jadi empat argumen. 806 00:41:57,960 --> 00:42:04,510 Mengapa saya tidak hanya menyalin ini, dan paste tepat di sini. 807 00:42:04,510 --> 00:42:10,060 808 00:42:10,060 --> 00:42:10,770 OK. 809 00:42:10,770 --> 00:42:13,673 Jadi, siapa yang dapat mulai mengisi argumen ini untuk saya? 810 00:42:13,673 --> 00:42:15,840 Avi. 811 00:42:15,840 --> 00:42:17,720 >> AVI: Ambil kekosongan. 812 00:42:17,720 --> 00:42:20,530 Menempatkan hanya src. 813 00:42:20,530 --> 00:42:23,142 Mengambil pointer dan bintang. 814 00:42:23,142 --> 00:42:26,102 Masukan src. 815 00:42:26,102 --> 00:42:27,050 Kemudian - 816 00:42:27,050 --> 00:42:28,500 >> JASON Hirschhorn: Jadi aku akan berhenti Anda di sana, karena itu tidak benar. 817 00:42:28,500 --> 00:42:32,590 818 00:42:32,590 --> 00:42:34,710 Kau benar dengan src, tapi mana src harus pergi? 819 00:42:34,710 --> 00:42:35,960 >> [Interposing SUARA] 820 00:42:35,960 --> 00:42:38,976 821 00:42:38,976 --> 00:42:41,610 >> JASON Hirschhorn: Seharusnya pergi ke sini. 822 00:42:41,610 --> 00:42:43,790 Itu src - src kami adalah tipe. 823 00:42:43,790 --> 00:42:44,610 Mari kita lihat di sini. 824 00:42:44,610 --> 00:42:49,610 Hal ini meminta jenis FILE *, kita sebenarnya biasanya melihat mereka seperti itu. 825 00:42:49,610 --> 00:42:57,630 Jadi ini meminta argumen dari ketik FILE * disebut aliran yang src. 826 00:42:57,630 --> 00:42:58,480 OK? 827 00:42:58,480 --> 00:43:00,410 >> Ukuran apa hal-hal yang dapat dilakukan kita ingin membaca? 828 00:43:00,410 --> 00:43:03,340 Aku memberimu ini di deskripsi masalah. 829 00:43:03,340 --> 00:43:04,370 >> SISWA 24: Satu byte pada suatu waktu. 830 00:43:04,370 --> 00:43:05,340 >> JASON Hirschhorn: Satu byte. 831 00:43:05,340 --> 00:43:08,205 Seberapa besar byte? 832 00:43:08,205 --> 00:43:11,642 Ukurannya adalah dalam byte, jadi apa bisa saya meletakkan di sana? 833 00:43:11,642 --> 00:43:12,910 >> SISWA 25: One. 834 00:43:12,910 --> 00:43:14,730 >> JASON Hirschhorn: One. 835 00:43:14,730 --> 00:43:17,020 Benar. 836 00:43:17,020 --> 00:43:19,940 Ukurannya adalah di unit byte, jadi 1 adalah 1 byte. 837 00:43:19,940 --> 00:43:22,284 Berapa banyak yang ingin saya baca pada suatu waktu. 838 00:43:22,284 --> 00:43:23,520 >> SISWA 26: One? 839 00:43:23,520 --> 00:43:24,270 >> JASON Hirschhorn: Satu hal. 840 00:43:24,270 --> 00:43:28,540 Saya ingin membaca satu hal ukuran 1, satu gigitan pada suatu waktu. 841 00:43:28,540 --> 00:43:32,110 Dan di mana saya katakan, setelah saya membacanya? 842 00:43:32,110 --> 00:43:35,050 843 00:43:35,050 --> 00:43:36,510 >> SISWA 27: Destination? 844 00:43:36,510 --> 00:43:39,270 >> JASON Hirschhorn: Jadi saya tidak dapat menempatkan langsung ke tujuan. 845 00:43:39,270 --> 00:43:40,800 >> SISWA 28: Kau akan put menjadi pointer ketiga? 846 00:43:40,800 --> 00:43:41,780 >> SISWA 27: Untuk tujuan. 847 00:43:41,780 --> 00:43:42,270 >> JASON Hirschhorn: OK. 848 00:43:42,270 --> 00:43:42,630 Ya. 849 00:43:42,630 --> 00:43:46,820 >> SISWA 29: Anda dapat menyatakan sesuatu bertindak sebagai penyimpanan sementara sebelumnya. 850 00:43:46,820 --> 00:43:47,350 >> JASON Hirschhorn: OK. 851 00:43:47,350 --> 00:43:50,080 Beri aku itu. 852 00:43:50,080 --> 00:43:53,930 >> SISWA 29: File lain pointer, mungkin? 853 00:43:53,930 --> 00:43:54,220 >> JASON Hirschhorn: OK. 854 00:43:54,220 --> 00:43:55,585 Jadi ini tidak berlaku bintang - 855 00:43:55,585 --> 00:43:57,750 itu adalah tipe void bintang, sehingga tidak harus menjadi pointer berkas. 856 00:43:57,750 --> 00:44:02,520 Dan jika saya membaca satu byte, di mana akan menjadi tempat yang baik 857 00:44:02,520 --> 00:44:03,850 untuk menyimpan satu byte? 858 00:44:03,850 --> 00:44:04,660 >> SISWA 29: Sebuah array? 859 00:44:04,660 --> 00:44:05,770 >> JASON Hirschhorn: Sebuah array. 860 00:44:05,770 --> 00:44:07,730 OK. 861 00:44:07,730 --> 00:44:14,040 Dan apa lagi adalah sesuatu yang hanya ukuran satu byte? 862 00:44:14,040 --> 00:44:16,980 863 00:44:16,980 --> 00:44:18,060 >> SISWA 30: A char *? 864 00:44:18,060 --> 00:44:18,530 >> SISWA 29: Ya. 865 00:44:18,530 --> 00:44:19,880 >> JASON Hirschhorn: A char * tidak satu byte. 866 00:44:19,880 --> 00:44:20,440 >> SISWA 29: A arang. 867 00:44:20,440 --> 00:44:21,810 >> JASON Hirschhorn: A char adalah satu byte. 868 00:44:21,810 --> 00:44:22,920 Benar? 869 00:44:22,920 --> 00:44:26,740 Jadi mari kita sebut penyangga ini adalah generik nama digunakan untuk hal-hal ini untuk menyimpan 870 00:44:26,740 --> 00:44:27,910 sesuatu yang sementara. 871 00:44:27,910 --> 00:44:30,880 Jadi saya membuat buffer. 872 00:44:30,880 --> 00:44:31,150 Benar? 873 00:44:31,150 --> 00:44:32,990 Tapi itu tidak mengambil void *. 874 00:44:32,990 --> 00:44:38,660 Jadi mungkin Anda benar, bahwa harus ada buffer ukuran 0. 875 00:44:38,660 --> 00:44:41,070 Jadi menyimpan satu - 876 00:44:41,070 --> 00:44:41,280 benar. 877 00:44:41,280 --> 00:44:43,560 >> Karena hak ini di sini - Char buffer karakter, tapi 878 00:44:43,560 --> 00:44:45,110 ini membutuhkan void * - 879 00:44:45,110 --> 00:44:45,870 pointer. 880 00:44:45,870 --> 00:44:50,640 Jadi aku bisa melakukan ini dan sekarang buffer pointer. 881 00:44:50,640 --> 00:44:53,214 Apa lagi yang bisa saya lakukan? 882 00:44:53,214 --> 00:44:55,775 >> SISWA 31: Letakkan bintang berikutnya untuk char. 883 00:44:55,775 --> 00:44:58,380 >> JASON Hirschhorn: aku bisa telah menciptakannya hangus *. 884 00:44:58,380 --> 00:45:00,216 OK. 885 00:45:00,216 --> 00:45:03,131 Apa hal lain yang bisa saya lakukan? 886 00:45:03,131 --> 00:45:04,050 Atau mari kita pergi dengan yang satu ini. 887 00:45:04,050 --> 00:45:05,740 Char * buffer, jadi apa saya dimasukkan ke dalam sini? 888 00:45:05,740 --> 00:45:08,290 889 00:45:08,290 --> 00:45:09,310 >> SISWA 31: Buffer. 890 00:45:09,310 --> 00:45:10,560 >> JASON Hirschhorn: Buffer. 891 00:45:10,560 --> 00:45:12,640 892 00:45:12,640 --> 00:45:14,500 Buffer adalah pointer ke char. 893 00:45:14,500 --> 00:45:19,480 Dan di lokasi itu, kami menempatkan satu byte dari sesuatu yang kita sudah membaca. 894 00:45:19,480 --> 00:45:19,980 Ya. 895 00:45:19,980 --> 00:45:20,700 Avi. 896 00:45:20,700 --> 00:45:21,230 >> AVI: Hanya pertanyaan singkat. 897 00:45:21,230 --> 00:45:24,440 Apakah Anda ingin malloc penyangga? 898 00:45:24,440 --> 00:45:25,930 >> JASON Hirschhorn: Siapa yang bisa menjawab pertanyaan itu? 899 00:45:25,930 --> 00:45:30,210 >> SISWA 32: Well, itu tidak benar-benar arahkan ke sesuatu sekarang, jadi - 900 00:45:30,210 --> 00:45:32,610 >> JASON Hirschhorn: Tapi apakah kami ingin malloc itu? 901 00:45:32,610 --> 00:45:35,600 >> SISWA 32: Jika Anda adalah untuk melakukannya bahwa cara, saya kira, ya, karena Anda akan perlu 902 00:45:35,600 --> 00:45:36,990 beberapa tempat untuk itu untuk menunjuk ke. 903 00:45:36,990 --> 00:45:38,350 >> JASON Hirschhorn: Apakah kita harus malloc itu? 904 00:45:38,350 --> 00:45:40,580 >> SISWA 33: Jika Anda akan menggunakannya di luar loop. 905 00:45:40,580 --> 00:45:42,524 >> JASON Hirschhorn: Apakah kita akan menggunakannya di luar loop? 906 00:45:42,524 --> 00:45:44,392 >> SISWA 34: Ya. 907 00:45:44,392 --> 00:45:44,860 >> SISWA 35: Tunggu. 908 00:45:44,860 --> 00:45:46,980 Apakah kita ingin mendeklarasikan dalam loop untuk di luar? 909 00:45:46,980 --> 00:45:50,100 >> JASON Hirschhorn: Jadi saya kira kita harus beberapa pseudo WHILE lingkaran di sini bahwa kita 910 00:45:50,100 --> 00:45:51,950 mencoba untuk mencari tahu, bahwa kami belum mendapatkan belum. 911 00:45:51,950 --> 00:45:54,710 912 00:45:54,710 --> 00:45:56,010 Kita tidak perlu malloc itu. 913 00:45:56,010 --> 00:45:59,310 Kami beroperasi di utama, itu hanya akan untuk digunakan di dalam lingkaran ini. 914 00:45:59,310 --> 00:46:00,540 Tidak perlu ada luar ini. 915 00:46:00,540 --> 00:46:02,340 >> Sehingga dapat menjadi variabel lokal. 916 00:46:02,340 --> 00:46:03,925 Anda memiliki pointer ke variabel lokal. 917 00:46:03,925 --> 00:46:07,984 918 00:46:07,984 --> 00:46:09,590 >> SISWA 36: Tapi itu tidak menunjuk ke sesuatu. 919 00:46:09,590 --> 00:46:11,540 >> JASON Hirschhorn: Tidak, itu tidak diinisialisasi apa pun. 920 00:46:11,540 --> 00:46:12,790 Tapi kami tidak akan menggunakannya juga. 921 00:46:12,790 --> 00:46:15,300 Kita akan memasukkan sesuatu ke dalam itu pertama kalinya kami menggunakannya. 922 00:46:15,300 --> 00:46:16,580 Jadi yang tampaknya OK. 923 00:46:16,580 --> 00:46:17,780 Jadi kita tidak perlu malloc sini. 924 00:46:17,780 --> 00:46:19,360 Dan saya pikir itu OK seperti. 925 00:46:19,360 --> 00:46:24,350 926 00:46:24,350 --> 00:46:25,790 OK. 927 00:46:25,790 --> 00:46:27,190 Kami memiliki garis fread. 928 00:46:27,190 --> 00:46:28,490 Mari kita lakukan baris berikutnya. 929 00:46:28,490 --> 00:46:32,984 >> Jika kita ingin menulis ke file, apa yang fungsi yang baik untuk digunakan untuk melakukan itu? 930 00:46:32,984 --> 00:46:33,770 >> SISWA 37: fwrite? 931 00:46:33,770 --> 00:46:35,140 >> SISWA 38: fprintf? 932 00:46:35,140 --> 00:46:36,010 >> JASON Hirschhorn: fprintf adalah satu. 933 00:46:36,010 --> 00:46:37,260 Apa yang satu lagi? 934 00:46:37,260 --> 00:46:37,680 >> SISWA 39: fwrite. 935 00:46:37,680 --> 00:46:38,510 >> JASON Hirschhorn: fwrite. 936 00:46:38,510 --> 00:46:41,250 Dan untuk tujuan kita, fwrite, yang kita lihat di sini, adalah 937 00:46:41,250 --> 00:46:42,500 mungkin pilihan yang lebih baik. 938 00:46:42,500 --> 00:46:51,970 939 00:46:51,970 --> 00:46:53,950 Dibutuhkan empat argumen juga. 940 00:46:53,950 --> 00:46:57,570 Nishant, Anda dapat memberikan saya argumen? 941 00:46:57,570 --> 00:47:00,570 >> Nishant: going pertama seseorang menjadi hanya penyangga. 942 00:47:00,570 --> 00:47:02,210 >> JASON Hirschhorn: OK. 943 00:47:02,210 --> 00:47:06,752 >> Nishant: Yang kedua seseorang hanya akan menjadi 1. 944 00:47:06,752 --> 00:47:09,510 Sepertiga akan menjadi 1. 945 00:47:09,510 --> 00:47:11,470 Dan yang keempat akan menjadi dst. 946 00:47:11,470 --> 00:47:18,010 947 00:47:18,010 --> 00:47:19,550 >> JASON Hirschhorn: Apakah ada yang punya pertanyaan tentang garis itu? 948 00:47:19,550 --> 00:47:28,370 949 00:47:28,370 --> 00:47:29,130 Yang terlihat baik. 950 00:47:29,130 --> 00:47:29,590 OK. 951 00:47:29,590 --> 00:47:34,250 Jadi sekarang terlihat seperti satu hal kita hilang - sebenarnya, mari kita menulis 952 00:47:34,250 --> 00:47:35,090 baris terakhir ini. 953 00:47:35,090 --> 00:47:36,300 Tutup file. 954 00:47:36,300 --> 00:47:38,880 Siapa yang bisa menyelesaikan kami menulis dua baris terakhir? 955 00:47:38,880 --> 00:47:39,120 Ya. 956 00:47:39,120 --> 00:47:39,850 Maaf, siapa namamu? 957 00:47:39,850 --> 00:47:40,580 >> LUCY: Lucy. 958 00:47:40,580 --> 00:47:41,580 >> JASON Hirschhorn: Lucy. 959 00:47:41,580 --> 00:47:47,560 >> LUCY: src fclose dan kemudian tujuan fclose. 960 00:47:47,560 --> 00:47:52,430 >> JASON Hirschhorn: fclose, paren terbuka, src, paren dekat, titik koma. 961 00:47:52,430 --> 00:47:53,680 Dan fclose - 962 00:47:53,680 --> 00:47:57,560 963 00:47:57,560 --> 00:47:58,090 ya? 964 00:47:58,090 --> 00:48:01,710 >> LUCY: Buka kurung, dst dan kemudian titik koma. 965 00:48:01,710 --> 00:48:02,520 >> JASON Hirschhorn: Great. 966 00:48:02,520 --> 00:48:04,338 Dan apa yang harus saya masukkan di akhir? 967 00:48:04,338 --> 00:48:05,210 >> LUCY: Kembali 0. 968 00:48:05,210 --> 00:48:05,570 >> JASON Hirschhorn: Kembali 0. 969 00:48:05,570 --> 00:48:06,820 Apakah saya harus? 970 00:48:06,820 --> 00:48:10,560 971 00:48:10,560 --> 00:48:12,590 Hanya pertanyaan. 972 00:48:12,590 --> 00:48:14,957 Apakah kita harus menyertakan return 0? 973 00:48:14,957 --> 00:48:16,240 >> MAHASISWA GANDA: No 974 00:48:16,240 --> 00:48:16,430 >> JASON Hirschhorn: No 975 00:48:16,430 --> 00:48:18,090 Main melakukannya secara otomatis jika Anda mendapatkan sampai akhir. 976 00:48:18,090 --> 00:48:20,580 Tapi saya pikir itu bagus untuk memasukkannya secara eksplisit. 977 00:48:20,580 --> 00:48:23,860 Terutama ketika kita kembali lainnya hal-hal di seluruh program. 978 00:48:23,860 --> 00:48:24,810 OK. 979 00:48:24,810 --> 00:48:26,230 Ini adalah apa yang kita hilang - 980 00:48:26,230 --> 00:48:28,520 WHILE apa? 981 00:48:28,520 --> 00:48:31,630 Siapa yang bisa memikirkan beberapa - 982 00:48:31,630 --> 00:48:35,240 memiliki beberapa rasa apa hal-hal bisa masuk ke sana? 983 00:48:35,240 --> 00:48:37,350 Bahkan jika itu hanya dalam beberapa pseudocode seperti bahasa? 984 00:48:37,350 --> 00:48:41,330 >> Apa yang kita benar-benar - apa kita ingin pergi sampai? 985 00:48:41,330 --> 00:48:41,980 Ya, Lucy. 986 00:48:41,980 --> 00:48:43,240 >> LUCY: The akhir file. 987 00:48:43,240 --> 00:48:44,990 >> JASON Hirschhorn: The akhir file. 988 00:48:44,990 --> 00:48:49,280 Jadi apa yang Anda maksud dengan akhir file? 989 00:48:49,280 --> 00:48:50,955 >> LUCY: Setelah Anda mencapai akhir file, berhenti. 990 00:48:50,955 --> 00:48:51,240 >> JASON Hirschhorn: OK. 991 00:48:51,240 --> 00:48:53,460 Jadi setelah kita mencapai akhir file. 992 00:48:53,460 --> 00:48:56,893 Bagaimana kita tahu ketika kita telah mencapai akhir file? 993 00:48:56,893 --> 00:48:59,900 >> SISWA 40: Saya pikir penyangga akan diatur ke NULL. 994 00:48:59,900 --> 00:49:01,885 >> SISWA 41: Buffer dinyatakan di dalam lingkaran. 995 00:49:01,885 --> 00:49:03,670 >> JASON Hirschhorn: Jadi Anda pikir buffer akan diatur ke NULL. 996 00:49:03,670 --> 00:49:05,850 Mengapa penyangga diatur ke NULL? 997 00:49:05,850 --> 00:49:10,420 >> SISWA 40: Karena ketika Anda fread, Anda mencoba untuk menempatkan 998 00:49:10,420 --> 00:49:13,528 apa-apa ke dalam buffer. 999 00:49:13,528 --> 00:49:13,980 >> JASON Hirschhorn: OK. 1000 00:49:13,980 --> 00:49:15,550 Jadi Anda berpikir fread - 1001 00:49:15,550 --> 00:49:19,000 ketika kita telah mencapai akhir dari File, apa yang fread akan lakukan? 1002 00:49:19,000 --> 00:49:21,230 Saya pikir itu pertanyaan kita harus mencari tahu. 1003 00:49:21,230 --> 00:49:21,960 Apa fread lakukan? 1004 00:49:21,960 --> 00:49:25,640 Apakah itu menempatkan NULL dalam buffer, atau apakah itu melakukan sesuatu yang lain? 1005 00:49:25,640 --> 00:49:27,510 Bagaimana kita bisa mengetahui apa itu? 1006 00:49:27,510 --> 00:49:28,190 >> SISWA 42: Man. 1007 00:49:28,190 --> 00:49:28,810 >> JASON Hirschhorn: Man. 1008 00:49:28,810 --> 00:49:32,280 Jadi mari kita lihat di sini. 1009 00:49:32,280 --> 00:49:34,000 Mengembalikan nilai. 1010 00:49:34,000 --> 00:49:39,620 Pada keberhasilan, fread dan fwrite mengembalikan jumlah item dibaca atau ditulis. 1011 00:49:39,620 --> 00:49:43,700 Jumlah ini sama dengan jumlah byte ditransfer hanya ketika ukuran 1. 1012 00:49:43,700 --> 00:49:47,780 Jika terjadi kesalahan, atau akhir file tercapai, nilai pengembalian adalah 1013 00:49:47,780 --> 00:49:51,490 jumlah item yang pendek atau 0. 1014 00:49:51,490 --> 00:49:57,860 >> Jadi untuk tujuan kita, jika mencapai fread akhir file, dan membaca dari 1015 00:49:57,860 --> 00:50:02,100 akhir file, tidak ada yang tersisa untuk membaca, apa itu akan kembali? 1016 00:50:02,100 --> 00:50:03,290 >> SISWA 43: Zero? 1017 00:50:03,290 --> 00:50:04,540 >> JASON Hirschhorn: Apa? 1018 00:50:04,540 --> 00:50:05,300 >> SISWA 43: Zero? 1019 00:50:05,300 --> 00:50:05,690 >> JASON Hirschhorn: Zero. 1020 00:50:05,690 --> 00:50:06,940 Ini akan kembali nol. 1021 00:50:06,940 --> 00:50:09,360 1022 00:50:09,360 --> 00:50:13,010 Jadi kita tahu bahwa fread, ketika kita sudah mencapai akhir file, akan 1023 00:50:13,010 --> 00:50:13,690 untuk kembali nol. 1024 00:50:13,690 --> 00:50:17,460 Bagaimana kita dapat menggunakannya untuk keuntungan kita? 1025 00:50:17,460 --> 00:50:21,733 >> AVI: Anda dapat mendeklarasikan variabel di luar loop disebut cek. 1026 00:50:21,733 --> 00:50:27,040 Jika cek sama - 1027 00:50:27,040 --> 00:50:28,190 untuk saat ini - satu. 1028 00:50:28,190 --> 00:50:28,920 >> JASON Hirschhorn: OK. 1029 00:50:28,920 --> 00:50:38,050 >> AVI: Dan kemudian Anda dapat menempatkan IF Pernyataan tepat setelah fread mengatakan jika 1030 00:50:38,050 --> 00:50:42,600 fread sama dengan nol - 1031 00:50:42,600 --> 00:50:43,850 no. 1032 00:50:43,850 --> 00:50:46,002 1033 00:50:46,002 --> 00:50:47,252 >> JASON Hirschhorn: Who dapat membantu Avi keluar? 1034 00:50:47,252 --> 00:50:49,690 1035 00:50:49,690 --> 00:50:52,410 >> AVI: Apa nilai dikembalikan oleh fread? 1036 00:50:52,410 --> 00:50:54,060 >> JASON Hirschhorn: Kami hanya pergi lebih dari itu. 1037 00:50:54,060 --> 00:50:55,450 >> AVI: Bagaimana Anda mewakilinya? 1038 00:50:55,450 --> 00:50:57,190 >> JASON Hirschhorn: Jadi kembali - mari kita mencari di sini - ia mengembalikan 1039 00:50:57,190 --> 00:50:59,340 size_t, yang pada dasarnya adalah integer. 1040 00:50:59,340 --> 00:51:02,240 1041 00:51:02,240 --> 00:51:03,410 Jadi itu mengembalikan sebuah integer. 1042 00:51:03,410 --> 00:51:05,160 Dan dalam kasus kami, itu akan kembali 1 atau 0 - 1043 00:51:05,160 --> 00:51:08,760 1 jika membaca satu hal - satu byte, dan 0 jika kita telah mencapai akhir. 1044 00:51:08,760 --> 00:51:13,560 1045 00:51:13,560 --> 00:51:16,450 Jadi jika fread - 1046 00:51:16,450 --> 00:51:16,855 ya? 1047 00:51:16,855 --> 00:51:20,330 >> SISWA 45: Tak bisakah kau hanya menempatkan penuh fread (buffer, 1, 1, src) ke dalam 1048 00:51:20,330 --> 00:51:21,660 while loop? 1049 00:51:21,660 --> 00:51:26,510 >> JASON Hirschhorn: Jadi Anda usulkan melakukan hal ini ke sana? 1050 00:51:26,510 --> 00:51:27,600 >> [Interposing SUARA] 1051 00:51:27,600 --> 00:51:29,520 >> JASON Hirschhorn: Tunggu. 1052 00:51:29,520 --> 00:51:30,885 Jadi kita Ridding itu. 1053 00:51:30,885 --> 00:51:33,300 Jadi Anda ajukan menempatkan fread ke sana? 1054 00:51:33,300 --> 00:51:35,457 Apa yang harus kami juga bergerak jika Anda ingin melakukan itu? 1055 00:51:35,457 --> 00:51:36,740 >> SISWA 45: buffer luar. 1056 00:51:36,740 --> 00:51:38,110 >> JASON Hirschhorn: Kita harus juga bergerak ini di sini. 1057 00:51:38,110 --> 00:51:41,700 >> SISWA 45: Tapi apakah yang terus-menerus bergerak ke depan? 1058 00:51:41,700 --> 00:51:42,950 >> [Interposing SUARA] 1059 00:51:42,950 --> 00:51:46,540 1060 00:51:46,540 --> 00:51:47,470 >> JASON Hirschhorn: OK. 1061 00:51:47,470 --> 00:51:50,570 Jadi ini adalah apa yang diusulkan Okshar. 1062 00:51:50,570 --> 00:51:51,930 Kita menciptakan penyangga kami. 1063 00:51:51,930 --> 00:51:57,020 Kami WHILE fread, maka kita fwrite. 1064 00:51:57,020 --> 00:51:59,760 Pemikiran tentang ini? 1065 00:51:59,760 --> 00:52:04,050 >> STUDENT 46: Satu-satunya pertanyaan adalah, apakah itu benar-benar menjalankan perintah fread? 1066 00:52:04,050 --> 00:52:06,175 >> JASON Hirschhorn: Pertanyaan besar. 1067 00:52:06,175 --> 00:52:11,050 Bila Anda meletakkan pemanggilan fungsi dalam kondisi, apakah itu 1068 00:52:11,050 --> 00:52:12,300 fungsi panggilan mengeksekusi? 1069 00:52:12,300 --> 00:52:15,760 1070 00:52:15,760 --> 00:52:17,770 Kami telah melihat contoh-contoh ini sebelumnya. 1071 00:52:17,770 --> 00:52:24,900 1072 00:52:24,900 --> 00:52:25,660 Benar? 1073 00:52:25,660 --> 00:52:26,125 >> SISWA 46: OK. 1074 00:52:26,125 --> 00:52:26,590 Ya. 1075 00:52:26,590 --> 00:52:30,140 Jadi itu tidak mengeksekusi. 1076 00:52:30,140 --> 00:52:31,790 >> JASON Hirschhorn: Kami telah melihat hal-hal seperti itu sebelumnya, di mana kita memiliki 1077 00:52:31,790 --> 00:52:33,550 fungsi panggilan dalam kondisi. 1078 00:52:33,550 --> 00:52:35,540 Apakah itu fungsi panggilan mengeksekusi? 1079 00:52:35,540 --> 00:52:36,350 Ya. 1080 00:52:36,350 --> 00:52:37,410 Jadi jawabannya adalah ya. 1081 00:52:37,410 --> 00:52:41,010 Fungsi panggilan ini akan mengeksekusi. 1082 00:52:41,010 --> 00:52:42,418 Tapi sekali lagi, itu adalah apa yang kita inginkan? 1083 00:52:42,418 --> 00:52:49,250 1084 00:52:49,250 --> 00:52:52,204 >> Apa salah satu cara kita bisa mencari tahu apakah itu yang kita inginkan? 1085 00:52:52,204 --> 00:52:53,470 >> MAHASISWA GANDA: Jalankan? 1086 00:52:53,470 --> 00:52:54,460 >> JASON Hirschhorn: Kita bisa menjalankannya. 1087 00:52:54,460 --> 00:52:57,500 Tapi sebelum kita melakukan itu, kita bisa juga alasan melalui ini. 1088 00:52:57,500 --> 00:52:57,920 Jika - 1089 00:52:57,920 --> 00:53:01,920 mengatakan bahwa kita memiliki satu byte dalam kami mengajukan, kita akan sampai ke sini, 1090 00:53:01,920 --> 00:53:02,660 kita akan sampai ke kode ini. 1091 00:53:02,660 --> 00:53:03,620 Ini akan berjalan. 1092 00:53:03,620 --> 00:53:07,780 fread akan kembali satu byte dan menyimpannya dalam buffer. 1093 00:53:07,780 --> 00:53:11,290 Dan ini akan mengevaluasi ke 1, benar, setelah ia kembali 1. 1094 00:53:11,290 --> 00:53:12,640 >> Jadi SEMENTARA 1. 1095 00:53:12,640 --> 00:53:15,325 Apakah itu berarti kode di dalam loop WHILE akan mengeksekusi? 1096 00:53:15,325 --> 00:53:15,453 >> SISWA 47: Ya. 1097 00:53:15,453 --> 00:53:16,040 Memang benar. 1098 00:53:16,040 --> 00:53:16,290 >> JASON Hirschhorn: Ya. 1099 00:53:16,290 --> 00:53:17,490 1 adalah benar. 1100 00:53:17,490 --> 00:53:18,240 Ini bukan 0. 1101 00:53:18,240 --> 00:53:20,360 Jadi kode di dalam sini akan mengeksekusi. 1102 00:53:20,360 --> 00:53:22,300 Jadi kita akan menulis itu. 1103 00:53:22,300 --> 00:53:25,340 Kami akan kembali ke ini baris sekali lagi. 1104 00:53:25,340 --> 00:53:26,850 Sekarang kita memiliki - 1105 00:53:26,850 --> 00:53:28,550 kita berada di akhir file kami. 1106 00:53:28,550 --> 00:53:30,980 Kita membaca dari akhir file kami, karena kita hanya memiliki satu byte di dalamnya. 1107 00:53:30,980 --> 00:53:34,270 >> Fread kembali 0, toko sesuatu dalam buffer. 1108 00:53:34,270 --> 00:53:35,890 Sejujurnya aku tidak tahu apa itu toko dalam buffer. 1109 00:53:35,890 --> 00:53:38,380 Kita mungkin bisa mencari untuk melihat apa yang dilakukannya. 1110 00:53:38,380 --> 00:53:40,130 Bahwa aku benar-benar tidak tahu. 1111 00:53:40,130 --> 00:53:43,090 Kita tidak tahu, siapa yang peduli apa itu toko dalam buffer? 1112 00:53:43,090 --> 00:53:44,010 Tapi itu kembali 0. 1113 00:53:44,010 --> 00:53:45,440 Dan akan sedangkan 0 mengeksekusi? 1114 00:53:45,440 --> 00:53:49,950 1115 00:53:49,950 --> 00:53:51,180 >> SAAT 0 tidak akan mengeksekusi. 1116 00:53:51,180 --> 00:53:54,030 Jadi kita akan pindah ke sini. 1117 00:53:54,030 --> 00:53:58,870 Jadi mari kita mengacungkan tangan jika ini adalah kode yang harus kita jalankan, atau jika kita 1118 00:53:58,870 --> 00:54:00,140 harus melakukan perubahan terlebih dahulu. 1119 00:54:00,140 --> 00:54:02,180 Jadi jika Anda berpikir - Anda harus memilih. 1120 00:54:02,180 --> 00:54:06,885 Jika Anda pikir kita harus menjalankan kode ini seperti, silahkan angkat tangan. 1121 00:54:06,885 --> 00:54:12,440 1122 00:54:12,440 --> 00:54:13,400 >> OK. 1123 00:54:13,400 --> 00:54:14,315 Ada satu - 1124 00:54:14,315 --> 00:54:17,260 apakah Anda memiliki pertanyaan, kekhawatiran? 1125 00:54:17,260 --> 00:54:18,080 Ya. 1126 00:54:18,080 --> 00:54:21,240 >> SISWA 48: Setelah kita bergerak penyangga luar loop, kita 1127 00:54:21,240 --> 00:54:22,670 harus malloc itu? 1128 00:54:22,670 --> 00:54:23,310 >> JASON Hirschhorn: Pertanyaan besar. 1129 00:54:23,310 --> 00:54:26,670 Setelah kita bergerak penyangga di luar lingkaran, kita harus malloc itu? 1130 00:54:26,670 --> 00:54:28,400 Ini adalah pertanyaan lingkup. 1131 00:54:28,400 --> 00:54:32,130 Jika kita menginisialisasi penyangga luar loop ini, akan itu ada 1132 00:54:32,130 --> 00:54:33,534 dalam loop? 1133 00:54:33,534 --> 00:54:35,230 >> MAHASISWA GANDA: Ya. 1134 00:54:35,230 --> 00:54:35,580 >> JASON Hirschhorn: Ya. 1135 00:54:35,580 --> 00:54:40,100 Jangkauannya mencakup dalam loop, dan, benar-benar, apa pun di bawah di dalam 1136 00:54:40,100 --> 00:54:42,460 kode ini, termasuk hal-hal di dalam sini. 1137 00:54:42,460 --> 00:54:43,930 Jadi kita tidak perlu malloc itu. 1138 00:54:43,930 --> 00:54:47,766 Ini adalah variabel lokal, dan ruang lingkup masih termasuk loop. 1139 00:54:47,766 --> 00:54:49,540 >> SISWA 49: Apakah kita perlu untuk membebaskan itu? 1140 00:54:49,540 --> 00:54:51,770 >> JASON Hirschhorn: Apakah kita perlu buffer bebas? 1141 00:54:51,770 --> 00:54:53,860 >> SISWA 49: Ya, jika kita tidak malloc. 1142 00:54:53,860 --> 00:54:55,750 >> JASON Hirschhorn: Apakah kita perlu buffer bebas? 1143 00:54:55,750 --> 00:54:57,160 Kami tidak. 1144 00:54:57,160 --> 00:55:01,280 Sekali lagi, itu adalah variabel lokal, jadi kita tidak perlu untuk membebaskan itu. 1145 00:55:01,280 --> 00:55:02,170 OK. 1146 00:55:02,170 --> 00:55:03,480 Mari kita lihat apa yang terjadi. 1147 00:55:03,480 --> 00:55:17,290 1148 00:55:17,290 --> 00:55:18,220 Jadi diinisiasi. 1149 00:55:18,220 --> 00:55:20,830 Itulah sesuatu yang Marcus diusulkan sebelumnya. 1150 00:55:20,830 --> 00:55:25,340 Jadi kita memiliki kesalahan itu, variabel penyangga adalah uninitialized bila digunakan di sini. 1151 00:55:25,340 --> 00:55:26,590 >> Bagaimana kita bisa memperbaiki ini? 1152 00:55:26,590 --> 00:55:29,460 1153 00:55:29,460 --> 00:55:30,960 >> SISWA 50: malloc itu? 1154 00:55:30,960 --> 00:55:31,770 >> SISWA 51: Setara NULL? 1155 00:55:31,770 --> 00:55:33,000 >> SISWA 52: Katakanlah penyangga sama dengan NULL. 1156 00:55:33,000 --> 00:55:34,250 >> JASON Hirschhorn: OK. 1157 00:55:34,250 --> 00:55:40,040 1158 00:55:40,040 --> 00:55:40,770 Terlihat bagus. 1159 00:55:40,770 --> 00:55:42,410 Kami memiliki sekarang. 1160 00:55:42,410 --> 00:55:45,630 Mari kita membuat sesuatu untuk mencoba menyalin. 1161 00:55:45,630 --> 00:56:08,990 1162 00:56:08,990 --> 00:56:10,490 Jadi kita memiliki file teks kami. 1163 00:56:10,490 --> 00:56:11,740 Bagaimana kita bisa menjalankan program ini? 1164 00:56:11,740 --> 00:56:14,140 1165 00:56:14,140 --> 00:56:15,472 Ya. 1166 00:56:15,472 --> 00:56:22,230 >> SISWA 53: Anda dapat melakukan dot slash cp, test.txt. 1167 00:56:22,230 --> 00:56:25,140 Dan kemudian Anda dapat memberi nama file lain yang akan menyimpan ke dalam. 1168 00:56:25,140 --> 00:56:25,510 >> JASON Hirschhorn: OK. 1169 00:56:25,510 --> 00:56:27,380 Kita akan menyebutnya out.txt. 1170 00:56:27,380 --> 00:56:28,630 Cool? 1171 00:56:28,630 --> 00:56:31,700 1172 00:56:31,700 --> 00:56:34,320 Kesalahan Seg. 1173 00:56:34,320 --> 00:56:35,570 Pemikiran tentang kesalahan seg? 1174 00:56:35,570 --> 00:56:40,900 1175 00:56:40,900 --> 00:56:41,390 Ini bagus. 1176 00:56:41,390 --> 00:56:45,040 Bagaimana kita bisa mencari tahu di mana kesalahan seg adalah? 1177 00:56:45,040 --> 00:56:45,680 Apa? 1178 00:56:45,680 --> 00:56:45,990 >> SISWA 54: gdb. 1179 00:56:45,990 --> 00:56:47,240 >> JASON Hirschhorn: gdb. 1180 00:56:47,240 --> 00:56:51,400 1181 00:56:51,400 --> 00:56:55,300 Kami menjalankan gdb dengan menulis gdb dot slash, nama program kami. 1182 00:56:55,300 --> 00:56:57,020 Tidak ada baris perintah argumen di sana. 1183 00:56:57,020 --> 00:56:59,570 Kita akan menetapkan breakpoint di utama. 1184 00:56:59,570 --> 00:57:02,190 Jika saya ingin memulai gdb, apa yang harus saya lakukan? 1185 00:57:02,190 --> 00:57:02,730 >> SISWA 55: R. 1186 00:57:02,730 --> 00:57:08,910 >> JASON Hirschhorn: R. Lalu apa? 1187 00:57:08,910 --> 00:57:09,400 >> SISWA 55: Argumen? 1188 00:57:09,400 --> 00:57:10,650 >> JASON Hirschhorn: Lalu argumen baris perintah. 1189 00:57:10,650 --> 00:57:15,890 1190 00:57:15,890 --> 00:57:17,120 Mari kita berjalan melalui. 1191 00:57:17,120 --> 00:57:19,090 N hanya membawaku baris demi baris. 1192 00:57:19,090 --> 00:57:21,450 Aku akan pergi sampai Saya mendapatkan kesalahan seg saya. 1193 00:57:21,450 --> 00:57:22,700 Ada kesalahan seg saya. 1194 00:57:22,700 --> 00:57:24,960 1195 00:57:24,960 --> 00:57:27,875 Sepertinya fread disebabkan kesalahan seg saya. 1196 00:57:27,875 --> 00:57:30,570 1197 00:57:30,570 --> 00:57:32,770 Aku tahu fread menyebabkan kesalahan seg saya, karena itu adalah 1198 00:57:32,770 --> 00:57:34,950 baris kami hanya dieksekusi. 1199 00:57:34,950 --> 00:57:36,530 >> Dan satu-satunya hal yang terjadi di garis itu - 1200 00:57:36,530 --> 00:57:37,520 dua hal yang terjadi. 1201 00:57:37,520 --> 00:57:40,610 Fread akan, dan kemudian kami melakukan beberapa pengecekan WHILE. 1202 00:57:40,610 --> 00:57:44,820 Saya berani bertaruh bahwa SAAT memeriksa tidak menyebabkan kesalahan seg saya. 1203 00:57:44,820 --> 00:57:46,950 Kemungkinan besar, fread adalah menyebabkan kesalahan seg saya. 1204 00:57:46,950 --> 00:57:49,260 Saya juga melihat sesuatu di sini, memcopy. 1205 00:57:49,260 --> 00:57:50,500 >> Salinan memori. 1206 00:57:50,500 --> 00:57:53,820 Kedengarannya seperti memindahkan memori dari satu lokasi ke lokasi yang lain. 1207 00:57:53,820 --> 00:57:56,890 Kedengarannya seperti sesuatu yang akan terjadi di fread, mungkin beberapa memori 1208 00:57:56,890 --> 00:57:58,910 pindah dari sini ke sini. 1209 00:57:58,910 --> 00:58:01,740 1210 00:58:01,740 --> 00:58:03,860 Mari kita pergi melalui ini lagi. 1211 00:58:03,860 --> 00:58:06,900 Bagaimana cara memulainya lebih dan jalankan lagi? 1212 00:58:06,900 --> 00:58:08,092 Ya. 1213 00:58:08,092 --> 00:58:15,140 >> SISWA 56: Apakah Anda perlu menempatkan ampersand sebelum penyangga? 1214 00:58:15,140 --> 00:58:17,800 >> JASON Hirschhorn: Jadi ampersand sebelum penyangga akan memberi saya alamat 1215 00:58:17,800 --> 00:58:22,330 penyangga, yaitu char *. 1216 00:58:22,330 --> 00:58:25,250 Mari kita jalankan melalui ini sekali lagi. 1217 00:58:25,250 --> 00:58:28,248 Bagaimana cara menjalankan melalui itu sekali lagi? 1218 00:58:28,248 --> 00:58:29,210 >> SISWA 57: Dapatkah Anda hanya ketik menjalankan lagi? 1219 00:58:29,210 --> 00:58:32,050 >> JASON Hirschhorn: Cukup ketik run lagi. 1220 00:58:32,050 --> 00:58:33,415 Jadi kita tidak akan mengeksekusi baris ini. 1221 00:58:33,415 --> 00:58:36,250 1222 00:58:36,250 --> 00:58:39,240 Jadi buffer adalah pointer NULL. 1223 00:58:39,240 --> 00:58:40,490 Benar? 1224 00:58:40,490 --> 00:58:45,870 1225 00:58:45,870 --> 00:58:47,060 Hal ini menunjuk ke - mari kita lihat. 1226 00:58:47,060 --> 00:58:48,500 Jika kita memiliki kami - 1227 00:58:48,500 --> 00:58:50,430 menggambar cepat ini. 1228 00:58:50,430 --> 00:58:53,500 Dapatkah orang melihat apakah Saya menulis di sini? 1229 00:58:53,500 --> 00:59:02,890 >> Jadi dalam stack, kami memiliki lokal variabel dan itu disebut buffer, dan 1230 00:59:02,890 --> 00:59:08,230 itu adalah pointer ke char. 1231 00:59:08,230 --> 00:59:10,325 Apa alamat char ini di? 1232 00:59:10,325 --> 00:59:12,550 >> SISWA 58: 0x0. 1233 00:59:12,550 --> 00:59:13,400 >> JASON Hirschhorn: Benar. 1234 00:59:13,400 --> 00:59:14,200 Itulah yang ini. 1235 00:59:14,200 --> 00:59:17,600 Di sini, di dalam penyangga, disimpan 0x0. 1236 00:59:17,600 --> 00:59:20,480 Itulah apa yang kita miliki - pengaturan yang kita miliki sekarang. 1237 00:59:20,480 --> 00:59:27,540 Jadi baris ini, fread, menempatkan sesuatu dari sumber mana? 1238 00:59:27,540 --> 00:59:30,560 Ke dalam kotak ini atau kotak ini? 1239 00:59:30,560 --> 00:59:31,060 Kotak mana? 1240 00:59:31,060 --> 00:59:33,290 Box atau kotak kanan kiri? 1241 00:59:33,290 --> 00:59:34,750 Kotak kanan ini. 1242 00:59:34,750 --> 00:59:38,440 >> Ini mengikuti pointer, dan menempatkan di sini. 1243 00:59:38,440 --> 00:59:42,620 Ketika kita mencoba dan memori sentuh pada lokasi 0, apa yang kita dapatkan? 1244 00:59:42,620 --> 00:59:45,050 Sebuah kesalahan segmentasi. 1245 00:59:45,050 --> 00:59:46,550 Itulah kesalahan yang kita miliki sekarang. 1246 00:59:46,550 --> 00:59:46,970 Ya. 1247 00:59:46,970 --> 00:59:48,410 >> SISWA 59: Jangan Anda memiliki untuk menempatkan star penyangga? 1248 00:59:48,410 --> 00:59:49,180 Atau tidak? 1249 00:59:49,180 --> 00:59:50,050 Untuk fread? 1250 00:59:50,050 --> 00:59:51,450 >> JASON Hirschhorn: Jadi fread membutuhkan pointer. 1251 00:59:51,450 --> 00:59:54,920 1252 00:59:54,920 --> 00:59:55,900 Jadi lewat di penyangga. 1253 00:59:55,900 --> 00:59:58,980 Dan kemudian akan de-referensi itu suatu tempat di dalam fread. 1254 00:59:58,980 --> 01:00:00,700 Tapi sekali lagi, kita melihat, dibutuhkan pointer. 1255 01:00:00,700 --> 01:00:02,560 Kita tidak perlu untuk lulus penyangga bintang. 1256 01:00:02,560 --> 01:00:05,350 Itu akan melewati apapun yang ada di sini. 1257 01:00:05,350 --> 01:00:07,980 Dan yang mungkin akan memberi kita kesalahan karena kita de-referensi itu. 1258 01:00:07,980 --> 01:00:08,150 >> Benar? 1259 01:00:08,150 --> 01:00:10,690 Ketika kita de-referensi pointer ini, ketika kami mencoba untuk mengakses lokasi ini, 1260 01:00:10,690 --> 01:00:13,140 kita mendapatkan kesalahan - kesalahan segmentasi kami. 1261 01:00:13,140 --> 01:00:15,800 Jadi - 1262 01:00:15,800 --> 01:00:16,690 oops. 1263 01:00:16,690 --> 01:00:19,090 Kita akan berhenti dari gdb. 1264 01:00:19,090 --> 01:00:20,160 Baris kami - 1265 01:00:20,160 --> 01:00:22,990 masalah kita - yang benar here on line ini. 1266 01:00:22,990 --> 01:00:26,410 Dan itu masalah karena baris ini. 1267 01:00:26,410 --> 01:00:31,780 >> Bagaimana kita bisa membuat sebuah kotak yang dapat diakses di fread. 1268 01:00:31,780 --> 01:00:31,980 Benar? 1269 01:00:31,980 --> 01:00:35,190 Kita perlu untuk membuat kotak itu salah satu byte besar, ukuran char. 1270 01:00:35,190 --> 01:00:38,590 Tapi kita perlu kotak yang dapat diakses saat fungsi ini dijalankan. 1271 01:00:38,590 --> 01:00:39,390 Jadi di mana - 1272 01:00:39,390 --> 01:00:39,640 ya. 1273 01:00:39,640 --> 01:00:40,440 Ada gagasan? 1274 01:00:40,440 --> 01:00:43,615 >> SISWA 60: Hanya mengatur sebagai karakter acak. 1275 01:00:43,615 --> 01:00:49,150 1276 01:00:49,150 --> 01:00:51,640 Hanya melakukan equals char buffer karakter. 1277 01:00:51,640 --> 01:00:53,795 Dan kemudian, ketika Anda telah penyangga di sana - 1278 01:00:53,795 --> 01:00:54,110 >> JASON Hirschhorn: Tunggu. 1279 01:00:54,110 --> 01:00:55,110 Char penyangga? 1280 01:00:55,110 --> 01:00:55,880 Jadi tidak ada bintang? 1281 01:00:55,880 --> 01:00:56,390 >> SISWA 60: Ya. 1282 01:00:56,390 --> 01:00:58,560 Keluarkan bintang. 1283 01:00:58,560 --> 01:01:00,690 Sama karakter acak. 1284 01:01:00,690 --> 01:01:01,460 >> JASON Hirschhorn: OK. 1285 01:01:01,460 --> 01:01:02,420 Jadi memberi saya satu. 1286 01:01:02,420 --> 01:01:03,170 >> SISWA 60: Like a atau sesuatu. 1287 01:01:03,170 --> 01:01:06,160 Dan kemudian ketika Anda memiliki penyangga ada, Anda menggunakan - 1288 01:01:06,160 --> 01:01:06,420 >> SISWA 61: Star? 1289 01:01:06,420 --> 01:01:07,650 Oh tidak, ampersand. 1290 01:01:07,650 --> 01:01:09,000 >> SISWA 60: Gunakan ampersand. 1291 01:01:09,000 --> 01:01:09,470 >> JASON Hirschhorn: OK. 1292 01:01:09,470 --> 01:01:11,320 Dan bagaimana dengan di fwrite? 1293 01:01:11,320 --> 01:01:14,150 >> SISWA 60: Gunakan ampersand lagi. 1294 01:01:14,150 --> 01:01:14,320 >> JASON Hirschhorn: Baiklah. 1295 01:01:14,320 --> 01:01:20,970 Jadi ide Anda, kami membuat char dan meletakkan sesuatu di dalamnya, dan kemudian 1296 01:01:20,970 --> 01:01:22,612 menulis ke char. 1297 01:01:22,612 --> 01:01:23,760 >> SISWA 60: Ya. 1298 01:01:23,760 --> 01:01:25,916 >> JASON Hirschhorn: Apa menurut orang lain? 1299 01:01:25,916 --> 01:01:27,770 >> SISWA 62: Ini berbelit-belit. 1300 01:01:27,770 --> 01:01:28,460 >> JASON Hirschhorn: OK. 1301 01:01:28,460 --> 01:01:29,760 Mari kita menariknya keluar. 1302 01:01:29,760 --> 01:01:35,720 Jadi, kali ini, aku akan menggambar ini di merah di tumpukan di sini, dan kemudian kita 1303 01:01:35,720 --> 01:01:36,410 akan memiliki - 1304 01:01:36,410 --> 01:01:36,822 ooh! 1305 01:01:36,822 --> 01:01:38,060 Maaf. 1306 01:01:38,060 --> 01:01:45,930 Jadi saat ini kita memiliki sesuatu yang disebut penyangga, dan itu di stack. 1307 01:01:45,930 --> 01:01:48,430 Benar? 1308 01:01:48,430 --> 01:01:51,520 Dan kita menyimpan di dalamnya, pada awalnya. 1309 01:01:51,520 --> 01:01:53,830 >> Kemudian kita memiliki panggilan kita untuk fread. 1310 01:01:53,830 --> 01:02:01,300 Apa fread tidak yang dibutuhkan byte dari file kita dan menempatkan di suatu tempat. 1311 01:02:01,300 --> 01:02:04,570 Ini menempatkan dalam apapun hal yang menunjuk ke. 1312 01:02:04,570 --> 01:02:09,130 Nah, sebelum kami memiliki alamat ini - 1313 01:02:09,130 --> 01:02:10,250 0x0. 1314 01:02:10,250 --> 01:02:13,349 Sekarang apa alamat yang kita miliki? 1315 01:02:13,349 --> 01:02:14,650 >> SISWA 63: Apapun alamat buffer. 1316 01:02:14,650 --> 01:02:15,970 >> JASON Hirschhorn: Apapun alamat buffer. 1317 01:02:15,970 --> 01:02:22,370 Ini mungkin akan menjadi sesuatu seperti itu. 1318 01:02:22,370 --> 01:02:26,950 Mungkin akan mulai dengan b dan f, dan kemudian memiliki enam lainnya 1319 01:02:26,950 --> 01:02:27,970 digit heksadesimal. 1320 01:02:27,970 --> 01:02:28,480 Tidak apa-apa. 1321 01:02:28,480 --> 01:02:29,470 Beberapa alamat. 1322 01:02:29,470 --> 01:02:31,410 Dan kita melewati alamat yang masuk 1323 01:02:31,410 --> 01:02:34,790 >> Dan kita akan menempatkan satu kami byte hal di alamat itu. 1324 01:02:34,790 --> 01:02:38,470 Jadi kita akan menempatkan satu kami Hal byte dalam sini. 1325 01:02:38,470 --> 01:02:40,800 Dan kemudian kita akan menulis dari apa pernah dalam sini. 1326 01:02:40,800 --> 01:02:43,425 1327 01:02:43,425 --> 01:02:45,380 Apakah Ada yang punya pertanyaan tentang itu? 1328 01:02:45,380 --> 01:02:50,990 1329 01:02:50,990 --> 01:02:54,690 Siapa yang berpikir kode ini akan bekerja? 1330 01:02:54,690 --> 01:02:56,020 >> Angkat tangan Anda jika Anda berpikir kode ini akan bekerja. 1331 01:02:56,020 --> 01:02:57,270 Anda harus mengambil sikap. 1332 01:02:57,270 --> 01:03:00,670 1333 01:03:00,670 --> 01:03:02,500 Dan yang berpikir kode ini tidak akan bekerja? 1334 01:03:02,500 --> 01:03:04,610 Angkat tangan Anda. 1335 01:03:04,610 --> 01:03:06,750 Semua orang harus mengangkat tangan mereka. 1336 01:03:06,750 --> 01:03:07,670 OK. 1337 01:03:07,670 --> 01:03:09,390 Michael, di mana kau berdiri? 1338 01:03:09,390 --> 01:03:10,680 >> MICHAEL: Saya tidak bisa memutuskan. 1339 01:03:10,680 --> 01:03:12,070 Jenis di tengah. 1340 01:03:12,070 --> 01:03:12,736 >> JASON Hirschhorn: Kau di tengah. 1341 01:03:12,736 --> 01:03:13,092 Pilih salah satu. 1342 01:03:13,092 --> 01:03:14,400 >> MICHAEL: Aku akan memiliki iman dan mengatakan ia akan bekerja. 1343 01:03:14,400 --> 01:03:14,660 >> JASON Hirschhorn: OK. 1344 01:03:14,660 --> 01:03:16,047 Anda akan memiliki iman dan mengatakan itu bekerja? 1345 01:03:16,047 --> 01:03:26,490 1346 01:03:26,490 --> 01:03:27,020 Apa yang terjadi? 1347 01:03:27,020 --> 01:03:28,270 >> [Interposing SUARA] 1348 01:03:28,270 --> 01:03:35,170 1349 01:03:35,170 --> 01:03:35,950 >> JASON Hirschhorn: Tidak ada seg kesalahan. 1350 01:03:35,950 --> 01:03:40,320 Bagaimana kita dapat memeriksa untuk melihat apakah dua hal yang sama? 1351 01:03:40,320 --> 01:03:42,060 Dua file adalah sama. 1352 01:03:42,060 --> 01:03:43,300 >> SISWA 64: Diff. 1353 01:03:43,300 --> 01:03:45,490 >> JASON Hirschhorn: Diff. 1354 01:03:45,490 --> 01:03:51,630 Cek Diff untuk perbedaan antara dua file, dan jika ia mengembalikan 1355 01:03:51,630 --> 01:03:52,890 apa-apa, mereka identik. 1356 01:03:52,890 --> 01:03:59,030 Dan jika kita membuka, kita mendapatkan file kita. 1357 01:03:59,030 --> 01:04:00,490 Jadi itu solusi yang tepat. 1358 01:04:00,490 --> 01:04:01,780 Mari kita melihat kembali sekali lagi. 1359 01:04:01,780 --> 01:04:04,080 Kami benar-benar bahkan tidak perlu menginisialisasi itu. 1360 01:04:04,080 --> 01:04:05,520 >> Mungkin akan terlihat sedikit bersih jika Anda tidak menaruh 1361 01:04:05,520 --> 01:04:07,680 sesuatu yang acak di sana. 1362 01:04:07,680 --> 01:04:13,070 Intinya menjadi, Anda perlu membuat beberapa ruang untuk menyimpan sesuatu dari 1363 01:04:13,070 --> 01:04:15,530 fread dan mengambil sesuatu dari fwrite. 1364 01:04:15,530 --> 01:04:18,400 Dan hal yang harus baik lokal variabel pada stack - Anda 1365 01:04:18,400 --> 01:04:19,890 bisa saja malloc'd beberapa ruang. 1366 01:04:19,890 --> 01:04:23,030 >> Jadi kita benar-benar bisa memiliki malloc tertulis di sini, dan 1367 01:04:23,030 --> 01:04:25,420 yang akan bekerja. 1368 01:04:25,420 --> 01:04:28,660 Dan kemudian kita akan telah menyimpan hal-hal kita di suatu tempat di heap. 1369 01:04:28,660 --> 01:04:31,940 Tapi ini sebenarnya, mungkin, solusi yang paling elegan. 1370 01:04:31,940 --> 01:04:34,490 Hanya membuat beberapa ruang pada stack untuk hal-hal ini untuk pergi. 1371 01:04:34,490 --> 01:04:37,690 1372 01:04:37,690 --> 01:04:38,990 >> Saya akan memiliki dua komentar lain. 1373 01:04:38,990 --> 01:04:44,650 Jika Anda adalah untuk mengambil giliran dalam hal ini, dan kemudian mendapatkan mencetak gol ini, komentar saya 1374 01:04:44,650 --> 01:04:47,400 akan menjadi sebagai berikut. 1375 01:04:47,400 --> 01:04:54,300 1 ini di sini, bagi saya, melihat seperti nomor ajaib. 1376 01:04:54,300 --> 01:04:56,860 Ini 1, dalam hal fread, masuk akal. 1377 01:04:56,860 --> 01:04:59,580 Itulah beberapa hal untuk membaca atau menulis. 1378 01:04:59,580 --> 01:05:03,740 >> Tapi yang satu ini di sini harus mungkin menjadi sesuatu yang lain. 1379 01:05:03,740 --> 01:05:05,180 Jadi apa adalah salah satu solusi? 1380 01:05:05,180 --> 01:05:06,545 >> SISWA 65: Ukuran byte. 1381 01:05:06,545 --> 01:05:10,100 1382 01:05:10,100 --> 01:05:11,080 >> JASON Hirschhorn: Seperti itu? 1383 01:05:11,080 --> 01:05:13,130 >> SISWA 65: Ukuran char. 1384 01:05:13,130 --> 01:05:13,820 >> JASON Hirschhorn: Ukuran char. 1385 01:05:13,820 --> 01:05:15,290 Ya, byte bukanlah tipe. 1386 01:05:15,290 --> 01:05:16,320 Jadi ukuran karya arang. 1387 01:05:16,320 --> 01:05:30,270 Kita bisa, di bagian atas kode kita, # didefinisikan itu. 1388 01:05:30,270 --> 01:05:33,410 Disebut sesuatu BYTE dan itu benar-benar sebuah char. 1389 01:05:33,410 --> 01:05:37,675 Sebenarnya, pendekatan yang lebih baik mungkin ini - 1390 01:05:37,675 --> 01:05:39,391 uint. 1391 01:05:39,391 --> 01:05:40,780 Ada yang tahu apa itu? 1392 01:05:40,780 --> 01:05:44,388 1393 01:05:44,388 --> 01:05:44,840 >> Maaf. 1394 01:05:44,840 --> 01:05:46,090 Saya memilikinya mundur. 1395 01:05:46,090 --> 01:05:51,620 1396 01:05:51,620 --> 01:05:52,200 Tunggu, tidak. 1397 01:05:52,200 --> 01:05:53,450 Arah mana ia pergi? 1398 01:05:53,450 --> 01:05:58,071 1399 01:05:58,071 --> 01:05:59,660 Ada yang tahu apa itu? 1400 01:05:59,660 --> 01:06:00,950 Ya. 1401 01:06:00,950 --> 01:06:05,650 >> SISWA 67: Seharusnya membantu standarisasi di sistem hal-hal yang 1402 01:06:05,650 --> 01:06:08,760 memiliki - seperti unsigned integer yang memiliki 8 byte? 1403 01:06:08,760 --> 01:06:11,785 >> JASON Hirschhorn: Itu tepat. 1404 01:06:11,785 --> 01:06:14,310 Pada mesin yang berbeda, ukuran char - 1405 01:06:14,310 --> 01:06:15,180 biasanya tidak char. 1406 01:06:15,180 --> 01:06:16,100 Karakter biasanya satu byte. 1407 01:06:16,100 --> 01:06:19,590 Tetapi ukuran tipe data lain ukuran yang berbeda pada mesin 32-bit 1408 01:06:19,590 --> 01:06:21,370 versus mesin 64-bit. 1409 01:06:21,370 --> 01:06:25,180 Sebuah uint8_t selalu 8 bit - 1410 01:06:25,180 --> 01:06:27,210 selalu satu byte. 1411 01:06:27,210 --> 01:06:29,580 >> Dan saya harus menyertakan bahwa file standar int sundulan. 1412 01:06:29,580 --> 01:06:35,040 Jadi sekarang, ini mungkin akan menjadi cara terbaik untuk menulis kode ini. 1413 01:06:35,040 --> 01:06:40,160 1414 01:06:40,160 --> 01:06:41,450 Jadi saya menyingkirkan angka ajaib. 1415 01:06:41,450 --> 01:06:44,690 Dan saya juga memiliki lebih logis ketik buffer. 1416 01:06:44,690 --> 01:06:49,450 Hal ini tidak hanya char, itu adalah byte, yang adalah apa yang kita harapkan untuk menjadi. 1417 01:06:49,450 --> 01:06:53,400 >> Dan di sini, kita sudah benar-benar telah sedikit lebih kuat. 1418 01:06:53,400 --> 01:06:55,190 Kami tidak menyebutnya char, yang - 1419 01:06:55,190 --> 01:06:58,630 mungkin, siapa tahu - bisa menjadi berbeda ukuran pada mesin yang berbeda. 1420 01:06:58,630 --> 01:07:02,025 Kami benar-benar mengatakan ini adalah persis satu byte, selalu, tidak peduli apa. 1421 01:07:02,025 --> 01:07:05,810 Dan jika kita melihat di sini, kita membuat cp. 1422 01:07:05,810 --> 01:07:08,340 Uh-oh. 1423 01:07:08,340 --> 01:07:09,590 Apa yang terjadi? 1424 01:07:09,590 --> 01:07:14,470 1425 01:07:14,470 --> 01:07:16,170 >> SISWA 68: Mungkin diaktifkan. 1426 01:07:16,170 --> 01:07:17,880 >> JASON Hirschhorn: Apa? 1427 01:07:17,880 --> 01:07:19,130 >> SISWA 69: Apakah itu? 1428 01:07:19,130 --> 01:07:21,940 1429 01:07:21,940 --> 01:07:25,080 >> SISWA 70: Anda tidak melakukan mendefinisikannya sebagai tipe. 1430 01:07:25,080 --> 01:07:28,684 >> SISWA 71: Tapi seharusnya didefinisikan dalam standar. 1431 01:07:28,684 --> 01:07:29,934 >> SISWA 72: Apa yang terjadi? 1432 01:07:29,934 --> 01:07:37,660 1433 01:07:37,660 --> 01:07:40,210 >> SISWA 73: Harus mendefinisikan menjadi huruf besar semua? 1434 01:07:40,210 --> 01:07:41,370 >> JASON Hirschhorn: Jadi bukan # define. 1435 01:07:41,370 --> 01:07:45,490 Sebenarnya, dalam hal ini, saya akan menggunakan typedef. 1436 01:07:45,490 --> 01:07:48,590 Karena kita menggunakannya sebagai jenis di satu lokasi. 1437 01:07:48,590 --> 01:07:51,990 Jadi dalam hal ini, kita benar-benar ingin typedef seperti kita mencetak jenis baru 1438 01:07:51,990 --> 01:07:54,490 byte, dan itu adalah, pada dasarnya, ini. 1439 01:07:54,490 --> 01:07:56,590 Ini sedikit berbeda dengan # define. 1440 01:07:56,590 --> 01:08:02,740 >> Dan sekarang, kode kita bekerja sempurna. 1441 01:08:02,740 --> 01:08:05,230 Jadi, sekali lagi, # define mengambil sesuatu, menggantikan di mana-mana 1442 01:08:05,230 --> 01:08:06,780 dengan hal lain. 1443 01:08:06,780 --> 01:08:07,920 Ini hanya makro - 1444 01:08:07,920 --> 01:08:09,420 singkatan untuk menyingkirkan angka ajaib. 1445 01:08:09,420 --> 01:08:11,360 Tapi dalam kasus ini, karena kita menggunakannya sebagai tipe - 1446 01:08:11,360 --> 01:08:12,180 di sini - 1447 01:08:12,180 --> 01:08:19,880 dalam rangka untuk itu untuk bekerja, kita perlu untuk typedef byte apa pun. 1448 01:08:19,880 --> 01:08:21,840 >> Dan kita mendefinisikan itu di sini. 1449 01:08:21,840 --> 01:08:24,750 Ini bukan sebuah struct, itu sebenarnya hanya integer unsigned. 1450 01:08:24,750 --> 01:08:27,680 Itu salah satu byte panjang. 1451 01:08:27,680 --> 01:08:31,910 Kode ini akan tersedia secara online, dan Anda semua harus memilikinya sekarang. 1452 01:08:31,910 --> 01:08:33,830 >> Jadi kita punya - 1453 01:08:33,830 --> 01:08:34,250 sempurna - 1454 01:08:34,250 --> 01:08:41,359 13 menit tersisa untuk pergi Masalah lebih set 5. 1455 01:08:41,359 --> 01:08:44,270 Saya ingin berjalan melalui copy.c bersama-sama, dan kemudian kita akan berbicara secara singkat 1456 01:08:44,270 --> 01:08:47,120 tentang bagian-bagian lain masalah ditetapkan. 1457 01:08:47,120 --> 01:08:48,899 Jadi biarkan aku menarik copy.c. 1458 01:08:48,899 --> 01:09:03,930 1459 01:09:03,930 --> 01:09:08,810 Dan hal yang keren adalah, kita sudah benar-benar sudah menulis banyak kode ini. 1460 01:09:08,810 --> 01:09:11,180 >> Kode kami menulis benar-benar hanya keluar dari sini ketika aku masih 1461 01:09:11,180 --> 01:09:13,120 menulis ini pada saya sendiri. 1462 01:09:13,120 --> 01:09:16,990 Tapi ini adalah copy.c, membentuk yayasan untuk dua bagian pertama 1463 01:09:16,990 --> 01:09:22,340 masalah ditetapkan untuk whodunit.c, yang Anda perlu menulis, dan resize.c. 1464 01:09:22,340 --> 01:09:27,050 Recover.c, yang merupakan ketiga dan terakhir bagian dari himpunan masalah, tidak 1465 01:09:27,050 --> 01:09:29,529 didasarkan dari file ini. 1466 01:09:29,529 --> 01:09:32,200 >> Anda akan perlu menulis file tersebut, kami memberikan template untuk itu 1467 01:09:32,200 --> 01:09:34,620 mengajukan, tapi itu tidak ada hubungannya dengan copy.c. 1468 01:09:34,620 --> 01:09:38,675 Tetapi karena copy.c adalah dasar untuk dua bagian pertama, kita akan 1469 01:09:38,675 --> 01:09:42,000 berjalan melalui sekarang, sehingga Anda memiliki pengertian yang baik dari apa yang dilakukannya. 1470 01:09:42,000 --> 01:09:43,640 >> Dan memberikan beberapa komentar dari itu pergi. 1471 01:09:43,640 --> 01:09:45,120 Kami sudah menulis beberapa hal ini. 1472 01:09:45,120 --> 01:09:49,220 Pertama, kami memastikan kita mendapatkan tiga argumen. 1473 01:09:49,220 --> 01:09:50,560 Selanjutnya, kita mengingat nama file. 1474 01:09:50,560 --> 01:09:52,960 Jadi kami melewatkan langkah ini ketika kami kode hal kami - 1475 01:09:52,960 --> 01:09:54,700 ketika cp kami. 1476 01:09:54,700 --> 01:09:56,750 Tapi di sini, mereka membuat sedikit lebih bersih. 1477 01:09:56,750 --> 01:09:59,350 >> Mereka memeriksa untuk memastikan kedua file baik, di 1478 01:09:59,350 --> 01:10:00,450 Selain membuka mereka. 1479 01:10:00,450 --> 01:10:04,760 Kami menulis semua kode ini sekarang, jadi aku tidak akan memikirkan kode ini. 1480 01:10:04,760 --> 01:10:09,670 Berikutnya adalah beberapa hal yang khusus untuk jenis file yang kita gunakan, yang 1481 01:10:09,670 --> 01:10:12,240 adalah file bitmap. 1482 01:10:12,240 --> 01:10:15,660 File Bitmap memiliki beberapa metadata terkait dengan mereka. 1483 01:10:15,660 --> 01:10:20,190 >> Jadi pasangan pertama byte memberitahu Anda tentang file. 1484 01:10:20,190 --> 01:10:23,460 Mereka bukan warna pixel dalam gambar itu. 1485 01:10:23,460 --> 01:10:25,120 Mereka memberitahu Anda tentang file. 1486 01:10:25,120 --> 01:10:28,220 Dan jika Anda membaca melalui set masalah, Anda akan memiliki lebih banyak informasi 1487 01:10:28,220 --> 01:10:33,100 pada apa jenis struktur metadata disertakan dengan bitmap. 1488 01:10:33,100 --> 01:10:39,350 >> Tapi itulah mengapa kita memiliki pertama ini set - kode ini di sini. 1489 01:10:39,350 --> 01:10:42,490 Kami membaca metadata - 1490 01:10:42,490 --> 01:10:45,800 dua potong metadata - file header dan informasi header. 1491 01:10:45,800 --> 01:10:51,030 Dan kami memeriksa beberapa bagian dari itu untuk pastikan itu adalah file bitmap yang benar 1492 01:10:51,030 --> 01:10:52,420 sebelum melanjutkan. 1493 01:10:52,420 --> 01:10:55,470 >> Dan lagi, ini adalah rincian kami tidak perlu masuk ke sekarang. 1494 01:10:55,470 --> 01:10:57,720 Jika Anda membaca melalui set masalah, Anda akan memahami ini. 1495 01:10:57,720 --> 01:11:01,370 Singkat cerita, ini hanya mengatakan, ini adalah file bitmap, dan 1496 01:11:01,370 --> 01:11:02,810 menyatakan bahwa. 1497 01:11:02,810 --> 01:11:05,180 >> Selanjutnya, kita sedang menulis mereka untuk keluar berkas. 1498 01:11:05,180 --> 01:11:05,660 Kita melihat bahwa di sini. 1499 01:11:05,660 --> 01:11:06,910 Kami menulis untuk keluar pointer. 1500 01:11:06,910 --> 01:11:09,260 1501 01:11:09,260 --> 01:11:11,320 Selanjutnya, kita menentukan bantalan. 1502 01:11:11,320 --> 01:11:15,240 Jadi sekali lagi, seperti kekhususan dengan file bitmap, beberapa baris termasuk 1503 01:11:15,240 --> 01:11:16,840 padding di akhir. 1504 01:11:16,840 --> 01:11:19,000 Dan jika Anda membaca melalui set masalah, Anda akan mempelajari lebih lanjut tentang bantalan. 1505 01:11:19,000 --> 01:11:22,330 Ini adalah formula untuk menemukan bantalan. 1506 01:11:22,330 --> 01:11:23,610 >> Penting untuk diingat - 1507 01:11:23,610 --> 01:11:29,720 ketika Anda mengubah ukuran bitmap mengajukan, perubahan bantalan. 1508 01:11:29,720 --> 01:11:31,970 Bila Anda mengubah ukuran mengajukan, perubahan bantalan. 1509 01:11:31,970 --> 01:11:34,310 Ini tidak akan menjadi lebih besar dari 3 - 1510 01:11:34,310 --> 01:11:36,510 itu akan menjadi 0 sampai 3, inklusif. 1511 01:11:36,510 --> 01:11:38,930 Tetapi ketika Anda mengubah ukuran sesuatu, perubahan bantalan. 1512 01:11:38,930 --> 01:11:47,100 >> Jika saya hanya memiliki satu piksel berturut-turut itu, saya membutuhkan tiga byte padding, karena 1513 01:11:47,100 --> 01:11:51,190 setiap baris harus kelipatan empat byte panjang dalam sebuah file bitmap. 1514 01:11:51,190 --> 01:11:56,120 Tapi kalau aku ganda itu, untuk pergi dari satu pixel dua pixel, masing-masing, 1515 01:11:56,120 --> 01:11:59,510 katakanlah, adalah byte, maka saya perlu dua byte padding untuk membuat 1516 01:11:59,510 --> 01:12:00,970 yang sama dengan empat. 1517 01:12:00,970 --> 01:12:04,200 >> Jadi ketika saya mengubah ukuran sesuatu, Saya perlu mengubah jumlah 1518 01:12:04,200 --> 01:12:06,551 padding yang saya miliki. 1519 01:12:06,551 --> 01:12:08,100 Apakah itu masuk akal bagi semua orang? 1520 01:12:08,100 --> 01:12:12,020 1521 01:12:12,020 --> 01:12:18,720 Selanjutnya, kita iterate atas setiap baris, atau melalui semua baris. 1522 01:12:18,720 --> 01:12:21,400 Dan kemudian kita iterate melalui setiap kolom dalam setiap baris. 1523 01:12:21,400 --> 01:12:25,330 Kami memperlakukan bitmap ini seperti grid, seperti kami telah diperlakukan 1524 01:12:25,330 --> 01:12:26,490 papan di 15. 1525 01:12:26,490 --> 01:12:29,200 >> Seperti kita memperlakukan batu bata ketika kami mencetak mereka di layar. 1526 01:12:29,200 --> 01:12:31,350 Sebuah grid baris dan kolom. 1527 01:12:31,350 --> 01:12:32,350 Kemudian - kami melihat ini. 1528 01:12:32,350 --> 01:12:33,840 Kami benar-benar hanya kode ini. 1529 01:12:33,840 --> 01:12:35,780 Kami menciptakan beberapa penyimpanan sementara. 1530 01:12:35,780 --> 01:12:38,710 Kita membaca di sana, dan kemudian kita menulis itu. 1531 01:12:38,710 --> 01:12:42,680 Ini adalah apa yang baru saja kita lakukan. 1532 01:12:42,680 --> 01:12:46,760 >> Selanjutnya, karena aku mengatakan setiap baris berakhir dalam beberapa padding, kita 1533 01:12:46,760 --> 01:12:48,260 melewatkan bantalan itu - 1534 01:12:48,260 --> 01:12:51,000 padding tua. 1535 01:12:51,000 --> 01:12:52,630 Dan kemudian kita tambahkan kembali. 1536 01:12:52,630 --> 01:12:55,140 Dalam hal ini, kita sedang menciptakan file yang tepat sama. 1537 01:12:55,140 --> 01:12:56,180 Kami hanya menyalin. 1538 01:12:56,180 --> 01:12:57,700 Jadi baris ini adalah konyol. 1539 01:12:57,700 --> 01:12:59,660 Kita bisa benar-benar hanya menempatkan padding masuk 1540 01:12:59,660 --> 01:13:04,290 >> Tetapi jika Anda mengubah ukuran file, Anda masih ingin baris ini? 1541 01:13:04,290 --> 01:13:08,510 1542 01:13:08,510 --> 01:13:11,560 Jadi jika kita mengubah ukuran file, apakah kita masih ingin melewatkan 1543 01:13:11,560 --> 01:13:12,810 lebih padding tua? 1544 01:13:12,810 --> 01:13:15,170 1545 01:13:15,170 --> 01:13:15,970 >> SISWA 74: Ya. 1546 01:13:15,970 --> 01:13:17,090 >> JASON Hirschhorn: Jadi kita lakukan. 1547 01:13:17,090 --> 01:13:19,290 Karena ini, sekali lagi, penawaran dengan file sumber. 1548 01:13:19,290 --> 01:13:21,570 Kami tidak peduli tentang padding dari file sumber. 1549 01:13:21,570 --> 01:13:23,410 Kami ingin pergi ke baris berikutnya. 1550 01:13:23,410 --> 01:13:28,850 Tapi kita tidak hanya menempatkan kembali jumlah lama padding. 1551 01:13:28,850 --> 01:13:31,540 Kita perlu untuk menempatkan kembali jumlah baru padding. 1552 01:13:31,540 --> 01:13:35,810 >> Jadi ketika kita mengubah ukuran berkas, kita masih ingin melewatkan 1553 01:13:35,810 --> 01:13:38,270 padding file lama - apa kita membaca dari. 1554 01:13:38,270 --> 01:13:40,370 Tapi apa yang kita menulis untuk, kita akan perlu untuk dimasukkan kembali beberapa berbeda 1555 01:13:40,370 --> 01:13:41,890 jumlah padding yang kita sudah ditentukan. 1556 01:13:41,890 --> 01:13:42,780 Ya. 1557 01:13:42,780 --> 01:13:44,550 >> SISWA 75: Urutan kedua garis tidak masalah, kan? 1558 01:13:44,550 --> 01:13:46,160 Karena Anda menangani file yang berbeda. 1559 01:13:46,160 --> 01:13:46,620 >> JASON Hirschhorn: Tepat. 1560 01:13:46,620 --> 01:13:48,220 Urutan dua baris tidak masalah. 1561 01:13:48,220 --> 01:13:49,790 Kami menulis baris ini. 1562 01:13:49,790 --> 01:13:51,430 Hal ini di sini untuk file kita menulis untuk. 1563 01:13:51,430 --> 01:13:54,370 Itu penting, sehingga kita mendapatkan jumlah yang tepat padding. 1564 01:13:54,370 --> 01:13:57,560 Hal ini harus berurusan dengan dalam file. 1565 01:13:57,560 --> 01:13:58,560 Kami ingin melewatkan hak lebih padding. 1566 01:13:58,560 --> 01:13:59,470 >> Kami tidak ingin membaca - 1567 01:13:59,470 --> 01:14:01,500 jika kita membaca byte pada suatu waktu, kita tidak peduli tentang orang-orang byte bantalan. 1568 01:14:01,500 --> 01:14:04,070 Kami ingin pindah ke baris berikutnya. 1569 01:14:04,070 --> 01:14:11,800 Akhirnya seperti Lucy berikan untuk kita, kita menutup file dan mengembalikan 0. 1570 01:14:11,800 --> 01:14:13,890 Jadi ini adalah copy.c. 1571 01:14:13,890 --> 01:14:17,850 Dan kami benar-benar menulis - kita menghabiskan sebagian besar bagian menulis ini, pada dasarnya. 1572 01:14:17,850 --> 01:14:18,740 >> Anda membuat ini. 1573 01:14:18,740 --> 01:14:22,440 Jadi mudah-mudahan Anda memiliki rasa yang baik apa yang terjadi di sini. 1574 01:14:22,440 --> 01:14:25,890 Perbedaan besar, jujur, hanya Bagian pertama ini yang berhubungan dengan 1575 01:14:25,890 --> 01:14:29,970 kekhasan file bitmap. 1576 01:14:29,970 --> 01:14:33,570 Jadi saya punya sebagai slide berikutnya, apa yang perlu kita lakukan? 1577 01:14:33,570 --> 01:14:35,510 Nah, mari kita berpikir tentang cerita detektif. 1578 01:14:35,510 --> 01:14:38,080 >> Dan untuk seseorang yang membaca masalahnya mengatur, apa yang kita 1579 01:14:38,080 --> 01:14:41,410 perlu dilakukan di cerita detektif? 1580 01:14:41,410 --> 01:14:42,080 Cukup. 1581 01:14:42,080 --> 01:14:42,460 Aleja. 1582 01:14:42,460 --> 01:14:48,570 >> Aleja: Bisakah Anda mengambil bagian setiap pixel yang menunjukkan merah. 1583 01:14:48,570 --> 01:14:49,730 Dan kemudian - 1584 01:14:49,730 --> 01:14:50,730 jenis? 1585 01:14:50,730 --> 01:14:51,860 >> JASON Hirschhorn: OK. 1586 01:14:51,860 --> 01:14:54,460 Jadi mengambil bagian masing-masing pixel yang menunjukkan merah. 1587 01:14:54,460 --> 01:14:57,234 Itu dekat, tapi tidak semuanya. 1588 01:14:57,234 --> 01:14:59,780 >> SISWA 76: Well, ada cara yang berbeda untuk melakukannya. 1589 01:14:59,780 --> 01:14:59,870 >> JASON Hirschhorn: OK. 1590 01:14:59,870 --> 01:15:03,070 Beri aku satu cara. 1591 01:15:03,070 --> 01:15:08,240 >> SISWA 76: Keluarkan semua merah, dan kemudian menekankan biru dan hijau. 1592 01:15:08,240 --> 01:15:10,010 >> JASON Hirschhorn: OK. 1593 01:15:10,010 --> 01:15:11,830 Jadi mengingat kedua cara ini - 1594 01:15:11,830 --> 01:15:15,210 kedengarannya seperti kita memberikan pixel, itu memiliki tingkat merah, biru, dan hijau. 1595 01:15:15,210 --> 01:15:19,350 Kami ingin mengubah tingkat relatif merah, biru, dan hijau, tergantung 1596 01:15:19,350 --> 01:15:20,740 pada pixel tersebut. 1597 01:15:20,740 --> 01:15:28,380 Dimana dalam kode ini harus kita ubah relatif merah, biru, dan hijau 1598 01:15:28,380 --> 01:15:29,720 tingkat pixel diberikan. 1599 01:15:29,720 --> 01:15:30,600 Setelah kami telah membacanya - 1600 01:15:30,600 --> 01:15:32,520 sebelum kita menulis itu? 1601 01:15:32,520 --> 01:15:34,564 Beri aku nomor baris. 1602 01:15:34,564 --> 01:15:35,950 >> MAHASISWA GANDA: 83. 1603 01:15:35,950 --> 01:15:37,320 >> JASON Hirschhorn: 83. 1604 01:15:37,320 --> 01:15:38,570 Jadi di sini. 1605 01:15:38,570 --> 01:15:40,830 1606 01:15:40,830 --> 01:15:45,710 Untuk cerita detektif, kode yang Anda butuhkan untuk menulis semua harus pergi di sana. 1607 01:15:45,710 --> 01:15:47,640 Dan itulah satu-satunya kode Anda perlu menulis. 1608 01:15:47,640 --> 01:15:51,520 Karena, seperti yang kita dengar, semua yang Anda butuhkan untuk lakukan adalah mengubah ini relatif biru, 1609 01:15:51,520 --> 01:15:54,420 tingkat merah, dan hijau dari setiap pixel. 1610 01:15:54,420 --> 01:15:58,250 >> Anda sudah membacanya, dan sekarang kau akan menulis itu. 1611 01:15:58,250 --> 01:16:03,100 Bagaimana cara mendapatkan - jika saya memiliki hal ini disebut tiga, di sini, dan itu dari 1612 01:16:03,100 --> 01:16:04,570 ketik RGBTRIPLE - 1613 01:16:04,570 --> 01:16:08,650 baik, jika kita melihat di bmp.h, apa RGBTRIPLE? 1614 01:16:08,650 --> 01:16:11,450 1615 01:16:11,450 --> 01:16:12,700 >> SISWA 77: Ini struct. 1616 01:16:12,700 --> 01:16:17,440 1617 01:16:17,440 --> 01:16:18,900 >> JASON Hirschhorn: RGBTRIPLE adalah struct. 1618 01:16:18,900 --> 01:16:22,330 Kita melihat bahwa tepat di sini. 1619 01:16:22,330 --> 01:16:26,600 Jadi jika saya ingin akses, katakanlah, tingkat merah dari struct, bagaimana cara 1620 01:16:26,600 --> 01:16:30,005 mengakses tingkat merah dari struct ini? 1621 01:16:30,005 --> 01:16:37,280 >> [CLASS murmur] 1622 01:16:37,280 --> 01:16:38,530 >> SISWA 78: RGBTRIPLE.rgbtred? 1623 01:16:38,530 --> 01:16:47,250 1624 01:16:47,250 --> 01:16:48,856 >> JASON Hirschhorn: Apakah itu benar? 1625 01:16:48,856 --> 01:16:53,040 >> SISWA 79: Ini harus tiga dot, bukan RGBTRIPLE dot? 1626 01:16:53,040 --> 01:16:54,120 >> JASON Hirschhorn: Triple. 1627 01:16:54,120 --> 01:16:56,700 Tiga adalah variabel lokal, sehingga sini, tidak ada petunjuk di sini. 1628 01:16:56,700 --> 01:16:58,400 Jadi kita hanya menggunakan notasi titik. 1629 01:16:58,400 --> 01:17:00,480 Hal ini akan memberikan tingkat merah. 1630 01:17:00,480 --> 01:17:06,180 Jika saya ingin mengubahnya, saya hanya mengatur itu sama dengan sesuatu yang berbeda. 1631 01:17:06,180 --> 01:17:13,190 Jadi sekali lagi, baris kode akses variabel ini di dalam struct ini, dan 1632 01:17:13,190 --> 01:17:15,070 kita dapat mengaturnya untuk sesuatu yang baru. 1633 01:17:15,070 --> 01:17:20,040 >> Jadi untuk cerita detektif, sekali lagi, ini adalah, pada dasarnya, apa yang perlu kita lakukan. 1634 01:17:20,040 --> 01:17:21,170 Sangat sederhana. 1635 01:17:21,170 --> 01:17:25,020 Hanya mengubah beberapa tingkat relatif, dan ini adalah di mana kode yang berjalan. 1636 01:17:25,020 --> 01:17:27,720 Resize, di sisi lain, adalah sedikit lebih sulit. 1637 01:17:27,720 --> 01:17:30,900 Bahkan, mengubah ukuran mungkin adalah Bagian paling sulit dari masalah ini ditetapkan. 1638 01:17:30,900 --> 01:17:32,720 Kami memiliki tiga menit untuk pergi di atasnya. 1639 01:17:32,720 --> 01:17:34,910 >> Tapi sekali lagi, kita sudah menulis sebagian besar kode ini, jadi kami 1640 01:17:34,910 --> 01:17:36,500 harus cukup familiar. 1641 01:17:36,500 --> 01:17:40,750 Apa sajakah hal yang ingin kita lakukan di mengubah ukuran, jika Anda sudah membaca selama 1642 01:17:40,750 --> 01:17:43,470 masalah set? 1643 01:17:43,470 --> 01:17:45,290 Jika Anda memberikan mereka kepada saya, kami dapat berbicara tentang mereka. 1644 01:17:45,290 --> 01:17:47,340 Apa sajakah hal yang ingin kita lakukan? 1645 01:17:47,340 --> 01:17:47,970 >> SISWA 80: Vertikal - 1646 01:17:47,970 --> 01:17:52,360 jadi anda harus horizontal mengubah ukurannya, tetapi secara vertikal mengubah ukurannya juga? 1647 01:17:52,360 --> 01:17:58,475 >> JASON Hirschhorn: Jadi jika kita diberi pixel, dan kami ingin mengubah ukurannya dengan 1648 01:17:58,475 --> 01:18:03,460 faktor dua, sekarang perlu ukurannya horizontal dan ukurannya 1649 01:18:03,460 --> 01:18:05,220 vertikal. 1650 01:18:05,220 --> 01:18:06,640 Apakah itu masuk akal? 1651 01:18:06,640 --> 01:18:07,060 Ya. 1652 01:18:07,060 --> 01:18:09,300 Jadi itu mungkin Tantangan terbesar. 1653 01:18:09,300 --> 01:18:10,430 Dan kita akan berbicara tentang itu dalam detik. 1654 01:18:10,430 --> 01:18:11,065 Ya. 1655 01:18:11,065 --> 01:18:15,270 >> SISWA 81: Cara saya memikirkannya itu Anda membutuhkan print it out - 1656 01:18:15,270 --> 01:18:15,490 >> JASON Hirschhorn: Tunggu. 1657 01:18:15,490 --> 01:18:17,580 Jangan katakan apa yang kau lakukan. 1658 01:18:17,580 --> 01:18:20,620 Kita akan berbicara dalam logika. 1659 01:18:20,620 --> 01:18:21,870 >> SISWA 81: OK. 1660 01:18:21,870 --> 01:18:25,090 1661 01:18:25,090 --> 01:18:27,410 Apa pertanyaannya? 1662 01:18:27,410 --> 01:18:28,892 >> JASON Hirschhorn: Anda hanya mengangkat tangan Anda. 1663 01:18:28,892 --> 01:18:31,600 Tidak ada pertanyaan. 1664 01:18:31,600 --> 01:18:32,520 Biarkan aku hadir. 1665 01:18:32,520 --> 01:18:34,560 Mari saya hanya membahas secara singkat ini. 1666 01:18:34,560 --> 01:18:38,400 Jadi kita memiliki satu pixel, kita ingin meniru, baik secara horizontal maupun 1667 01:18:38,400 --> 01:18:39,360 vertikal. 1668 01:18:39,360 --> 01:18:48,920 Jadi idealnya apa yang kita lakukan di sini adalah, kita membaca dalam pixel, kita menuliskannya 1669 01:18:48,920 --> 01:18:51,690 namun banyak kali. 1670 01:18:51,690 --> 01:18:54,720 >> Tapi kemudian kami memiliki trik kami di sini, karena maka kita ingin melompat ke 1671 01:18:54,720 --> 01:18:57,660 baris berikutnya dan menuliskannya pada awal baris berikutnya. 1672 01:18:57,660 --> 01:19:02,960 Jadi jika kita ingin meniru kedua horizontal dan vertikal, apa yang 1673 01:19:02,960 --> 01:19:05,050 salah satu cara yang baik untuk melakukan itu - 1674 01:19:05,050 --> 01:19:06,780 yang baik meskipun untuk melakukan itu? 1675 01:19:06,780 --> 01:19:11,950 Jadi kita tidak perlu terus-menerus mencari sekitar file kita untuk menempatkan hal-hal. 1676 01:19:11,950 --> 01:19:14,360 >> Pertanyaan itu mungkin tidak memiliki masuk akal, tapi saya pikir sebuah 1677 01:19:14,360 --> 01:19:15,800 menjawab itu akan membantu. 1678 01:19:15,800 --> 01:19:17,210 >> SISWA 82: Buat array? 1679 01:19:17,210 --> 01:19:20,090 >> JASON Hirschhorn: Jadi mari kita berpikir setiap file sebagai baris. 1680 01:19:20,090 --> 01:19:22,550 Mari kita berpikir dalam hal baris. 1681 01:19:22,550 --> 01:19:26,670 Jika kita memiliki baris pertama kami dari kecil kami gambar, kita dapat membuat baris yang 1682 01:19:26,670 --> 01:19:30,640 ke baris besar dari gambar besar, dan kemudian meniru baris yang bagaimanapun 1683 01:19:30,640 --> 01:19:34,250 berkali-kali perlu direplikasi, daripada pergi pixel by pixel, 1684 01:19:34,250 --> 01:19:37,260 yang akan membingungkan ketika menangani file. 1685 01:19:37,260 --> 01:19:38,730 >> Karena jika kita punya - 1686 01:19:38,730 --> 01:19:41,260 Saya kehabisan ruang. 1687 01:19:41,260 --> 01:19:46,490 Jika ini adalah file kita, dan kita mendapati bahwa satu pixel di sana, dan kami ingin meletakkannya 1688 01:19:46,490 --> 01:19:49,840 di sana, kami masih memiliki beberapa hal yang perlu untuk pergi ke sana ketika kita berada 1689 01:19:49,840 --> 01:19:51,450 menulis dan membuat file baru - 1690 01:19:51,450 --> 01:19:53,250 file kita yang dua kali lebih besar. 1691 01:19:53,250 --> 01:19:56,820 >> Tapi itu benar-benar keras dengan fungsi file untuk melewati sekitar untuk baris baru 1692 01:19:56,820 --> 01:20:00,260 seperti itu, dan kemudian kembali ke sini dan meletakkan segala sesuatu di sana. 1693 01:20:00,260 --> 01:20:04,500 Ini hampir mustahil untuk melakukan sesuatu seperti itu, kalau itu masuk akal. 1694 01:20:04,500 --> 01:20:10,180 Jadi jika kita berpikir dalam hal baris, kita bisa mengambil baris kami, dan kemudian meletakkannya - 1695 01:20:10,180 --> 01:20:11,720 meniru baris vertikal. 1696 01:20:11,720 --> 01:20:15,860 >> Dan itulah bagaimana kita berurusan dengan ukuran vertikal daripada horizontal. 1697 01:20:15,860 --> 01:20:18,810 Itu agak cepat, dan sedikit membingungkan. 1698 01:20:18,810 --> 01:20:22,375 Sayangnya waktu kita sudah habis. 1699 01:20:22,375 --> 01:20:27,340 Aku akan berdiri di luar bagi anda di sini yang memiliki pertanyaan tentang 1700 01:20:27,340 --> 01:20:30,500 masalah set, termasuk pulih. 1701 01:20:30,500 --> 01:20:32,320 >> Jadi mari kita menunda untuk saat ini. 1702 01:20:32,320 --> 01:20:34,480 Dan lagi, jika Anda memiliki pertanyaan, kita bisa chatting luar. 1703 01:20:34,480 --> 01:20:38,294