1 00:00:00,000 --> 00:00:00,340 2 00:00:00,340 --> 00:00:01,960 >> SPEAKER 1: Mari kita sekarang memperbaiki bahwa program terakhir. 3 00:00:01,960 --> 00:00:04,920 Dan kali ini, mari kita secara eksplisit mengalokasikan beberapa memori di mana 4 00:00:04,920 --> 00:00:06,550 input pengguna akan disimpan. 5 00:00:06,550 --> 00:00:09,600 Untuk melakukannya, mari kita mengasah dalam pada itu pertama baris kode di mana kita menyatakan s 6 00:00:09,600 --> 00:00:11,590 sebelumnya menjadi bintang arang. 7 00:00:11,590 --> 00:00:14,210 Kali ini, mari kita re-declare sebagai berikut - 8 00:00:14,210 --> 00:00:19,380 char s bracket 16, misalnya, braket dekat. 9 00:00:19,380 --> 00:00:23,690 >> Dengan kata lain, mari kita menyatakan untuk tidak lagi menjadi alamat dari karakter, 10 00:00:23,690 --> 00:00:26,610 melainkan sebuah array dari 16 karakter. 11 00:00:26,610 --> 00:00:30,295 Dengan cara ini, pengguna dapat mengetikkan sampai 15 karakter dan masih meninggalkan ruang untuk 12 00:00:30,295 --> 00:00:31,570 terminator null. 13 00:00:31,570 --> 00:00:35,870 Mari kita lanjutkan untuk Simpan, Kompilasi, dan Jalankan program ini. 14 00:00:35,870 --> 00:00:40,770 Membuat scanf2 dot slash scanf2. 15 00:00:40,770 --> 00:00:45,100 Mari kita sekarang ketik string seperti halo, dan kami mengucapkan terima kasih untuk hello. 16 00:00:45,100 --> 00:00:46,440 >> Sekarang, masih ada masalah. 17 00:00:46,440 --> 00:00:50,140 Saya hanya mengetik halo, yang hanya lima karakter, ditambah 1 untuk null 18 00:00:50,140 --> 00:00:50,445 terminator. 19 00:00:50,445 --> 00:00:53,610 Ini meninggalkan kita dengan hanya kebutuhan untuk enam byte. 20 00:00:53,610 --> 00:00:56,740 >> Tapi sayangnya, kita hanya dialokasikan 16 secara total. 21 00:00:56,740 --> 00:01:01,305 Jadi, jika pengguna benar-benar tipe di 16 karakter, atau 17, atau beberapa ratus 22 00:01:01,305 --> 00:01:04,410 karakter, kita masih tidak akan memiliki cukup ruang di memori untuk 23 00:01:04,410 --> 00:01:05,400 masukan pengguna. 24 00:01:05,400 --> 00:01:07,750 Dan pada kenyataannya, ini adalah apa yang membuat mendapatkan masukan pengguna sehingga 25 00:01:07,750 --> 00:01:08,940 sulit pada umumnya. 26 00:01:08,940 --> 00:01:12,270 Dan memang, ini adalah mengapa kita menerapkan get fungsi string dalam pertama 27 00:01:12,270 --> 00:01:13,900 Tempat di perpustakaan CS50 - 28 00:01:13,900 --> 00:01:16,900 untuk mengetahui bagaimana menangani mereka situasi dimana jenis pengguna dalam 29 00:01:16,900 --> 00:01:19,710 lebih karakter daripada kita awalnya diantisipasi. 30 00:01:19,710 --> 00:01:21,750 >> Terus terang, tanpa benar-benar menulis ulang program ini, 31 00:01:21,750 --> 00:01:23,290 tidak ada solusi yang bersih. 32 00:01:23,290 --> 00:01:26,970 Sebaliknya, apa yang kita harus lakukan adalah mendapatkan karakter dari pengguna satu per satu 33 00:01:26,970 --> 00:01:28,860 waktu, lagi dan lagi. 34 00:01:28,860 --> 00:01:32,510 Dan pada setiap titik jika kita menyadari kita dari memori, kita harus di 35 00:01:32,510 --> 00:01:36,450 saat itu kembali dan realokasi beberapa memori lebih, salin pengguna 36 00:01:36,450 --> 00:01:39,400 masukan sebelumnya dari potongan pertama kami memori ke yang baru, 37 00:01:39,400 --> 00:01:40,810 sepotong lebih besar dari memori. 38 00:01:40,810 --> 00:01:44,610 Dan kemudian mengulangi proses itu lagi dan lagi sampai pengguna dilakukan memberikan 39 00:01:44,610 --> 00:01:45,860 masukan nya. 40 00:01:45,860 --> 00:01:48,246