1 00:00:07,260 --> 00:00:09,180 [Powered by Google Translate] Ας μιλήσουμε για structs. 2 00:00:09,180 --> 00:00:12,130 Structs μας παρέχει έναν τρόπο για να συγκεντρώσει ένα μάτσο μεταβλητές μαζί 3 00:00:12,130 --> 00:00:14,350 σε ένα ωραίο πακέτο. 4 00:00:14,350 --> 00:00:17,020 Είναι ίσως πιο εύκολο να δούμε ένα παράδειγμα αμέσως, 5 00:00:17,020 --> 00:00:20,030 έτσι λέμε struct, 6 00:00:20,030 --> 00:00:23,340 τότε το άνοιγμα άγκιστρο, 7 00:00:23,340 --> 00:00:26,630 και σε αυτό το struct, θα έχουμε έναν int ηλικία, 8 00:00:28,920 --> 00:00:31,350 ένα char * name, 9 00:00:31,350 --> 00:00:34,670 και αυτό είναι αυτό. 10 00:00:37,350 --> 00:00:40,650 Μπορεί να φαίνεται παράξενο με ένα ερωτηματικό μετά από ένα στήριγμα σγουρά, 11 00:00:40,650 --> 00:00:43,620 αλλά είναι στην πραγματικότητα αναγκαία structs. 12 00:00:43,620 --> 00:00:46,270 Οποιαδήποτε έγκυρη τύπος μπορεί να πάει στον ορισμό struct. 13 00:00:46,270 --> 00:00:49,530 Εδώ, έχουμε χρησιμοποιήσει μια int και char *, 14 00:00:49,530 --> 00:00:52,610 αλλά μπορείτε επίσης να χρησιμοποιήσετε μια σειρά, ας πούμε, 100 στοιχεία 15 00:00:52,610 --> 00:00:54,910 ή ακόμα και ένα άλλο struct. 16 00:00:54,910 --> 00:00:56,960 Όταν χρησιμοποιείτε structs σε C, 17 00:00:56,960 --> 00:00:58,430 είστε δημιουργία νέων τύπων 18 00:00:58,430 --> 00:01:00,860 από μια συλλογή των άλλων τύπων. 19 00:01:00,860 --> 00:01:02,620 Εδώ, κάνουμε ένα νέο τύπο 20 00:01:02,620 --> 00:01:05,060 από έναν ακέραιο και ένα char *. 21 00:01:05,060 --> 00:01:07,400 Όπως θα δούμε αργότερα, ένας τύπος struct 22 00:01:07,400 --> 00:01:10,700 είναι σε πολλούς τρόπους που ισοδυναμεί με οποιονδήποτε άλλο τύπο που έχετε συνηθίσει. 23 00:01:10,700 --> 00:01:13,310 Συνήθως, θα πρέπει να συγκρίνει τον τρόπο με έναν τύπο struct 24 00:01:13,310 --> 00:01:15,790 είναι παρόμοιο με ένα ακέραιο τύπο. 25 00:01:15,790 --> 00:01:18,520 Ενώ ο κώδικας που γράψαμε είναι έγκυρη C, 26 00:01:18,520 --> 00:01:20,320 δεν είναι πολύ χρήσιμο, 27 00:01:20,320 --> 00:01:22,340 κλαγγή και θα μας δώσει μια προειδοποίηση. 28 00:01:22,340 --> 00:01:24,970 Θυμηθείτε πώς και structs του είναι παρόμοια; 29 00:01:24,970 --> 00:01:26,710 Λοιπόν, βασικά ακριβώς είπε 30 00:01:27,840 --> 00:01:30,060 int, 31 00:01:30,060 --> 00:01:33,140 η οποία δεν είναι μια πολύ χρήσιμη γραμμή. 32 00:01:33,140 --> 00:01:35,760 Ας δηλώσει στην πραγματικότητα μια μεταβλητή αυτού του τύπου 33 00:01:35,760 --> 00:01:38,760 δίνοντας ένα όνομα πριν το ελληνικό ερωτηματικό. 34 00:01:42,170 --> 00:01:45,000 Θα καλέσετε τη μεταβλητή μαθητή. 35 00:01:48,190 --> 00:01:51,350 Τώρα έχουμε δηλώσει μια μεταβλητή που ονομάζεται φοιτητής 36 00:01:51,350 --> 00:01:53,980 με τον τύπο δίδεται από τον struct. 37 00:01:53,980 --> 00:01:56,730 Πώς θα φτάσουμε στις μεταβλητές μέσα στο struct; 38 00:01:56,730 --> 00:01:59,040 Τεχνικά, τα ονόματα για αυτές τις μεταβλητές 39 00:01:59,040 --> 00:02:01,070 είναι μέλη. 40 00:02:01,070 --> 00:02:04,000 Για την πρόσβαση σε οποιοδήποτε συγκεκριμένο μέλος σε ένα struct μαθητή, 41 00:02:04,000 --> 00:02:06,440 την προσάρτηση μια τελεία στο όνομα της μεταβλητής, 42 00:02:06,440 --> 00:02:08,860 ακολουθούμενο από το όνομα του μέλους που θέλετε. 43 00:02:08,860 --> 00:02:11,690 Μέχρι εδώ, τα έγκυρα μόνο 2 δυνατότητες 44 00:02:11,690 --> 00:02:17,760 είναι student.age 45 00:02:17,760 --> 00:02:24,460 και student.name. 46 00:02:24,460 --> 00:02:26,820 Και μπορούμε να κάνουμε κάτι σαν 47 00:02:26,820 --> 00:02:30,320 student.age = 12 48 00:02:30,320 --> 00:02:39,310 και student.name = μαθητή. 49 00:02:39,310 --> 00:02:42,580 Τώρα τι γίνεται αν θέλουμε να κάνουμε ένα δεύτερο μαθητή; 50 00:02:42,580 --> 00:02:44,760 Μπορείτε να σκεφτείτε να αντιγράψετε και να επικολλήσετε αυτές τις γραμμές 51 00:02:44,760 --> 00:02:48,110 και να αλλάξετε μαθητή σε μαθητή 2 ή κάτι, 52 00:02:48,110 --> 00:02:50,090 και ότι θα λειτουργήσει, 53 00:02:50,090 --> 00:02:52,670 αλλά τεχνικά, φοιτητών και σπουδαστών 2 54 00:02:52,670 --> 00:02:54,540 δεν έχουν τον ίδιο τύπο. 55 00:02:54,540 --> 00:02:56,940 Δείτε, δεν θα είστε σε θέση να τους τοποθετεί σε ένα από το άλλο. 56 00:02:56,940 --> 00:02:58,560 Αυτό συμβαίνει επειδή, μέχρι στιγμής, 57 00:02:58,560 --> 00:03:00,950 struct σας ήταν ανώνυμο. 58 00:03:00,950 --> 00:03:02,290 Πρέπει να δώσετε ένα όνομα. 59 00:03:02,290 --> 00:03:04,420 Για να το κάνετε αυτό, εισάγετε το όνομα του struct 60 00:03:04,420 --> 00:03:06,950 μετά τη λέξη struct. 61 00:03:09,440 --> 00:03:11,170 φοιτητής, 62 00:03:11,170 --> 00:03:14,680 ακολουθούμενο από τον ορισμό. 63 00:03:16,500 --> 00:03:18,940 Μπορούμε ακόμη να δηλώσει αμέσως μια μεταβλητή του τύπου 64 00:03:18,940 --> 00:03:21,570 struct φοιτητής, όπως κάναμε πριν. 65 00:03:24,320 --> 00:03:28,360 Θα το ονομάσουμε S1 66 00:03:28,590 --> 00:03:30,760 Δίνοντας το struct ένα όνομα, 67 00:03:30,760 --> 00:03:33,050 μπορούμε να χρησιμοποιήσουμε τώρα φοιτητής struct 68 00:03:33,050 --> 00:03:36,950 με σχεδόν τον ίδιο ακριβώς τρόπο που θα χρησιμοποιήσει int. 69 00:03:36,950 --> 00:03:39,580 Έτσι, μπορούμε να δηλώσουμε μια μεταβλητή τύπου struct μαθητή, 70 00:03:39,580 --> 00:03:42,360 σαν 71 00:03:42,360 --> 00:03:49,500 struct φοιτητής S2. 72 00:03:51,020 --> 00:03:55,130 Όπως και συστοιχίες, structs παρέχουν μια σύνταξη προετοιμασίας συντόμευσης, 73 00:03:55,130 --> 00:03:58,670 έτσι μπορούμε να πούμε, struct φοιτητής S2 74 00:03:58,670 --> 00:04:01,420 ισούται 75 00:04:01,420 --> 00:04:06,040 αριστερό άγκιστρο 3, S2. 76 00:04:09,210 --> 00:04:12,600 Εδώ, S2.age θα είναι 3, 77 00:04:12,600 --> 00:04:15,910 S2.name και θα επισημάνει στο S2. 78 00:04:15,910 --> 00:04:19,149 Σκεφτείτε όλα τα πράγματα που μπορείτε να κάνετε με ένα τύπου int 79 00:04:19,149 --> 00:04:22,460 και τα περισσότερα από αυτά που μπορείτε να κάνετε με έναν τύπο φοιτητή struct. 80 00:04:22,460 --> 00:04:26,060 Μπορούμε να χρησιμοποιήσουμε έναν σπουδαστή struct ως ένα είδος μιας παραμέτρου λειτουργίας. 81 00:04:26,060 --> 00:04:28,790 Μπορούμε να χρησιμοποιήσουμε φοιτητής struct μέσα από ένα νέο struct. 82 00:04:28,790 --> 00:04:31,010 Μπορούμε να έχουμε ένα δείκτη σε struct μαθητή. 83 00:04:31,010 --> 00:04:33,540 Μπορούμε να κάνουμε το μέγεθος του σπουδαστή struct. 84 00:04:33,540 --> 00:04:35,510 Struct φοιτητής είναι ένας τύπος 85 00:04:35,510 --> 00:04:38,030 ακριβώς όπως int είναι ένας τύπος. 86 00:04:38,030 --> 00:04:40,540 Μπορούμε επίσης να εκχωρήσετε το S1 στο S2 87 00:04:40,540 --> 00:04:43,760 δεδομένου ότι και οι δύο είναι του ίδιου τύπου, ώστε να μπορούμε να κάνουμε 88 00:04:44,390 --> 00:04:47,540 S1 = S2. 89 00:04:47,540 --> 00:04:50,430 Τι θα συμβεί αν κάνουμε 90 00:04:50,430 --> 00:04:55,300 S1.age = 10; 91 00:04:56,340 --> 00:04:58,880 Μήπως S2 αλλαγή σε όλα; 92 00:04:58,880 --> 00:05:02,800 Και πάλι, σκεφτείτε τα structs όπως ακριβώς τακτική ακέραιοι. 93 00:05:02,800 --> 00:05:05,590 Αν αντιστοιχίσετε κάποια int X Y σε κάποιο int, 94 00:05:05,590 --> 00:05:08,970 όπως Χ = Υ 95 00:05:08,970 --> 00:05:10,850 και στη συνέχεια, αλλάξτε το Χ, 96 00:05:10,850 --> 00:05:14,230 όπως στο Χ + +, 97 00:05:14,230 --> 00:05:17,020 Υ έχει αλλάξει καθόλου; 98 00:05:17,020 --> 00:05:20,980 Υ δεν αλλάζει εδώ, και έτσι ούτε και S2 παραπάνω. 99 00:05:20,980 --> 00:05:24,120 S2.age εξακολουθεί να είναι 3. 100 00:05:24,120 --> 00:05:27,350 Αλλά σημειώστε ότι κατά την ανάθεση ενός struct στο άλλο, 101 00:05:27,350 --> 00:05:30,300 όλοι οι δείκτες εξακολουθούν να δείχνουν το ίδιο πράγμα, 102 00:05:30,300 --> 00:05:32,260 δεδομένου ότι μόλις αντιγράψατε. 103 00:05:32,260 --> 00:05:34,300 Αν δεν θέλετε οι δείκτες να μοιραστούν, 104 00:05:34,300 --> 00:05:36,100 θα πρέπει να χειριστεί το χέρι ότι, 105 00:05:36,100 --> 00:05:39,780 ίσως με malicking ένα μπλοκ μνήμης για έναν από τους δείκτες για να υποδεικνύουν 106 00:05:39,780 --> 00:05:42,120 και την αντιγραφή των δεδομένων πάνω. 107 00:05:42,120 --> 00:05:45,540 Θα μπορούσε να είναι ενοχλητικό να πρέπει να γράψετε φοιτητής struct παντού. 108 00:05:45,540 --> 00:05:48,730 Χρησιμοποιώντας ένα def τύπου, μπορούμε να κάνουμε 109 00:05:51,630 --> 00:05:55,850 τύπου def 110 00:05:55,850 --> 00:05:58,830 struct 111 00:05:58,830 --> 00:06:01,270 και θα καλέσουμε το μαθητή. 112 00:06:05,620 --> 00:06:08,360 Τώρα, μπορούμε να χρησιμοποιήσουμε φοιτητής παντού 113 00:06:08,360 --> 00:06:11,090 που χρησιμοποιείται για να χρησιμοποιήσει φοιτητής struct. 114 00:06:11,090 --> 00:06:13,410 Αυτό def τύπος είναι μια ανώνυμη struct 115 00:06:13,410 --> 00:06:15,750 και καλεί το μαθητή. 116 00:06:15,750 --> 00:06:18,220 Αλλά αν συνεχίσουμε επίσης το αναγνωριστικό φοιτητής 117 00:06:18,220 --> 00:06:22,380 δίπλα στο struct λέξη, όπως και σε typedef struct σπουδαστή, 118 00:06:27,670 --> 00:06:31,590 θα μπορούσαμε να χρησιμοποιήσουμε τόσο μαθητή και σπουδαστή struct εναλλακτικά τώρα. 119 00:06:31,590 --> 00:06:34,060 Δεν χρειάζεται καν να έχουν το ίδιο όνομα. 120 00:06:34,060 --> 00:06:36,710 Θα μπορούσαμε να πληκτρολογήσετε def φοιτητής struct στον Bob 121 00:06:36,710 --> 00:06:38,950 struct και τότε φοιτητής και ο Bob 122 00:06:38,950 --> 00:06:41,270 θα είναι εναλλάξιμα είδη. 123 00:06:41,270 --> 00:06:44,050 Ανεξάρτητα από τον τύπο του def, 124 00:06:44,050 --> 00:06:46,750 χρειαζόμαστε το αναγνωριστικό δίπλα στο struct 125 00:06:46,750 --> 00:06:48,250 αν ο ορισμός του struct 126 00:06:48,250 --> 00:06:50,450 είναι αναδρομική. 127 00:06:50,450 --> 00:06:52,620 Για παράδειγμα, 128 00:06:52,620 --> 00:06:56,140 def τύπου struct node 129 00:06:56,140 --> 00:07:01,200 και θα ορίζεται ως int val 130 00:07:01,200 --> 00:07:05,420 και θα έχουν ένα δείκτη που δείχνει σε άλλο κόμβο struct., 131 00:07:05,420 --> 00:07:09,490 όπως σε struct node * επόμενο. 132 00:07:09,490 --> 00:07:13,670 Και τότε εμείς θα αποκαλούμε κόμβο. 133 00:07:15,490 --> 00:07:18,020 Αυτό το struct είναι αναδρομική, 134 00:07:18,020 --> 00:07:21,450 δεδομένου ότι ο ορισμός του κόμβου struct περιέχει εντός αυτού 135 00:07:21,450 --> 00:07:24,200 ένα δείκτη σε struct node. 136 00:07:24,200 --> 00:07:27,740 Σημειώστε ότι πρέπει να πούμε struct node * επόμενο 137 00:07:27,740 --> 00:07:30,690 εσωτερικό του ορισμού του κόμβου struct, 138 00:07:30,690 --> 00:07:33,620 δεδομένου ότι ο τύπος def δεν έχει τελειώσει ακόμη για να μας επιτρέψει να απλοποιήσει αυτό 139 00:07:33,620 --> 00:07:36,210 ακριβώς δίπλα κόμβο *. 140 00:07:36,210 --> 00:07:39,260 Θα μάθετε περισσότερα σχετικά με structs παρόμοιο με αυτό 141 00:07:39,260 --> 00:07:41,750 όταν ασχολείται με συνδεδεμένες λίστες και δέντρα. 142 00:07:41,750 --> 00:07:44,130 Τι γίνεται με structs σε λειτουργία; 143 00:07:44,130 --> 00:07:46,800 Αυτό είναι επίσης απολύτως έγκυρη. 144 00:07:46,800 --> 00:07:49,430 Θα μπορούσαμε να έχουμε 145 00:07:49,430 --> 00:07:53,630 ακυρώσουν την λειτουργία 146 00:07:53,630 --> 00:07:55,930 η οποία λαμβάνει ως επιχείρημα, 147 00:07:55,930 --> 00:07:59,590 φοιτητής s 148 00:07:59,590 --> 00:08:02,790 και κάνει κάτι με αυτό το μαθητή. 149 00:08:05,270 --> 00:08:08,450 Και τότε μπορούμε να το περάσει ως φοιτητής struct όπως έτσι. 150 00:08:08,450 --> 00:08:12,850 Func του S1 από πριν. 151 00:08:12,850 --> 00:08:15,230 Η struct συμπεριφέρεται 152 00:08:15,230 --> 00:08:18,460 ακριβώς όπως ένας ακέραιος θα όταν περάσει σε μια λειτουργία. 153 00:08:18,460 --> 00:08:21,510 Func λαμβάνει ένα αντίγραφο του S1 154 00:08:21,510 --> 00:08:23,690 και έτσι δεν μπορεί να τροποποιήσει S1? 155 00:08:23,690 --> 00:08:27,110 Αντίθετα, μόνο το αντίγραφο του αυτό που είναι αποθηκευμένο στο S. 156 00:08:27,110 --> 00:08:30,010 Αν θέλετε η λειτουργία να είναι σε θέση να τροποποιήσει S1, 157 00:08:30,010 --> 00:08:33,000 λειτουργία θα πρέπει να λάβει φοιτητής * S, 158 00:08:33,000 --> 00:08:36,570 και θα πρέπει να περάσει από τη διεύθυνση S1, όπως έτσι. 159 00:08:37,549 --> 00:08:41,100 Φοιτητής * S, λειτουργία & S1. 160 00:08:41,100 --> 00:08:44,760 Υπάρχει άλλος ένας λόγος για να περάσει από τη διεύθυνση εδώ. 161 00:08:44,760 --> 00:08:48,030 Τι θα συμβεί αν struct μας περιείχε 100 πεδία; 162 00:08:48,030 --> 00:08:51,250 Κάθε χρόνο περνάμε ένα μαθητή να λει, 163 00:08:51,250 --> 00:08:55,770 το πρόγραμμά μας πρέπει να αντιγράψει όλα αυτά τα 100 γήπεδα σε S επιχείρημα λειτουργία του, 164 00:08:55,770 --> 00:08:59,320 ακόμη και αν δεν χρησιμοποιεί τη συντριπτική πλειοψηφία τους. 165 00:08:59,320 --> 00:09:02,700 Έτσι, ακόμη και αν δεν λει το σχέδιο για την τροποποίηση του μαθητή, 166 00:09:02,700 --> 00:09:05,170 αν μπορεί ακόμα να είναι πολύτιμη για να περάσει από τη διεύθυνση. 167 00:09:05,170 --> 00:09:08,990 Εντάξει, τι γίνεται αν θέλουμε να δημιουργήσουμε ένα δείκτη σε struct; 168 00:09:08,990 --> 00:09:11,130 Θα μπορούσαμε να κάνουμε κάτι σαν 169 00:09:11,130 --> 00:09:17,580 * S φοιτητής 170 00:09:17,580 --> 00:09:20,980 ισούται με malloc 171 00:09:20,980 --> 00:09:26,600 μέγεθος του μαθητή. 172 00:09:30,450 --> 00:09:33,590 Παρατηρήστε ότι το μέγεθος του εξακολουθεί να εργάζεται εδώ. 173 00:09:33,590 --> 00:09:37,260 Επομένως, πώς θα έχουν πρόσβαση τώρα το μέλος ηλικία 174 00:09:37,260 --> 00:09:39,640 του μπλοκ που να επισημαίνει S; 175 00:09:39,640 --> 00:09:42,300 Μπορεί να πρώτα να σκεφτούμε να κάνουμε 176 00:09:42,300 --> 00:09:47,970 * S.age = 4, 177 00:09:47,970 --> 00:09:50,220 αλλά αυτό δεν θα εργάζονται αρκετά. 178 00:09:50,220 --> 00:09:52,940 Δεδομένου ότι αυτό θα είναι πραγματικά να ερμηνευθεί ως 179 00:09:52,940 --> 00:09:57,740 * S.age σε παρενθέσεις = 4, 180 00:09:57,740 --> 00:10:00,160 η οποία δεν θα είναι καν σύνταξη, 181 00:10:00,160 --> 00:10:03,600 από S δεν είναι ένα struct ή μάλλον ένας δείκτης σε μια struct, 182 00:10:03,600 --> 00:10:06,270 και έτσι η τελεία δεν θα λειτουργήσει εδώ. 183 00:10:06,270 --> 00:10:08,860 Θα μπορούσαμε να κάνουμε 184 00:10:08,860 --> 00:10:13,760 (*, S). Ηλικία = 4 185 00:10:13,760 --> 00:10:16,790 αλλά οι παρενθέσεις μπορούν να πάρουν ενοχλητικό και σύγχυση. 186 00:10:16,790 --> 00:10:19,880 Ευτυχώς, έχουμε ένα ειδικό φορέα βέλος 187 00:10:19,880 --> 00:10:22,350 που μοιάζει 188 00:10:22,350 --> 00:10:28,860 S-> ηλικία = 4. 189 00:10:28,860 --> 00:10:31,600 Αυτές οι 2 τρόποι αναφορά ηλικία 190 00:10:31,600 --> 00:10:33,270 είναι ισοδύναμες 191 00:10:33,270 --> 00:10:36,870 και δεν πρέπει ποτέ πραγματικά τον χειριστή βέλος, 192 00:10:36,870 --> 00:10:39,300 αλλά αυτό κάνει τα πράγματα να φαίνονται πιο ωραία. 193 00:10:39,300 --> 00:10:43,050 Επειδή το S είναι ένας δείκτης για κάποια μπλοκ μνήμης που περιέχει το struct, 194 00:10:43,050 --> 00:10:47,820 μπορείτε να σκεφτείτε την ηλικία S> ως εξής το βέλος δείκτη 195 00:10:47,820 --> 00:10:50,250 και να αρπάξει την ηλικία μέλος. 196 00:10:50,250 --> 00:10:53,750 Έτσι, γιατί θα πρέπει να χρησιμοποιήσετε ποτέ structs; 197 00:10:53,750 --> 00:10:57,560 Είναι σίγουρα δυνατόν να ξεφύγει με μόνο τα πρωτόγονα ακέραιοι, 198 00:10:57,560 --> 00:10:59,050 χαρακτήρες, οι δείκτες και τα παρόμοια 199 00:10:59,050 --> 00:11:01,550 ότι έχουμε συνηθίσει να? 200 00:11:01,550 --> 00:11:03,340 αντί των S1 και S2 πριν, 201 00:11:03,340 --> 00:11:06,290 θα μπορούσαμε να είχαμε age1, age2, NAME1, NAME2 και 202 00:11:06,290 --> 00:11:09,120 όλα σε ξεχωριστές μεταβλητές. 203 00:11:09,120 --> 00:11:11,390 Αυτό είναι καλό, με μόνο 2 φοιτητές, 204 00:11:11,390 --> 00:11:13,310 αλλά τι θα γινόταν αν είχαμε 10 από αυτούς; 205 00:11:13,310 --> 00:11:15,540 Και τι θα γίνει αν αντί για μόνο 2 πεδία, 206 00:11:15,540 --> 00:11:17,720 η struct φοιτητής είχε 100 πεδία; 207 00:11:17,720 --> 00:11:21,240 ΣΔΣ, τα μαθήματα, το χρώμα των μαλλιών, το φύλο, και ούτω καθεξής. 208 00:11:21,240 --> 00:11:25,790 Αντί μόλις 10 structs, χρειαζόμαστε 1.000 ξεχωριστές μεταβλητές. 209 00:11:25,790 --> 00:11:28,360 Επίσης, σκεφτείτε μια λειτουργία 210 00:11:28,360 --> 00:11:32,270 που παίρνει αυτό το struct με 100 πεδία με μόνο επιχείρημα του 211 00:11:32,270 --> 00:11:34,350 και εκτυπώνει όλα τα πεδία. 212 00:11:34,350 --> 00:11:36,320 Αν δεν χρησιμοποιείτε ένα struct, 213 00:11:36,320 --> 00:11:38,540 κάθε φορά που λέμε αυτή τη λειτουργία, 214 00:11:38,540 --> 00:11:41,460 θα πρέπει να περάσει σε όλες τις μεταβλητές 100, 215 00:11:41,460 --> 00:11:44,430 και αν έχουμε 100 μεταβλητές για το μαθητή 1, 216 00:11:44,430 --> 00:11:47,020 και 100 μεταβλητές για φοιτητή 2, 217 00:11:47,020 --> 00:11:50,540 πρέπει να είμαστε σίγουροι ότι δεν περνούν τυχαία κάποιες μεταβλητές από φοιτητή 1 218 00:11:50,540 --> 00:11:52,910 και κάποιες μεταβλητές από το μαθητή 2. 219 00:11:52,910 --> 00:11:55,710 Είναι αδύνατο να κάνει αυτό το λάθος με ένα struct, 220 00:11:55,710 --> 00:11:59,010 δεδομένου ότι όλες οι μεταβλητές που περιέχονται 100 σε ένα ενιαίο πακέτο. 221 00:11:59,010 --> 00:12:02,050 Ακριβώς ένα ζευγάρι των τελικών σημειώσεις: 222 00:12:02,050 --> 00:12:04,870 Εάν έχετε κατανοήσει τα πάντα μέχρι αυτό το σημείο, μεγάλη. 223 00:12:04,870 --> 00:12:07,900 Το υπόλοιπο του βίντεο είναι μόνο για λόγους πληρότητας ». 224 00:12:07,900 --> 00:12:11,010 Επειδή structs μπορεί να κρατήσει οποιοδήποτε τύπο του δείκτη, 225 00:12:11,010 --> 00:12:14,220 μπορούν να κρατήσουν επίσης δείκτες λειτουργίας. 226 00:12:14,220 --> 00:12:17,040 Αν είστε εξοικειωμένοι με αντικειμενοστραφή προγραμματισμό, 227 00:12:17,040 --> 00:12:21,790 αυτό παρέχει έναν τρόπο για να χρησιμοποιήσετε το πρόγραμμα για να structs σε μια αντικειμενοστραφή στυλ. 228 00:12:21,790 --> 00:12:24,500 Περισσότερα για την λειτουργία δείκτες σε άλλη χρονική στιγμή. 229 00:12:24,500 --> 00:12:27,760 Επίσης, μερικές φορές μπορεί να έχουν 2 structs 230 00:12:27,760 --> 00:12:30,220 ορισμούς των οποίων εξαρτάται από το ένα στο άλλο. 231 00:12:30,220 --> 00:12:32,320 Για παράδειγμα, 232 00:12:32,320 --> 00:12:35,470 θα μπορούσαμε να έχουμε ένα struct, 233 00:12:35,470 --> 00:12:38,580 που ορίζεται ως 234 00:12:38,580 --> 00:12:41,910 ένα δείκτη σε struct Β, 235 00:12:41,910 --> 00:12:47,180 struct B * X, 236 00:12:47,180 --> 00:12:50,470 και τώρα μπορούμε να έχουμε ένα struct Β 237 00:12:53,890 --> 00:12:56,280 η οποία ορίζεται ως δείκτης 238 00:12:56,280 --> 00:12:59,180 σε ένα struct Α, 239 00:12:59,180 --> 00:13:03,640 Ένα struct * Y. 240 00:13:07,230 --> 00:13:09,060 Αλλά αυτό δεν θα καταρτίσει, 241 00:13:09,060 --> 00:13:14,110 από struct Β δεν υπάρχει κατά το χρόνο που struct Α που καταρτίζονται. 242 00:13:14,110 --> 00:13:17,600 Και αν έχουμε ανταλλάξει struct Α και Β struct, 243 00:13:17,600 --> 00:13:20,100 τότε είχαμε απλώς να μείνει με το ίδιο πρόβλημα? 244 00:13:20,100 --> 00:13:22,640 αυτή τη φορά, με ένα struct δεν υπάρχουν. 245 00:13:22,640 --> 00:13:24,720 Για να λυθεί αυτό, μπορούμε να γράψουμε 246 00:13:24,720 --> 00:13:29,290 struct Β? 247 00:13:29,290 --> 00:13:32,460 πριν στον ορισμό του Α. struct 248 00:13:32,460 --> 00:13:35,590 Αυτό ονομάζεται δήλωση προς τα εμπρός. 249 00:13:35,590 --> 00:13:38,590 Αυτό αφήνει μόνο ο compiler γνωρίζει ότι 250 00:13:38,590 --> 00:13:42,040 struct Β είναι ένας έγκυρος τύπος που θα οριστεί αργότερα πλήρως ή αλλού. 251 00:13:42,040 --> 00:13:45,980 Το όνομά μου είναι Rob Bowden, και αυτό είναι CS50. 252 00:13:45,980 --> 00:13:48,980 [CS50.TV]