פרופ' מוטי בן-ארי המחלקה להוראת המדעים מכון ויצמן למדע

Slides:



Advertisements
Similar presentations
ממיבחניםC שאלות ++.
Advertisements

תוכנה 1 סמסטר א ' תשע " ב תרגול מס ' 7 * מנשקים, דיאגרמות וביטים * לא בהכרח בסדר הזה.
מבוא למדעי המחשב לתעשייה וניהול
1 Formal Specifications for Complex Systems (236368) Tutorial #4 Refinement in Z: data refinement; operations refinement; their combinations.
האוניברסיטה העברית בירושלים
Map-Reduce Input: a collection of scientific articles on different topics, each marked with a field of science –Mathematics, Computer Science, Biology,
Pointers הרצאה קריטית. השאלות הפתוחות מה זה ה- & שמופיע ב scanf מדוע כשמעבירים מחרוזת ל scanf אין צורך ב & האם ניתן להכריז על מערך שגדלו אינו ידוע בתחילת.
היכרות עם אקסל 1. 2 נושאי המפגש היכרות עם אקסל – אלכסוני הקסם שימושים בהוראה: מחשבון סודי ופעילות לחנוכה שימושים נוספים: ממוצע.
תכנות מונחה עצמים Object Oriented Programming (OOP) אתגר מחזור ב'
מבוא למדעי המחשב תרגול 2 שעת קבלה : יום שני 11:00-12:00 דוא " ל :
מכון ויצמן למדע - שמוליק מתוך 8 חישוב מקבילי ומבוזר מה זה יחידה חמישית במדעי המחשב... n ענף מתקדם במדעי המחשב העוסק במערכות ממוחשבות מרובות ישויות.
מה החומר למבחן ? כל החומר שנלמד בהרצאות ובתרגולים. לגבי backtracking: לא תידרשו לממש אלגוריתם, אך כן להבין או להשלים מימוש נתון. אחת משאלות המבחן מבוססת.
הכנת המצגת: מוטי בן ארי ומיכל סמואל המחלקה להוראת המדעים, מכון ויצמן למדע ©
Map-Reduce Input: a collection of scientific articles on different topics, each marked with a field of science –Mathematics, Computer Science, Biology,
1 Formal Specifications for Complex Systems (236368) Tutorial #5 Refinement in Z: data refinement; operations refinement; their combinations.
מרצה: פרופסור דורון פלד
תרגול חזרה. מבנה האובייקט תאר את מבנה האובייקט כולל מבנה טבלאות הפונקציות הוירטואליות עבור התכנית הבאה struct A { int x; virtual void a() {}; }; struct.
Formal Specifications for Complex Systems (236368) Tutorial #6 appendix Statecharts vs. Raphsody 7 (theory vs. practice)
תכנות תרגול 6 שבוע : תרגיל שורש של מספר מחושב לפי הסדרה הבאה : root 0 = 1 root n = root n-1 + a / root n-1 2 כאשר האיבר ה n של הסדרה הוא קירוב.
Slide 1 of 40. Lecture A מבוא למדעי המחשב. Slide 2 of 40. Lecture A Lesson A - Introduction Unit A1 – About This Course.
איתור ותפיסת כדור לזריקה תוך שיתוף שתי זרועות רובוטיות הטכניון - מכון טכנולוגי לישראל הפקולטה להנדסת חשמל המעבדה לבקרה ורובוטיקה תופאחה חיסאוי יגאל סיגל.
© המרכז להוראת המדעים האוניברסיטה העברית בירושלים 1 הפניות.
מערכים עד היום כדי לייצג 20 סטודנטים נאלצנו להגדיר עד היום כדי לייצג 20 סטודנטים נאלצנו להגדיר int grade1, grade2, …, grade20; int grade1, grade2, …, grade20;
מודל הלמידה מדוגמאות Learning from Examples קלט: אוסף של דוגמאות פלט: קונסיסטנטי עם פונקציה f ב- C ז"א קונסיסטנטי עם S ז"א מודל הלמידה מדוגמאות Learning.
מערכות הפעלה ( אביב 2006) חגית עטיה © 1 סיכום הקורס.
תכנות מונחה עצמים Object Oriented Programming (OOP) אתגר מחזור ב' Templates תבניות.
מבוא למדעי המחשב תרגול 3 שעת קבלה : יום שני 11:00-12:00 דוא " ל :
רכיבי ידע בהוראה ד"ר גילה קאופמן.
מבוא למדעי המחשב, סמסטר א ', תשע " א תרגול מס ' 1 נושאים  הכרת הקורס  פסאודו - קוד / אלגוריתם 1.
Markov Decision Processes (MDP) תומר באום Based on ch. 14 in “Probabilistic Robotics” By Thrun et al. ב"הב"ה.
מה היום ? - - חזרה מהירה. - קריאה וכתיבה לקבצים. - בניית תוכנית כתיבה low-level - בניית ערוץ גלובלי והדגמה מול חומרה - low-level DAQ, פולימורפיזם וטריגר.
Points on a perimeter (Convex Hull) קורס – מבוא לעבוד מקבילי מבצעים – אריאל פנדלר יאיר ברעם.
11 Introduction to Programming in C - Fall 2010 – Erez Sharvit, Amir Menczel 1 Introduction to Programming in C תרגול
פיתוח מערכות מידע Class diagrams Aggregation, Composition and Generalization.
1 מבוא למדעי המחשב הרצאה 21: Queue, Iterator & Iterable.
1 המרכז להוראת המדעים © האוניברסיטה העברית בירושלים עוברים לג ' אווה.
מבוא למדעי המחשב לתעשייה וניהול הרצאה 7. סברוטינות subroutines.
1 המרכז להוראת המדעים © האוניברסיטה העברית בירושלים פולימורפיזם מתקדם ממשקים בג ' אווה 1.
שיאון שחוריMilOSS-il מוטיבציה  python זה קל ו C זה מהיר. למה לא לשלב?  יש כבר קוד קיים ב C. אנחנו רוצים להשתמש בו, ולבסס מעליו קוד חדש ב python.
מבוא למדעי המחשב לתעשייה וניהול הרצאה 12. ספריות.
עקרונות תכנות מונחה עצמים תרגול 10: Generics. Outline  Generic classes  Generics & Inheritance  Wild Cards  Case study: Generic Graph.
1 תרגול 11: Design Patterns ומחלקות פנימיות אסף זריצקי ומתי שמרת 1 תוכנה 1.
1 נתבונן בפונקציה הבאה public static int min(int[] a,int n) { int min = a[0]; for (int i = 1; (i < n ) && (i < a.length) ; i++) if (min > a[i]) min = a[i];
ד"ר רון בלונדר, המחלקה להוראת המדעים, מכון ויצמן למדע
קצת היסטוריה 1981דיווח ראשון על תסמונת כשל חיסוני נרכש בקרב מספר הומוסקסואלים. 1981דיווח על ביטויים שונים של איידס בקרב מזריקי סמים, חולי המופיליה, מקבלי.
מחרוזות – הטיפוס String
אביב תשס " ה JCT תיכון תוכנה ד " ר ר ' גלנט / י ' לויאןכל הזכויות שמורות 1 פרק 5 תרשימי מצבים Statecharts למחלקות תגובתיות Reactive Classes הקדמה ודוגמא.
האוניברסיטה העברית בירושלים
מספרים אקראיים ניתן לייצר מספרים אקראיים ע"י הפונקציה int rand(void);
Programming Arrays.
Object Oriented Programming
Object Oriented Programming
Operators Overloading
תכנות מונחה עצמים.
מצביעים קרן כליף.
SQL בסיסי – הגדרה אינדוקטיבית
עבודה עם נתונים באמצעות ADO.NET
מבוא ל Maven אליהו חלסצ'י תכנות מתקדם תרגול מספר 3
ממשקים - interfaces איך לאפשר "הורשה מרובה".
חדוה מילוא, ספריה מכון ויצמן למדע
הנעה חשמלית.
תכנות מכוון עצמים ושפת JAVA
למה.
תיכון אהל שם, רמת גן קורס PHP – הרצאה מס' 10
קורס תכנות שיעור ראשון: מבוא.
מבוא לתכנות מונחה עצמים Object Oriented Programming
Shell Scripts בסביבת UNIX
תוכנה 1 תרגול 13 – סיכום.
מבוא לתכנות ב- Java תרגול 10 - רשימות מקושרות.
פולימורפיזם מתקדם ממשקים בC# עריכה ועיצוב: קרן הרדי
Presentation transcript:

פרופ' מוטי בן-ארי המחלקה להוראת המדעים מכון ויצמן למדע מהי שפת Java? פרופ' מוטי בן-ארי המחלקה להוראת המדעים מכון ויצמן למדע

Copyright © Moti Ben-Ari, 2005. תכנות מונחה עצמים מהו? הגישה הפונקציונאלית המסורתית לפיתוח תכנה מתרכזת במה שתכנית "צריכה לעשות": פתח תכנית לחישוב ממוצע ציונים. תכנות מונחה עצמים (תמ"ע) היא גישה לפיתוח תכנה המבוססת על פעילות של עצמים שהם ישויות על תכונותיהם והפעולות שניתן לבצע עליהם. עצם: ציונים של כיתה בספרות. תכונה: מערך של שלמים. פעולה: חשב ממוצע. Copyright © Moti Ben-Ari, 2005.

Copyright © Moti Ben-Ari, 2005. למה תכנות מונחה עצמים? לא ניתן לתכנן תכניות גדולות מאוד לפי השיטה הפונקציונאלית, כי הקשרים בין הפונקציות השונות מסועפים מדי. תמ"ע מאפשר פיתוח של מספר רב של מודולים שהם "חסרי הקשר", ואח"כ את תפירתם למערך תכנה גדול מאוד. בגלל שהמודולים "חסרי הקשר", תמ"ע מקל על שימוש חוזר בחלקי תכנה קיימים. Copyright © Moti Ben-Ari, 2005.

שפות לתכנות מונחה עצמים Simula 1967 [Pascal 1970] Smalltalk 1972/1980 [C 1972] Ada 1983/1995 C++ 1986 Eiffel 1992 Java 1995 C# 2002 Copyright © Moti Ben-Ari, 2005.

Copyright © Moti Ben-Ari, 2005. Java מאפייני שפת תחביר דומה מאוד ל-C. ביטוים, משפטי השמה ובקרה דומים ל-C. בדיקת טיפוסים חזקה בדומה ל-Pascal!!! מצביעים סמויים -- reference semantics. (כמו פרמטר של משתנה var ב- Pascal.) טיפול ב"חריגים" (Exceptions) – שגיאות בזמן ביצוע. "שפה" קטנה יחסית. הספריות גדולות מאוד. Copyright © Moti Ben-Ari, 2005.

Copyright © Moti Ben-Ari, 2005. Java מאפייני שפת בניית עצמים והקשרים ביניהם. מושגים חדשים ומינוחים חדשים: עצם (ערך): object טיפוס (מודול): class תכונה (משתנה): attribute, field פעולה (פונקציה, פרוצדורה):method פעולה בונה (אתחול): constructor Copyright © Moti Ben-Ari, 2005.

Copyright © Moti Ben-Ari, 2005. מאפייני שפת Java Applications Program Interface (API). גראפיקה, צליל, ממשק גרפי, תקשורת, קלט-פלט, מקביליות, מבני נתונים, מתמטיקה, הגנה. "אין מה ללמוד". אין חידושים מבחינת התחביר והסמנטיקה, רק טיפוסים, פעולות, תכונות, וכו'. ה-API כבד מאוד: כ-2700 טיפוסים. התיעוד הוא 34 MB (דחוס)! ההבדלים בין "השפות" הם למעשה בין ה-API. Copyright © Moti Ben-Ari, 2005.

Copyright © Moti Ben-Ari, 2005. דוגמה לטיפוס מה-API JButton void setEnabled(boolean b) void setFont(Font f) void setText(String text) boolean isEnabled() void addActionListener(ActionListener l) Copyright © Moti Ben-Ari, 2005.

Copyright © Moti Ben-Ari, 2005. Java בהוראה שפת Java הפכה להיות שפת התכנות המרכזית להוראה באוניברסיטאות בעולם. שפת Java היא שפת התכנות בה משתמשים במבחני ה- Advanced Placement : בחינות ארציות המיועדת לתלמידי תיכון בארה"ב הממשיכים לאוניברסיטה. התכנים מקבילים ל"יסודות" ו-"עיצוב". שינוי בשפות: Pascal -> C++ -> Java Copyright © Moti Ben-Ari, 2005.

Copyright © Moti Ben-Ari, 2005. Java מול C# עבור התכנים ב-"יסודות", "עיצוב", "מבוא לתכנות מונחה עצמים", אין כלל הבדל בין השפות, אלא ברמה תחבירית זניחה. לכן, אין הבדלים פדגוגיים, פרט להבדלים בחומרי הלמידה וכלי התכנה. למקצוענים שיקולים שונים: The Web services debate: J2EE vs. .NET Communications of the ACM, Volume 46 Issue 6 Copyright © Moti Ben-Ari, 2005.

Copyright © Moti Ben-Ari, 2005. מה הבעיה ? Java היא שפה שניתן לתכנת בה רק לפי שיטת "תכנות מונחה עצמים". לדעתנו רצוי ללמד שפת תכנות לתמ"ע, בשיטת "עצמים תחילה". לפי החלטת המפמ"ר וועדת המקצוע, הסילבוס של "יסודות" לא משתנה. איך ללמד תכנות פרוצדוראלי תוך שימוש בשפה לתמ"ע כגון Java ??? Copyright © Moti Ben-Ari, 2005.

אז איך נראית תכנית ב- Java ? תכנית Hello world ב- Pascal וב- Java. תכנית ב- Pascal מ"יסודות 2". אותה תכנית ב- C. אותה תכנית ב- Java, ללא תמ"ע. אותה תכנית ב- C#, ללא תמ"ע. אותה תכנית ב- Java עם תמ"ע. Copyright © Moti Ben-Ari, 2005.

Copyright © Moti Ben-Ari, 2005. תכנית פשוטה ב- Pascal program Hello; begin writeln(‘Hello world’) end. Copyright © Moti Ben-Ari, 2005.

Copyright © Moti Ben-Ari, 2005. תכנית פשוטה ב- Java class Hello { public static void main(String[] args) { OutputWindow.println("Hello world"); } Copyright © Moti Ben-Ari, 2005.

Copyright © Moti Ben-Ari, 2005. program MostPoints(input, output); const LAST = 100; type PointType = array[1..LAST] of integer; var Points: PointType; MaxPoints, P, NumPlay: integer; function Max(A: PointType; Players: integer): integer; var PointMax, P: integer; begin PointMax := A[1]; for P := 2 to Players do if A[P] > PointMax then PointMax := A[P]; Max := PointMax end {Max}; Copyright © Moti Ben-Ari, 2005.

Copyright © Moti Ben-Ari, 2005. begin writeln('Enter number of points:'); NumPlay := 1; read(Points[NumPlay]); while Points[NumPlay] > -1 do NumPlay := NumPlay + 1; read(Points[NumPlay]) end; NumPlay := NumPlay - 1; MaxPoints := Max(Points, NumPlay); for P := 1 to NumPlay do if Points[P] = MaxPoints then writeln('Prize to player', P) end. Copyright © Moti Ben-Ari, 2005.

Copyright © Moti Ben-Ari, 2005. #include <stdio.h> const int LAST = 100; int max(int a[], int numPlay( { int pointMax = a[0]; int p; for (p = 1; p < numPlay; p++) if (a[p] > pointMax) pointMax = a[p]; return pointMax; { Copyright © Moti Ben-Ari, 2005.

Copyright © Moti Ben-Ari, 2005. int main() { int points[LAST]; int maxPoints, numPlay, p = 0; printf("Enter number of points:”); scanf("%d", points[numPlay]); while (points[numPlay] > -1) { numPlay++; { maxPoints = max(points, numPlay); for (p = 0; p < numPlay; p++) if (points[p] == maxPoints) printf("Prize to player %d\n", p)’ Copyright © Moti Ben-Ari, 2005.

Copyright © Moti Ben-Ari, 2005. class MostPointsJ { static int max(int[] a, int numPlay) { int pointMax = a[0]; for (int p = 1; p < numPlay; p++) if (a[p] > pointMax) pointMax = a[p]; return pointMax; } static final int LAST = 100; Copyright © Moti Ben-Ari, 2005.

Copyright © Moti Ben-Ari, 2005. public static void main(String[] args) { int[] points = new int[LAST]; int maxPoints, numPlay = 0; points[numPlay] = InputRequestor.requestInt("Enter:"); while (points[numPlay] > -1) { numPlay++; points[numPlay] = InputRequestor.requestInt("Enter:"); } maxPoints = max(points, numPlay); for (int p = 0; p < numPlay; p++) if (points[p] == maxPoints) OutputWindow.println("Prize to" + p); Copyright © Moti Ben-Ari, 2005.

Copyright © Moti Ben-Ari, 2005. using System; class MostPoints { static int max(int[] a, int numPlay) { int pointMax = a[0]; for (int p = 1; p < numPlay; p++) if (a[p] > pointMax) pointMax = a[p]; return pointMax; } static readonly int LAST = 100; Copyright © Moti Ben-Ari, 2005.

Copyright © Moti Ben-Ari, 2005. static void Main() { int[] points = new int[LAST]; int maxPoints, numPlay = 0; Console.WriteLine("Enter:"); points[numPlay] = int.Parse(Console.ReadLine()); while (points[numPlay] > -1) { numPlay++; points[numPlay] = int.Parse(Console.ReadLine()); } maxPoints = max(points, numPlay); for (int p = 0; p < numPlay; p++) if (points[p] == maxPoints) Console.WriteLine("Prize to" + p); Copyright © Moti Ben-Ari, 2005.

Copyright © Moti Ben-Ari, 2005. class MostPointsObj { static final int LAST = 100; int[] points = new int[LAST]; public MostPointsObj () { … } void getPoints () { … } void printPrizes () { … } int max() { … } public static void main(String[] args) { MostPointsObj m = new MostPointsObj(); m.getPoints(); m.printPrizes(); { Copyright © Moti Ben-Ari, 2005.

Copyright © Moti Ben-Ari, 2005. הבנת שגיאות הודעות על שגיאות מנוסחות כמובן לפי תמ"ע! אין קיצורי דרך: יש להבין את העקרונות כדי לפענח אותן. public static void main(String args[]) public static void main(String args) public static main(String[] args) public static Hello(String[] args) Copyright © Moti Ben-Ari, 2005.

Copyright © Moti Ben-Ari, 2005. הבנת שגיאות exception in thread "main" java.lang.NoSuchMethodError: main invalid method declaration: return type expected modifier static not allowed here Copyright © Moti Ben-Ari, 2005.

Copyright © Moti Ben-Ari, 2005. מסקנה חובה/כדאי למורה הרוצה ללמד את שפת Java ללמוד תכנות מונחה עצמים, כדי להבין את מבנה השפה ועקרונותיה. בשלב שני ניתן להבין איך ללמד "יסודות" ו-"עיצוב" עם שפת Java, תחילה ללא תמ"ע כלל, ואח"כ תוך הוראה מדורגת, הכול לפי הנדרש בסילבוסים. Copyright © Moti Ben-Ari, 2005.

Copyright © Moti Ben-Ari, 2005. מהדר ומפרש System Development Kit. ניתן להורדה בחינם מהאתר של חברת Sun. ניתן לערוך תכנית עם עורך פשוט כגון Notepad ולהריץ אותה מחלון Command! javac MostPoints.java java MostPoints Copyright © Moti Ben-Ari, 2005.

כל כלי התכנה שמוזכרים ניתנים להורדה בחינם!! Copyright © Moti Ben-Ari, 2005.

Copyright © Moti Ben-Ari, 2005. סביבות פיתוח לימודיות סביבות מלאות הכוללות מנפה שגיאות ותמיכה בבדיקת תכניות: BlueJ (U. Southern Denmark, Deakin U., U. of Kent) DrJava (Rice U.) jGrasp (Auburn U.) Copyright © Moti Ben-Ari, 2005.

Copyright © Moti Ben-Ari, 2005. סביבות פיתוח לימודיות סביבות להוראה לתלמידים מתחילים וחלשים: Alice (Carnegie Mellon U.) JPIE (Washington U. in St. Louis) LIVE (Hamilton College) Copyright © Moti Ben-Ari, 2005.

Copyright © Moti Ben-Ari, 2005. סביבות פיתוח JCreator LE בשימוש בקורס "תמ"ע בשפת ג'אווה". אין מנפה שגיאות (אלא בגרסה בתשלום). jEdit סביבה בקוד פתוח עם plugins רבים לניפוי שגיאות, סידור קוד המקור, בדיקת תכניות, ניהול תצורה, ועוד. Eclipse (IBM). JBuilder (Borland). Copyright © Moti Ben-Ari, 2005.

ספריות מותאמות לתלמידים Java Power Tools (Northeastern U.) ספריה להקל על תלמידים לכתוב ממשקים GUI. ObjectDraw (Williams College) ספריה התומכת בגישת הוראה "אירועים תחילה", ובהוראת מקביליות בשלב מוקדם. Java Gently (U. of Pretoria) Copyright © Moti Ben-Ari, 2005.

Copyright © Moti Ben-Ari, 2005. כלי תכנה לוויזואלזציה Jeliot (U. of Joensuu, Weizmann Institute) אנימציה מליאה של תכניות פשוטות ב-Java. ניתן להשתמש גם בסביבת פיתוח ראשונית. Dot.java (U. of Auckland) ספריה המאפשרת הצגה גראפית של כל מבנה נתונים בתכנית Java. MatrixPro (Helsinki U. of Technology) כלי לוויזואליזציה של מבני נתונים ואנימציה של אלגוריתמים. JAWAA, JIVE, jVisual, Animal, … Copyright © Moti Ben-Ari, 2005.

Copyright © Moti Ben-Ari, 2005. הניסיון שלנו לימדנו תמ"ע ושפת Java בגישת "עצמים תחילה" לתלמידי כיתה יוד בגימנסיה גן נחום בראשל"צ (שני מחזורים בשנים תשס"א, תשס"ב). ההוראה לוותה במחקר מעמיק של נוע. (בסופו של דבר) התלמידים הצעירים תפסו את העקרונות של תמ"ע, והיו מסוגלים לפתח בהצלחה פרויקטי תכנה לפי העקרונות. יש חשיבות רבה לסדר הוראת הנושאים, לדיוק במינוחים, לאיכות ההסברים, ולתמיכה של כלי התכנה. Copyright © Moti Ben-Ari, 2005.