1 00:00:00,000 --> 00:00:05,300 2 00:00:05,300 --> 00:00:07,300 DOUG LLOYD: როგორც თქვენ დაიწყოს მუშაობის ფუნქციები, 3 00:00:07,300 --> 00:00:09,966 კიდევ ერთი რამ უნდა გახდეს მართლაც მნიშვნელოვანია იმის გაგება, 4 00:00:09,966 --> 00:00:12,380 რომელიც არის კონცეფცია ცვლადი ფარგლებს. 5 00:00:12,380 --> 00:00:14,490 ასე ფარგლებს არის დამახასიათებელი ცვლადი 6 00:00:14,490 --> 00:00:18,860 რომელიც განსაზღვრავს, რომლის ფუნქციები რომ ცვლადი შეიძლება ხელმისაწვდომი იყოს. 7 00:00:18,860 --> 00:00:24,595 >> არსებობს ორი ძირითადი scopes C, ადგილობრივი ცვლადები და გლობალური ცვლადები. 8 00:00:24,595 --> 00:00:27,830 ახლა, ადგილობრივი ცვლადები მხოლოდ ხელმისაწვდომი იყოს ფარგლებში ფუნქციები 9 00:00:27,830 --> 00:00:29,045 რომელშიც ისინი შეიქმნა. 10 00:00:29,045 --> 00:00:32,170 ისინი არ შეიძლება იქნეს ყოველი სხვა ფუნქცია, რომელიც არსებობს თქვენს პროგრამაში, 11 00:00:32,170 --> 00:00:34,184 მხოლოდ ფუნქცია რომლის ის შეიქმნა. 12 00:00:34,184 --> 00:00:36,350 გლობალური ცვლადები წლის მეორე მხრივ, შესაძლებელია 13 00:00:36,350 --> 00:00:37,719 ნებისმიერი ფუნქცია პროგრამა. 14 00:00:37,719 --> 00:00:40,260 და მიზეზი ის არის, იმიტომ, რომ ისინი არ შექმნილა შიგნით 15 00:00:40,260 --> 00:00:41,441 კონკრეტული ფუნქცია. 16 00:00:41,441 --> 00:00:43,690 ჩვენ ვაცხადებთ, მათ გარეთ ყველა ფუნქცია, რომელიც 17 00:00:43,690 --> 00:00:48,940 იმას ნიშნავს, რომ ყოველი ფუნქცია იცის, სადაც ეს არის და შეუძლია და მართვას. 18 00:00:48,940 --> 00:00:52,010 >> ჯერჯერობით, რა თქმა უნდა თქვენ საკმაოდ ბევრი უკვე მუშაობს მხოლოდ 19 00:00:52,010 --> 00:00:54,280 ადგილობრივი ცვლადები. 20 00:00:54,280 --> 00:00:58,320 აი, მაგალითად, ძალიან, ძალიან მარტივი მთავარი ფუნქცია და ძალიან მარტივი 21 00:00:58,320 --> 00:01:00,680 დამატებითი ფუნქცია, რომელიც ჩვენ იწერება. 22 00:01:00,680 --> 00:01:03,180 ამ შემთხვევაში, x, რომელიც მე მწვანეა მხოლოდ 23 00:01:03,180 --> 00:01:07,400 ხაზი გავუსვა რაიონი ან ფარგლებს, რომ ცვლადი, 24 00:01:07,400 --> 00:01:09,240 ადგილობრივი ფუნქცია სამჯერ. 25 00:01:09,240 --> 00:01:12,300 მთავარი ვერ ეხება x ყველა. 26 00:01:12,300 --> 00:01:14,259 ეს არ ვიცი რა არის. 27 00:01:14,259 --> 00:01:17,050 არც ერთი სხვა ფუნქცია, ფაქტობრივად, თუ ჩვენ ჰქონდა დამატებითი ფუნქციები აქ, 28 00:01:17,050 --> 00:01:19,360 შეიძლება მიმართოს x. 29 00:01:19,360 --> 00:01:23,520 >> ანალოგიურად, შედეგები, რომელიც მე ლურჯი, ადგილობრივი მხოლოდ ძირითადი. 30 00:01:23,520 --> 00:01:26,980 მხოლოდ ძირითადი იცის, რა ცვლადი შედეგი არის. 31 00:01:26,980 --> 00:01:30,010 სამჯერ ვერ გამოიყენებს. 32 00:01:30,010 --> 00:01:32,580 >> ახლა, როგორც აღვნიშნე, გლობალური ცვლადები არ არსებობს. 33 00:01:32,580 --> 00:01:35,575 თუ თქვენ აცხადებენ, რომ ცვლადი გარეთ ნებისმიერი ფუნქცია, 34 00:01:35,575 --> 00:01:38,290 ყველა ფუნქციების პროგრამას შეუძლია მიმართოს მას. 35 00:01:38,290 --> 00:01:44,010 ასე რომ, ამ შემთხვევაში, მე მონიშნულია მწვანე გლობალური ცვლადი დეკლარაცია. 36 00:01:44,010 --> 00:01:45,830 ამ შემთხვევაში, ცვლადი ცხადდება 37 00:01:45,830 --> 00:01:48,720 ეწოდება გლობალური, უბრალოდ ძალიან ნათელი შესახებ. 38 00:01:48,720 --> 00:01:49,720 ეს არის ტიპის float. 39 00:01:49,720 --> 00:01:52,940 და მე დაავალოს ეს ღირებულება 0,5050. 40 00:01:52,940 --> 00:01:58,080 >> თქვენ შეამჩნევთ, რომ მთავარ და სამჯერ, მე შეუძლია ეხება გლობალური. 41 00:01:58,080 --> 00:02:03,480 და სინამდვილეში, თუ მე გავლა პროგრამა როგორც მითითებულია, მთავარი, პირველი ზარები სამჯერ, 42 00:02:03,480 --> 00:02:10,440 სამმაგი მრავლდება გლობალური 3, რომელიც ადგენს მისი ღირებულება 1,5 რაღაც, 43 00:02:10,440 --> 00:02:16,080 1.51 ან რამე მაგდაგვარს და შემდეგ მთავარ ასევე ბეჭდავს out ღირებულება 44 00:02:16,080 --> 00:02:16,620 გლობალური. 45 00:02:16,620 --> 00:02:24,424 ასე რომ, მთავარი არ ამობეჭდოთ 0,5050, ეს ამობეჭდოთ გლობალური ჯერ 3, 1.51. 46 00:02:24,424 --> 00:02:27,340 ასე, რომ თქვენ მოხვდით ფრთხილად, როდესაც თქვენ მუშაობის გლობალური ცვლადები. 47 00:02:27,340 --> 00:02:30,260 მიუხედავად იმისა, რომ ისინი ძალიან მოქნილი მიმდინარეობს შეუძლია გაიაროს ინფორმაცია 48 00:02:30,260 --> 00:02:32,650 დაახლოებით ისე, რომ ყოველ ფუნქცია შეგიძლიათ გამოიყენოთ იგი, 49 00:02:32,650 --> 00:02:34,580 იგი ასევე შეიძლება ჰქონდეს საშიში შედეგები 50 00:02:34,580 --> 00:02:38,770 იმ შემთხვევაში, თუ ერთი ფუნქცია ცვლილებები ღირებულება ცვლადი 51 00:02:38,770 --> 00:02:42,360 სანამ ველოდებით, რომ ეს უნდა შეიცვალოს. 52 00:02:42,360 --> 00:02:44,200 >> რატომ ეს განსხვავება აქვს? 53 00:02:44,200 --> 00:02:48,070 რატომ აღელვებს თუ არა ზოგიერთი ცვლადის ადგილობრივი და სხვები არიან გლობალური? 54 00:02:48,070 --> 00:02:53,880 ისე, უმეტესწილად, ადგილობრივი ცვლადები დო ვართ რასაც მიერ მიღებულ ღირებულება 55 00:02:53,880 --> 00:02:56,087 როდესაც ჩვენ ფუნქცია ზარი. 56 00:02:56,087 --> 00:02:56,920 რას ნიშნავს ეს? 57 00:02:56,920 --> 00:03:00,880 >> ისე, როცა ცვლადი გავიდა მიერ ღირებულება, Callee, რომელიც 58 00:03:00,880 --> 00:03:04,350 არის კიდევ ერთი გზა ამბობდა ფუნქცია რომ იღებს ცვლადი, რომ 59 00:03:04,350 --> 00:03:08,465 იღებს გავიდა, როგორც შეყვანის, ის რეალურად არ მიიღებს, რომ ცვლადი თავად. 60 00:03:08,465 --> 00:03:12,490 იგი იღებს თავისი ასლი მუშაობა. 61 00:03:12,490 --> 00:03:14,350 ეს არის ძალიან მნიშვნელოვანი განსხვავება. 62 00:03:14,350 --> 00:03:18,250 დავინახეთ, მეორე წინ რომ გლობალური ცვლადები, 63 00:03:18,250 --> 00:03:23,240 თუ ჩვენ მანიპულირება გლობალური ცვლადი ერთი ფუნქცია, ეფექტი 64 00:03:23,240 --> 00:03:26,390 რომ ერთი ფუნქცია ახორციელებს გადის ყოველ მეორე ფუნქცია. 65 00:03:26,390 --> 00:03:28,920 >> მაგრამ ადგილობრივი ცვლადები, ეს არ არის ჭეშმარიტი. 66 00:03:28,920 --> 00:03:32,060 თითოეული ფუნქცია, როდესაც ის იღებს ცვლადები, როგორც შეყვანის 67 00:03:32,060 --> 00:03:36,367 ასლი იმ ცვლადების, არ ცვლადები თავს. 68 00:03:36,367 --> 00:03:37,825 რა არის გვერდითი ეფექტი, რომ? 69 00:03:37,825 --> 00:03:40,450 ეს ნიშნავს, რომ ცვლადი აბონენტის, ფუნქცია, რომელიც 70 00:03:40,450 --> 00:03:45,600 არის მიღების ფუნქცია ზარი, არის უცვლელი თუ არ override იგი. 71 00:03:45,600 --> 00:03:50,420 >> მაგალითად, ეს კოდი foo არ შეცვლილა. 72 00:03:50,420 --> 00:03:55,450 Int foo შეადგენს 4, დარეკეთ triple foo, შიგნით სამჯერ, 73 00:03:55,450 --> 00:03:58,850 ჩვენ ველით, რომ foo გვინდა მრავლდება 3 და დაბრუნდა, 74 00:03:58,850 --> 00:04:01,450 მაგრამ იქ რეალურად არ ახდენს. 75 00:04:01,450 --> 00:04:03,460 >> აქ, თუმცა, ძალიან დახვეწილი განსხვავება. 76 00:04:03,460 --> 00:04:06,520 ეს იმას აქვს ეფექტი ჩვენ გვინდა. 77 00:04:06,520 --> 00:04:07,730 მიგაჩნიათ თუ არა, რატომ? 78 00:04:07,730 --> 00:04:11,500 ჩვენ მნიშვნელოვანი foo მთავარ ამ დროს. 79 00:04:11,500 --> 00:04:16,899 >> ასე int foo შეადგენს 4, foo ტოლია სამმაგი foo, როდესაც ჩვენ, რომ ზარის, 80 00:04:16,899 --> 00:04:21,680 სამჯერ იღებს საკუთარი ასლი foo, საკუთარი ასლი 4. 81 00:04:21,680 --> 00:04:27,340 იგი აცხადებს, რომ დაბრუნდეს 4 ჯერ 3, ან რასაც ცვლადი იღებს გავიდა ჯერ 3. 82 00:04:27,340 --> 00:04:32,109 და მაშინ ჩვენ მივანიჭოთ დაბრუნების ღირებულება სამჯერ უნდა foo ერთხელ. 83 00:04:32,109 --> 00:04:33,650 ასე რომ, ეს რეალურად გადაწერა foo. 84 00:04:33,650 --> 00:04:35,816 ეს არის ერთადერთი გზა ამის გაკეთება ეს ადგილობრივი ცვლადი. 85 00:04:35,816 --> 00:04:38,120 ასე რომ, ახლა თუ დავუმატებთ კიდევ ხაზი კოდი აქ 86 00:04:38,120 --> 00:04:40,870 ბოლოს მთავარ ამობეჭდოთ ღირებულება foo, 87 00:04:40,870 --> 00:04:45,030 ეს საკითხი ფაქტობრივად ბეჭდვა 12. 88 00:04:45,030 --> 00:04:48,600 >> ცვლადი ფარგლებს ზოგადად არ არის ძალიან ბევრი პრობლემა 89 00:04:48,600 --> 00:04:51,190 თუ თქვენ დაარქვით ყველა თქვენი ცვლადები სხვადასხვა რამ. 90 00:04:51,190 --> 00:04:54,920 მაგრამ მას შეუძლია მიიღოს სახის nasty თუ იგივე ცვლადის სახელი 91 00:04:54,920 --> 00:04:58,820 როგორც ჩანს, მრავალი ფუნქციები, რომელიც მოხდება ბევრი. 92 00:04:58,820 --> 00:05:02,130 თუ თქვენ ოდესმე არ მუშაობენ რეალურ სამყაროში, სადაც 93 00:05:02,130 --> 00:05:06,080 ვმუშაობთ ერთობლივი პროგრამები და ადამიანები სხვადასხვა გუნდები 94 00:05:06,080 --> 00:05:11,000 ვმუშაობთ ერთად დაწერა იგივე პროგრამა ან იგივე კომპლექტი პროგრამები, 95 00:05:11,000 --> 00:05:13,900 ისინი ხშირად reuse ცვლადი სახელები, განსაკუთრებით საერთო პირობა 96 00:05:13,900 --> 00:05:18,020 ისევე როგორც x, y, i, j, და ასე შემდეგ. 97 00:05:18,020 --> 00:05:20,370 >> მაგრამ როდესაც ცვლადები ამავე სახელწოდების, ფარგლებს საკითხი 98 00:05:20,370 --> 00:05:23,080 შეიძლება კიდევ ცოტა უფრო რთული გარჩევის. 99 00:05:23,080 --> 00:05:26,790 მაგალითად, თქვენ იცით, რა იქნება დაბეჭდილი, 100 00:05:26,790 --> 00:05:30,190 ბოლოს ამ კონკრეტული პროგრამა? 101 00:05:30,190 --> 00:05:31,280 მიიღეთ წუთი. 102 00:05:31,280 --> 00:05:33,382 პაუზის ვიდეო და წაიკითხა ამ პროგრამის. 103 00:05:33,382 --> 00:05:35,590 თქვენ ხედავთ ზედა ჩვენ აქვს ფუნქცია დეკლარაცია 104 00:05:35,590 --> 00:05:37,350 ფუნქცია მოუწოდა იყოს. 105 00:05:37,350 --> 00:05:40,800 ეს ფუნქცია იღებს ერთი პარამეტრი, რიცხვი, რომელიც ჩვენ მოვუწოდებთ x. 106 00:05:40,800 --> 00:05:42,610 და ეს შედეგები რიცხვი. 107 00:05:42,610 --> 00:05:44,820 სწორედ დაბრუნების ტიპის დასაწყისში. 108 00:05:44,820 --> 00:05:48,140 >> მაშინ ჩვენ გვაქვს მთავარი, რამდენიმე ხაზები კოდი მთავარ, ბოლო რომლის 109 00:05:48,140 --> 00:05:49,250 ბეჭდვითი განცხადებაში. 110 00:05:49,250 --> 00:05:51,140 და მახსოვს, რომ კითხვა აქ. 111 00:05:51,140 --> 00:05:54,240 რა არის რეალურად იქნება ნაბეჭდი ბოლოს ეს ფუნქცია? 112 00:05:54,240 --> 00:05:58,110 და მაშინ ჩვენ რეალურად აქვს განმარტება წუთობრივი ქვემოთ. 113 00:05:58,110 --> 00:06:01,760 >> ასე რომ, ერთი წუთით, ნაბიჯ მეშვეობით კოდი, კვალი რამ. 114 00:06:01,760 --> 00:06:08,100 იცით, რა დაიბეჭდება ბოლოს ამ კონკრეტული პროგრამა? 115 00:06:08,100 --> 00:06:08,600 >> ყველა უფლება. 116 00:06:08,600 --> 00:06:11,433 იმედია, თქვენ გადაღებული რამდენიმე წამში ცდილობენ და გარჩევის ეს ერთი. 117 00:06:11,433 --> 00:06:13,370 მოდით ერთად. 118 00:06:13,370 --> 00:06:16,022 >> ასე რომ, მე გადახაზა ნამატი მიერ დეკლარაციის ზედა არსებობს. 119 00:06:16,022 --> 00:06:17,230 ეს იყო ერთგვარი განადგურების. 120 00:06:17,230 --> 00:06:18,570 ეს არ არის საკუთარი ცვლადი. 121 00:06:18,570 --> 00:06:19,879 მას არ აქვს თავისი ფარგლები. 122 00:06:19,879 --> 00:06:21,920 ეს მხოლოდ ფუნქცია დეკლარაცია, ასე მიზნებისათვის 123 00:06:21,920 --> 00:06:24,330 ცდილობს გარჩევის, თუ რა არის ხდება ამ პროგრამაში, 124 00:06:24,330 --> 00:06:26,660 ჩვენ შეიძლება ასევე მხოლოდ თავიდან აცილება. 125 00:06:26,660 --> 00:06:29,560 >> ახლა ჩვენ გვაქვს ამ შემთხვევაში, მიზეზი ეს პრობლემა არის სახიფათო 126 00:06:29,560 --> 00:06:34,030 იმიტომ, რომ ჩვენ გვაქვს ადგილობრივი ცვლადები ორივე ძირითადი და ნამატი, რომელთაგან თითოეული 127 00:06:34,030 --> 00:06:35,090 ეწოდება x. 128 00:06:35,090 --> 00:06:39,830 და რა თქმა უნდა არსი ეს საკითხი ცდილობს, რომ მიხვდე, რომელიც x შეიცვლება 129 00:06:39,830 --> 00:06:41,890 და როგორ უნდა შეიცვალოს. 130 00:06:41,890 --> 00:06:46,900 ასე რომ, მე ფერადი ყველა ინსტანციის of x, რომ ადგილობრივი მთავარ წითელი. 131 00:06:46,900 --> 00:06:52,040 და მე ფერადი ყველა ინსტანციის x, რომ ადგილობრივი ნამატი ლურჯი. 132 00:06:52,040 --> 00:06:55,220 >> ცნობა, რომ მესამე ხაზი მთავარი, y ტოლია ნამატი 133 00:06:55,220 --> 00:07:00,800 x, რომ ნამატი არ მიმდინარეობს გავიდა ძირითად x, ან წითელი x. 134 00:07:00,800 --> 00:07:03,320 ეს არც გავიდა მას ასლი. 135 00:07:03,320 --> 00:07:06,987 და ეს მხოლოდ იმუშავებს რომ ასლი, ლურჯი x. 136 00:07:06,987 --> 00:07:08,820 თუ თქვენ მათემატიკურად დახრილი, თქვენ შეიძლება 137 00:07:08,820 --> 00:07:14,230 ამის ნაცვლად ფიქრობდა, როგორც x sub მ ძირითადი და x sub მე იყოს. 138 00:07:14,230 --> 00:07:15,700 მაგრამ ეს იმავე იდეას. 139 00:07:15,700 --> 00:07:18,999 x sub m, ან წითელი x მიერ წინა slide, 140 00:07:18,999 --> 00:07:21,790 არიან ცვლადები, რომლებიც local-- არის ინსტანციის x უფრო, რომ 141 00:07:21,790 --> 00:07:26,900 არის ადგილობრივი მთავარ, და x sub i, ან ლურჯი ცვლადები წინა slide, 142 00:07:26,900 --> 00:07:30,760 არის შემთხვევები, x, რომ არიან ადგილობრივი ნამატი. 143 00:07:30,760 --> 00:07:36,220 >> ასე რომ, იყავით შეუძლია გაერკვნენ, თუ რა ამ ფუნქციის დაბეჭდილი ბოლოს? 144 00:07:36,220 --> 00:07:39,420 მე Doug Lloyd, და ეს არის CS50. 145 00:07:39,420 --> 00:07:41,542