בתשובה לאיש המרק, 15/06/07 19:28
התחלת ולכן תסיים? 447169
אין בה שום דבר "מיוחד" במיוחד, היא דומה ללא מעט שפות טובות אחרות (למשל פייתון, המפורסמת הרבה יותר), היא פשוט הראשונה שממש הצליחה לגרום לי להתעניין בה, כך שהייחוד שלה הוא די אינדיבידואלי.

לגבי מה שטוב בה - איסוף אשפה (כמו בג'אווה) שמוחק לגמרי את כל מימד בעיות ניהול הזיכרון, תכנות מונחה עצמים שלם יותר (אין פרימיטיבים, הכל אובייקטים), טיפוסי נתונים מורכבים (מערך, hash, ביטויים רגולריים) מובנים בשפה בצורה מאוד נוחה, מנגנון פשוט מאוד של איטרטורים והעברת פונקציות אנונימיות, שבא לידי ביטוי בקוד קריא ו"טבעי" מאוד.

באופן כללי, כשאני כותב ב-++C או בג'אווה, אני מרגיש שחצי מהזמן אני בונה פיגומים כדי שאוכל להתמודד עם המטלה התכנותית שלי, וכשבסוף הם מוכנים ואני משתמש בהם, התוצאה מאוד לא קריאה בגלל רמת הסיבוך הנוספת שלהם. ברובי אני פשוט פותר את הבעיה, כשלרוב כל מה שאני צריך להוסיף לפיגומים זה פונקציות של שורה או שתיים שמתווספות אוטומטית לטיפוסי הנתונים הקיימים.
התחלת ולכן תסיים? 447177
יצא לך לכתוב משהו ב-smalltalk ? אם כן, איך Ruby בהשוואה אליה?
התחלת ולכן תסיים? 447178
לא יצא לי, אבל אולי כן אפשר לבצע השוואה כלשהי: התחלתי בעבר ללמוד smalltalk ונשברתי די מהר - עד כמה ש-if שהוא אובייקט הוא דבר מגניב, זה בעיקר מרגיש מסורבל - ואילו ברובי התאהבתי מהרגע הראשון. אני מניח שעכשיו אני כבר מוכן ל"סיבוב שני" עם smalltalk, ואנסה לדווח בעתיד על התוצאות.
התחלת ולכן תסיים? 447182
ב-smalltalk זה לא ש-if הוא אובייקט אלא שהוא מתודה (הודעה) של כל מחלקה. הבלוק שיש לבצע (שהוא בעצם פונקציה אנונימית), הוא האובייקט. כל המושג של בלוקים/פונקציות אנונימיות היה קשה לי להבנה בתחילה, כמו ב-Lisp. אחר כך התרגלתי. אולי הגיע הזמן שאקח את רובי לסיבוב (אולי אפילו On Rails!).
התחלת ולכן תסיים? 447183
איך קרה שדיון בשבוע הספר הפך לדיון ב-ruby?

ערן - ממליץ בחום לקחת את רובי לסיבוב, אבל בזהירות. אני נדבקתי בחידק, מה שגרם לי בסופו של דבר לעזוב את העבודה כי לא יכולתי יותר לראות java מול העיניים, ולהקים סטארט-אפ בין היתר כדי שאוכל לקודד בכיף ב-ruby...
אתה יכול לחשוב עליה כמשהו קרוב מספיק ל-lisp כדי להיות מוצלח, אבל עם סיכוי טוב להצלחה מסחרית.
התחלת ולכן תסיים? 447184
מה שיפה בדיונים באייל זו האסוציאטיביות הזו, שבה אתה יודע איפה דיון מתחיל, אבל לא יודע לאן הוא יכול להגיע :)
התחלת ולכן תסיים? 447197
You mentioned associations... Look for Topic Maps.

התחלת ולכן תסיים? 447188
הממ, לא זכרתי טוב, ועכשיו בלבלת אותי עוד יותר - אתה בטוח שהאובייקט הוא לא ערך ה-true/false, והבלוק הוא הפרמטר לפונקציה?

אגב, ככה גם רובי עובד - לכל פונקציה אפשר להעביר בלוק/פונקציה אנונימית, וכך גם מממשים איטרטורים. הסינטקס די דומה לזה של smalltalk אבל לדעתי קצת יותר קריא.

הנה דוגמה שאני מחבב לקוד ברובי, במקרה הזה שמדפיסה את 1,000 מספרי פיבונאצ'י הראשונים:

x=y=1
1000.times {x,y=y,x+y; puts x}

והנה דוגמה לאיטרטור שלוקח מערך של ערכי x, מפעיל פונקציה f עליהם ומחזיר מערך y של התוצאות:

y=x.collect {|x_value| f(x_value)}

אין לי ספק שגם בשפות אחרות יש מבנים דומים, אבל אני תוהה בכמה מהשפות שהן לא ב-Cluster של רובי (כדוגמת פייתון וסמולטוק) זה קריא ואלגנטי בצורה דומה.
התחלת ולכן תסיים? 447194
הלכתי לבדוק. אם אני מבין נכון את מה שמצאתי כאן:
אז האובייקט הוא מופע (יחיד) של תת-מחלקה של Boolean - או True או False. כל אחת מהן מממשת את ההודעות ifTrue ו-IfFalse ושילובים של השתיים (אשר מוצהרות כבר ב-Boolean), כשכל הודעה מקבלת כפרמטר בלוק (או שניים). הנה דוגמה לתחביר (מתוך הערך בוויקיפדיה):
result := a > b
ifTrue:[ 'greater' ]
ifFalse:[ 'less' ]
התחלת ולכן תסיים? 447195
טוב, עשית לי חשק, ועוד לא גמרתי ללמוד פייתון. תתבייש לך.
התחלת ולכן תסיים? 447196
נו, ואני אפילו עוד לא התחלתי ללמוד פייתון. בוש והיכלם.
הנוער של ימינו 447336
כשאני למדתי לתכנת לימדו ב-pascal ואז עברו ל-C (או ל-fortran). אח"כ, במהלך הקריירה שלי, למדתי שפות קצת יותר "מתקדמות" כמו C++ Java ושפות סקריפטים (ksh, visual basic, list וכו'). רוב הקריירה שלי עסקתי ב-C++ ובגלל ש"שפת האם" שלי היא עדיין C (למרות שלמדתי אותה שניה, pascal זה ממש איכס), אני ממש נהנה לתכנת ב-C++. כל פעם שאני כותב משהו ב-Java (שזה, בסיכום כולל, 30% מהקוד שכתבתי בקריירה) , אני חייב להכנס לקוד המקור שלהם ולבדוק מה באמת עושה המתודה הזאת, ואם זו באמת הדרך הטובה ביותר לצרכים שלי... רק המחשה על לכתוב בשפה יותר "גבוהה" מצמררת.
הנוער של ימינו 447340
כמוני כמוך - הן בכך ששפת "אימי" היא C, לימוד ++C בעבודה והבעייה עם ג'אווה. אחת הבעיות שלי כמנהל בחברה מסחרית היא שאלו המתכנתים בג'אווה אינם תמיד מודעים ואף לא איכפת להם מה בדיוק עושה המחשב עם הקוד. לעיתים תכופות אני נדרש לאזן את הגישה של: "קוד נועד בעיקר לבני אדם (מהירות פיתוח, תחזוקה) ולא למחשבים".

זו בעייה כאשר הביצועים הנדרשים הם תובעניים במיוחד והינם חלק מן היתרון התחרותי של החברה. זה הרבה יותר מאשר הבדלי הביצועים בין השפות, זה אופן החשיבה עימו ניגשים לפתור בעיות.
הנוער של ימינו 447356
תוכל להדגים מדוע זה אופן חשיבה שונה, ולמה זה בהכרח טוב?

אי הידיעה של איך הפונקציה ממומשת היא מה שמכונה בעגה המחשבית "זה לא באג, זה פיצ'ר" - הפרדה בין רמות אבסטרקציה שונות עוזרת לטפל במטלה התכנותית הנוכחית. כמובן, לא חייבים להסתמך על ספריה סטנדרטית - אם ממש רוצים, אפשר לכתוב את הספריה שלך בעצמך ולדאוג לאופטימיזציות שמתאימות לך. העניין הוא שלעתים קרובות (לא יודע איך זה אצלכם ובמה בדיוק אתם עוסקים) אין בכך צורך, לפחות לא בהתחלה, וכמעט תמיד יש בעיות במימוש שדורשות מספר איטרציות כדי לתקן.
הנוער של ימינו 448188
זה לא בהכרח טוב, אלא רק לחלקים מסויימים של תוכנה, וגם זה לא בכל תחום. אבל זה חלק מן ההתמחות והעיסוק שלי: אלגוריתמים למחשב לא מופשט.

הבעייה במעבר מסודר מרמות הפשטה גבוהות ומטה, הוא שבמקרים מסויימים מסיימים עם מוצר חסר כושר תחרות.
דוגמא אחת בה אני נתקל לא פעם היא פירוק טקסט (אני עוסק בעיקר בטקסט). הנטייה של המתכנן הממוצע היא בניית מודול להפרדה בין מילים, מודול להפרדה למשפטים ומודול לפסקאות. לאחר מכן ישנם מודולים לניתוחי עומק. בפועל, כל אלו תלויים הדוקות זה בזה - יש מילים המכילות נקודות, יש סופי שורה שאינם חותכים משפט ויש שהם מבטאים אף פסקה חדשה - לפי ההקשר וסגנון הכתיבה וגם בניתוחי העומק (למשל תחביר, סגנון כתיבה) התלות בין הפירוקים השונים אינה תמיד פשוטה.

לפעמים לא ניתן להגיע לזה באיטרציות ומה שקורה הוא שכדי לחלק את המשימה, כופים הפרדות שלא עובדות, מה שבא לידי ביטוי באיטיות בריצה ובתחזוקה כאחד. הבעייה היא כללית, כאשר מנסים לעשות דברים בהם גם המוח מערב דרגות הפשטה שונות, כמו למשל ניתוח מידע ויזואלי ולינגוויסטי.

עדיין, כמעט בכל המקרים, שיטות העבודה המקובלות ובראשן פירוק מירבי למודולים ומעבר מסודר בין רמות הפשטה, הן המומלצות.

נקודה אחרת היא התאמה מראש של אלגוריתם למשאבים, ובראשם כמות הזיכרון, מהירות הגישה וקצב הכתיבה והקריאה מן הדיסק וכן גודל זכרון המטמון של המעבד. התברר לנו למשל שגישה אקראית לזיכרון האקראי היא איטית באופן דטרמיניסטי. תוצאה: החלפת אלגוריתם ושינוי מערכתי משמעותי שהפך את המערכת לתחרותית.

לפעמים, כאלו שהתרגלו לחיים הטובים עם שפות שכבר עושות הכל בשבילם, מעסיקים את עצמם רק ברעיונות נעלים, מבלי תן-דעת על הטראומה אותה הם גורמים למחשב באצבע כה קלה על המקלדת. התוצר אינו סקיילבילי – עקב התעלמות מטבעו הלא מופשט של הדיסק וכן צריכת זיכרון גבוהה, או צריכה נמוכה, המסתמכת על איסוף אשפה – אך מסתיימת בפרגמנטציה של הזיכרון. התוצאה – צריך לבנות הכל מחדש, אם רוצים לעבור למערכת מסחרית, שעובדת על pc פשוט, על כמויות גדולות של מידע, ולא על מחשב עם ארבעה מעבדים ומערך יקר של דיסקים מסוג scsi.

אגב, אכן, כפי שניחשת, במקום הספריות הטובות לרוב המקרים יש לעיתים צורך בספריות ומחלקות לטיפול באבני הבניין של המערכות עליהן אני מדבר: מחרוזות, קבצים וטיפול בזיכרון.

רציתי לכתוב תגובה יותר משכנעת ורהוטה - אבל איני מוצא לכך את הזמן. אני מקווה שעיקר הטענות מובן.
הנוער של ימינו 448191
תודה, מעניין מאוד.

כעת השאלה היא האם שפה רב תכליתית כמו ++C היא אכן הפתרון הטוב ביותר, ולא עדיף להשתמש בשפות תכנות שמותאמות במיוחד לבעיות שאתם מתמודדים איתן... (אם יש כאלו)
הנוער של ימינו 447355
כשאתה אומר "לתכנת ב-++C", הכוונה לתכנות ב-++C (כלומר, הסתמכות רחבה על ספריות בכלל ועל ה-STL בפרט) או לתכנות ב-C עם עוד כמה תוספות ואולי שמץ של תכנות מונחה עצמים?

בכל אופן, אם אתה צריך להיכנס לקוד המקור כדי לדעת מה *עושה* המתודה, יש בעיה חמורה בדוקומנטציה של הספריה שאתה עובד איתה.

אגב, Visual Basic זו שפת סקריפטינג? באיזה מובן?
הנוער של ימינו 447362
הסתמכות על STL ודומות כשאפשר. יש ב-STL דברים שלא עובדים כל כך טוב (למשל STRING בהרבה מערכות הפעלה מקצה זיכרון בצורה בעייתית), אבל הכוונה בעיקר לתכנות מונחה עצמים ככל הניתן (בכל זאת, זה מיעל את הפיתוח והתחזוקה).

הדוקומנטציה לא תמיד עוזרת, לפעמים, בעיקר בשביל יעילות, חשוב לך לדעת מה בדיוק "הם" עושים שם, בשביל שתוכל לספק להם תשתית שתהיה יעילה בשבילם.

התכוונתי ל-VBA
הנוער של ימינו 447366
כמו שאמרתי במקום אחר כאן, אם רוצים יעילות סופר-דופר, צריך לרוב כתוב את הקוד בעצמך, בצורה שמתאימה הכי טוב לאפליקציה. לא תמיד חייבים יעילות סופר-דופר, ולעתים קרובות אין צורך לייעל עד שלב מתקדם יחסית (כלומר, עד שהתוכנה כבר רצה, ואפשר לבדוק מה בדיוק צווארי הבקבוק).

אני לא מכיר את VBA, אבל באיזה מובן היא שפת סקריפטינג? כי היא מפורשת ולא מקומפלת?
הנוער של ימינו 447368
לשפות גבוהות יש הרבה פעמים גג להתיעילות האפשרית, ובחירה בשפה מתקדמת בתחית הפרוייקת עלולה להגביל את ההתיעלות שלך בעתיד, דבר שהוא לפעמים בלתי סביר מבחינת ניהול פרוייקט.

היא מפורשת, קלה לכתיבה, קלה ללימוד ראשוני ("hello world"), קשה ללימוד כולל (לך תבנה בה עץ בינארי...), לא אלגנטית, מאד קשה לעשות בה מה שהתכננים שלה לא חשבו שתרצה לעשות, ומאד פשוט לעשות בה מה שהמתכננים שלה חשבו שתרצה לעשות.
הנוער של ימינו 447385
כאן נכנס היתרון של שפות שמאפשרות שילוב קוד בשפות "נמוכות" כמו C. לא יודע איך זה הולך בג'אווה, אמנם, אבל אני לא חסיד גדול של ג'אווה (וממילא המטרה שלה אינה להיות סופר-דופר יעילה).

אני לא חושב שהמאפיינים מ"לא אלגנטי" והלאה תואמים שפות סקריפטינג (כשאתה אומר "שפות סקריפטינג" מה שיש לי בראש הוא רובי ופייתון, למשל).
הנוער של ימינו 447402
בג'אווה אתה יכול להשתמש ב-Java Native Interface כדי לקרוא לפונקציות ב-C. זה לא המנגנון הכי נוח בעולם, אבל זה עובד.
הנוער של ימינו 447426
אולי אנחנו מגדירים "אלגנטי" בצורה שונה, ג'אווה, למשל, היא שפה מאד אלגנטית לדעתי, שפה שכמעט מאלצת מתכנתים לא אלגנטים לכתוב בצורה אלגנטית. למעשה, יש הרבה מאד מתכנתים שהייתי מעביר לעבוד בג'אווה לתקופה מסויימת, רק בשביל שידעו לעבוד בצורה אלגנטית. במובן הזה שפות סקריפט (כולל, עד כמה שאני מכיר, פיתון ורובי) הן מאד לא אלגנטיות. C++ יכולה להיות אלגנטית מאד או לא אלגנטית מאד בתלות במתכנת בלבד. זה מה שיפה בה, וזה מה שעושה אותה לבעייתית.
הנוער של ימינו 447428
מה זה אלגנטי?

לדעתי אלגנטי פירושו "לכתוב את מה שרוצים לעשות, עם מינימום כתיבה של מה שצריך לעשות כדי שמה שרוצים לעשות יתבצע". במילים אחרות, ככל שמשהו יותר קרוב לפסאודו-קוד, הוא יותר אלגנטי.

אתן דוגמה פשוטה: הצורך לכתוב

for (i=0; i<n; i++){
doSomething(array[i]);
}

כדי לעשות משהו על מערך בן n איברים הוא לא אלגנטי כמו, לדוגמה, לכתוב

array.each{|item| doSomething(item)}

ה-Vector שב-STL של ++C מותיר את אי האלגנטיות במקומה, כשה-i מתחלף באובייקט של איטרטור שעושה בערך את אותו הדבר. במקרה הראשון אנחנו צריכים לגלוש לפרטים - קח איטרטור, אתחל אותו לתחילת המערך, הגדל אותו כל עוד לא הגענו לסוף. במקרה השני הכל מתמצה בכתיבת array.each.

עוד דרך נחמדה להמחיש את ההבדל היא לנסות לקרוא בקול (או סתם להקריא בראש) את שני קטעי הקוד. הראשון פחות נוח להקראה, ויוצא מבולבל יותר. השני נשמע כמעט כמו שפה טבעית.
הנוער של ימינו 447432
אמנם חלפו בערך שש שנים מאז הפעם האחרנה שכתבתי קוד ב-C++ ובערך שבע מאז שכתבתי עם שימוש כבד ב-STL, אבל עד כמה שאני זוכר, יש בה for_each שמקבל איטרטור ו-function object. אולי זה מה שאתה מחפש?

הנוער של ימינו 447448
אכן, אבל אתה חייב להודות שהקוד שם נראה מסורבל למדי... ולא ברור לי מה קורה כשעושים משהו מורכב יותר - למשל, כשרוצים לעשות משהו דמוי collect, שמחזיר את המערך שמתקבל אחרי שמפעילים פונקציה על כל אברי המקור, או find שמחזיר תת מערך של אברי המקור שמקיימים קריטריון מסויים, וכשמשלבים אותם יחד באותה שורה.
הנוער של ימינו 447544
כפי שכבר נאמר כאן, סיפלוספלוס היא מולטי-פאראדיגמטית וגם קצת מסובכת (יחסית לשפות תיכנות אחרות). יש לזה חסרונות ברורים: זמן הפיתוח קצת ארוך יותר, למתכנתים ולמעצבים פחות מנוסים קל יותר לשגות והקוד לפעמים עלול להיות קצת קשה יותר להבנה.

אבל יש לזה גם יתרונות ברורים, בעיקר בפרוייקטים עם דיזיין מורכב ודרישות לביצועים גבוהים. לא ערכתי מחקר השוואתי, ורפרטואר שפות התכנות שלי כנראה טעון-שיפור, אבל אני לא מכיר אלטרנטיבה שיכולה להתחרות עם השפה, כמעט מכל בחינה (כולל אלגנטיות, תיעוד-עצמי, ויעילות).

האמת היא שרוב יתרונותיה מצויים בפיצ'רים שלעיתים נזנחים (ואפילו מוקצים מחמת ה-"פחד שמישהו יעשה שטות"), כמו ייחוד (חלקי ומלא) של תבניות, העמסת-יתר של אופרטורים, ירושה מרובה, ואריתמטיקת מצביעים. במקרה כזה, אם אופטימיזציה אינה קריטית ותכנות "רמה-נמוכה" אינו נדרש, אולי באמת עדיף לבחור באפשרות אחרת.

לשאלותך, עד כמה שהבנתי אותן, ב-STL נכללים לא-מעט אלגוריתמים שימושיים, וביניהם כאלה שעונים עליהן. יש פונקציות רבות לחיפוש מותנה כמו למשל find_if, search_n או search, ויש גם כמה אפשרויות להפעיל פונקציה על כל אברי קונטיינר, כמו for_each שכבר הוזכר קודם, ו-transform.

אפשר לשלב את שתי הפעולות בשורה יחידה, אם כי לטעמי לא באופן יפה. במקרה כזה, כמובן, אפשר לעשות זאת בשתי שורות. בסופו של דבר, כשמדובר בפרוייקט בינוני עם כמה עשרות תבניות ומחלקות-קונקרטיות, אני באמת מתקשה לראות בזה חיסרון ממשי.

הגישה הכללית של ה-stl היא אכן להשתמש ב-functors, וזה לא תמיד נוח או אלגנטי. אבל יש אינסוף אלטרנטיביות, החל ממימוש אד-הוק (אין-ליין) של הפעולה הדרושה, דרך כתיבה של פונקציות, פונקציות-תבנתיות או מאקרו-יים לצורך הענייין וכלה בשימוש בספריות חיצוניות, שחלקן סטדנדרטיות מאד, כמו למשל ספריות ה-boost. לדוגמא:
הנוער של ימינו 447546
אני מסכים איתך כמעט לגבי הכל, פרט ל-Operator overloading. המנגון הזה בדרך כלל אינו אינטואיטיבי (בניגוד לאחרים, טוב, גם חישובי קיצין ומצביעים לא היו כוס התה שלי) ויש לו תועלת לדעתי רק במקרים מאוד ספציפיים - מחלקות מתמטיות, מצביעים חכמים ו-function objects. ספרטניות בשימוש במנגנון זה דווקא עדיפה בעיני.
הנוער של ימינו 447550
לא בהכרח. לא היית רוצה שתהיה לך, לדוגמה, אפשרות של חיסור מערכים? יש שתי משמעויות מוסכמות בלבד שאני יכול לחשוב עליהן לדבר הזה, ולא קשה לבחור אחת ולדבוק בה.
הנוער של ימינו 447551
כשאתה אומר "חיסור מערכים" אתה מתכוון לפעולות על מטריצות באופן כללי? אם כן, זה נופל אצלי תחת "מחלקות מתמטיות".
הנוער של ימינו 447555
לא, הכוונה היא ''תוציא מהמערך שבאגף שמאל את האיברים שיש במערך שבצד ימין''.
הנוער של ימינו 447557
אני מוכן להתפשר איתך גם על זה למערכים ו-collections (אבל מעדיף שמות משמעותיים כמו union, intersect וכו'). אבל לא הרבה מעבר לזה. לא רוצה ש-Employee יתווסף ל-Department על ידי האופרטור +, ויגרע ממנה על ידי האופרטור -.
הנוער של ימינו 447558
כן, זה כבר באמת נראה כמו הורדה לזנות.
הנוער של ימינו 447573
גם new ו-delete הם אופרטורים.
הנוער של ימינו 447548
אולי כדאי להעיר שוב שהדוגמה (הפשוטה) של for_each שהבאתי קודם באה בעיקר להציג עד כמה התחביר של רובי אלגנטי לעומת מה שקורה במקומות אחרים. שימוש ב-STL, לפחות השימוש שיצא לי לעשות, דורש קצת עבודת הכנה והוא אף פעם לא אלגנטי באותה המידה. זו לא תחרות של "מה השפה שלי יודעת לעשות ששלך לא" (אבל מה שכן, האם ב-++C יש יכולות אינטרוספקטיביות?)
הנוער של ימינו 447554
(למיטב זכרוני, רק בהרחבות שפה של Visual C++ של מייקרוסופט. בשפה עצמה אין אינטרוספקציה, ואין טעינה דינאמית כמו ב-Java).
הנוער של ימינו 447779
מה הן יכולות אינטרוספקטיביות?
הנוער של ימינו 447799
גישה לעצם המתאר את המחלקה. בדרך כללל זה נותן גישה לשם המחלקה, לעצמים המחזיקים את המתודות שלה וכו'. זה גם מאפשר לטעון באופן דינמי מחלקות בזמן ריצה (למשל, לקרוא שם של מחלקה מקובץ קונפיגורציה, למשל שימוש ב-Factory שונה לכל מערכת הפעלה, עבור מחלקות המימוש של הספריה הגרפית. ברגע שיש לנו את שם המחלקה, נשתמש בטוען מחלקות: ב-Java זהו ה-ClassLoader, כדי ליצור מופע חדש של עצם מהמחלקה הנ"ל), ואפילו להפעיל מתודות לא דרך הממשק הרגיל של

object.someMethod(arg1, arg2)

אלא על ידי שימוש במחלקה ש"מפעילה" את המתודה. למשל

invoker.invoke(object, methodName, argsArray)

ובטח יש עוד דברים שלא הזכרתי כאן.
הנוער של ימינו 447880
תודה.
הנוער של ימינו 447433
קוד אלגנטי הוא קוד שקל להבין מה קורה בו (מה תעשה המכונה, ומה חשב המתכנת כשהוא כתב את הקוד), קל לשנות אותו, קל לפרק אותו, קל להגדיל אותו וקל לתקן אותו, במינימום עבודה, וכל זה ללא צורך בהערות, או בשיחה עם מי שכתב את הקוד.

(כצפוי, לג'אווה יש פתרון אלגנטי לבעיה שלך, for each, http://java.sun.com/j2se/1.5.0/docs/guide/language/f...)

עכשיו, תקח קוד פשוט בruby, למשל ה-MegaGreeter מתוך http://www.ruby-lang.org/en/documentation/quickstart... ותנסה לקרוא אותה. איכס.
הנוער של ימינו 447450
אז שוב, לא ברור לי במה ++C יותר אלגנטי.

הפתרון של ג'אווה נחמד. מענין איך הם מתמודדים עם דברים יותר מורכבים. מה שכן, הוא שקול למשהו שקיים גם ברובי (תחביר ה-for item in collection).

לא הבנתי מה הבעיה עם הדוגמה שנתת. אולי יותר כדאי להשוות אותה למשהו בעל אותה פונקציונליות בשפות אחרות. אני גם לא בטוח שכדאי לקחת קוד שמיועד ל-tutorial ולכן מפורט יתר על המידה בתור דוגמה.
הנוער של ימינו 447463
C++ הוא פלסטלינה, הוא יכול להיות אלגנטי יותר מכל שפה אחרת, ויכול להיות מאד לא אלגנטי. זה היתרון שלו, וזה החסרון שלו.

הפתרון של java לקוח משפות סקריפטים. אני אוהב את זה שהם חסכו במילה מיותרת (each או in) בלי להרוס את הקריאות. לדברים מורכבים יש את האיטראטורים.

קשה לי להסביר. מילים השמורות במקום סימני פיסוק, גישה ישירה לחברים, ומה זה ה"puts "Hello #{name}!"" המכוער הזה?
הנוער של ימינו 447471
ב(http://www.dmh2000.com/cjpr/index.shtml) יש מאמר ארוך יחסית שמנסה לתאר את היתרונות והחסרונות בכל שפה, ומכיל את אותו קוד (עץ אדום שחור http://www.dmh2000.com/cjpr/cmpframe.html) בכמה שפות.
הנוער של ימינו 447473
כן, ראיתי את המאמר הזה, אם כי לא את השוואת הקוד. נראה לי שהשורה התחתונה שלו היא "רובי/פייתון נוחים יותר לתכנות", לא?
מה יותר טוב, גליל או m-16? 447520
הדיונים על איזה שפה יותר טובה, מזכירים לי במשהו את הדיונים בצבא על מה יותר טוב, גליל או m-16. מה גם, שבמקרים רבים, אותם אנשים שהתווכחו בדיון הראשון, התווכחו לאחר שנה שנתיים בדיון השני. אני לא אומר שאין טעם לדיונים האלו; אני בעצמי חטאתי בדיונים ארוכים כמו האם צריך לקרוא למתודה Processor.process או אולי דווקא Processor.act (ברור שהשני עדיף, כאילו דה).
אני רק רוצה להציב את הדיון בפרופורציה. יש כלי נשק עתיקים כמו קרבין, שלא ניתן אותם ליחידה מבוחרת; מצד שני, היחידה המובחרת שלנו כנראה תבצע את המשימה שלה בהצלחה גם עם גליל וגם עם m-16 . מצד שלישי ייתכן שהייתרונות הקטנים של כל כלי (למשל, עמידות למים) הם מאד רלוונטיים. אבל זה נדיר. הרבה פעמים היתרונות הם לא פונקציונאליים - למשל נשק מסויים הוא יותר זול, יותר לוחמים מכירים אותו, יותר כיף לירות בו, או פשוט למפקד היחידה יש חיבה אישית לכיוון מסויים. גם זה חשוב, מפקד מרוצה הוא מפקד טוב.

אחרי התובנות הלא ממש עמוקות האלו, אפשר לחזור לדיון המקורי. קודם כל, ברור ש m-16 יותר טוב. שנית, לי יש חיבה אישית ל #C . כנראה בגלל שיצא לי לעבוד איתה לא מעט. יש לה כמה תכונות נחמדות שאין ב Java (יצא לי לעבוד גם ב Java. שתי השפות די קרובות) - למשל Properties , Attributes ו Events-delegates (לא שאין לתכונות האלו תחליף, פשוט התחליף הוא פחות נוח). אבל הייתרון העיקרי של #C ושל NET. הוא הספריות המוצלחות מאד שמגיעות עם החבילה, והתעוד המצויין.
חסרון רציני מאד גם של #C וגם של NET. הוא שממש קשה לכתוב את השם שלהם בעברית. הוא מתהפך. אין ספק שהיו לא מעט מנהלי פיתוח שהתחילו לכתוב מייל בסגנון "החלטתי שנכתוב את הפרוייקט ב C#" ואז ניסו לתקן את המייל במשך חצי שעה, ובסוף התייאשו ואמרו לעצמם, לעזאזל הכל, נכתוב אותו ב Java וזהו.
מה יותר טוב, גליל או m-16? 447524
לסי-שארפ יש יתרון גדול אחד על ג'אווה - אתה יכול לסנן בעזרתה אידיוטים בראיון עבודה. "אז אתה אומר שיש לך עשר שנות ניסיון עם סי-סולמית? אנחנו מצטערים, אתה overqualified. אל תיתן לדלת להסביר לך שהשפה לא קיימת עשר שנים בדרכך החוצה."
ראיון עבודה בחמש מערכות 447559
הנה קטעים מראיון עבודה שנערך היום במקום עבודתי.
משתתפים: אני, מראיין מתלמד (שותק רוב הזמן), מרואיין - ד"ר למדעי המחשב בתחום האלגוריתמים, בעל ניסיון מקצועי עשיר בתעשייה (לפי קוה"ח), אך עם טון דיבור ושפת גוף מלאי זילזול.

אתה אולי רוצה לתאר משהו שעשית?
מה למשל?
משהו...
יש הרבה דברים.
תבחר אחד...
אין משהו מיוחד.

איך פותרים את הבעייה?
יש את זה בספר של קנות'.

מה הסיבוכיות של הכנסה לעץ?
זה יוצא די הרבה.
כמה הרבה?
נו, אם הייתי יושב עם דף וחושב אז בטח הייתי אומר לך.
(לפניו היה מונחים דף ועט)

יש לך רעיון איך לגשת לזה?
גם את זה אתה יכול למצוא בספר של קנות'.
אני מנסה לכוון אותו ושואל לבסוף: נו, אז איך עושים את זה?
נו, זה שורה שתיים.
בכ"ז...?
יש שם And לוגי.
יפה! של מה עם מה?
בטח יש את זה בגוגל- אין טעם להמציא שוב את הגלגל.

(המערכה המסכמת כללה כתיבת קוד - שגוי לחלוטין)
ככה שלושת רבעי שעה, כדי שלפחות ירגיש שקיבל הזדמנות.
ראיון עבודה בחמש מערכות 447815
כמו שאתה מתאר אותו, אולי כדאי שתראיין אותי.
ראיון עבודה בחמש מערכות 447821
מה אתה יודע לעשות?
ראיון עבודה בחמש מערכות 447822
אני מכיר עוד ספרים מלבד זה של קנות' להגיד שהפתרון נמצא בוודאי בהם.
ראיון עבודה בחמש מערכות 447836
אתה בהחלט בכיוון!
אם בנוסף אתה גם טוב בשיחות מסדרון, שיטוטים באינטרנט, פלירטוטים עם המזכירה ולקיחת קרדיט על עבודה של אחרים - אנו זקוקים גם ליכולותיך הניהוליות.
ראיון עבודה בחמש מערכות 447840
כמה אתם משלמים? כדאי שתמהר, יש לי הצעה מתחרה ממקדונלד'ס.
הראיון הוא הרעיון 447856
משלמים? מי דיבר בכלל על כסף? כל הרעיון שמאחרי הקמת החברה היה מה שנקרא בבתי הספר למנהל עסקים "ראיונות מוכווני רווח": המערכות המפותחות בחברה מאופיינות, מתוכננות, ממומשות, נבדקות ומופעלות ע"י מרואיינים, כחלק ממבחני הקבלה לעבודה. המראיינים הם מועמדים לתפקיד "מנהל כ"א" וגם עלויות בניין אין, מאחר והראיונות מתבצעים בבתי קפה עם לפטופים.
אז למתי קבענו?
הראיון הוא הרעיון 447879
כמו כן, אין צורך במזכירה וטלפון. הראיונות מתואמים דרך תגובות באייל.
הראיון הוא הרעיון 448317
:-)
הראיון הוא הרעיון 448351
שמע, רק עכשיו עליתי על הפתיל הזה והחברה שלך נשמעת לי יוצאת מן הכלל. אם תתנו לי לפטופ, אשמח להיות מראיינת.
הראיון הוא הרעיון 448353
ייתנו לך להביא אחד מהבית, אבל תצטרכי להשיב אותו לחברה אחרי הראיון.
הראיון הוא הרעיון 448355
מראיינות אינן אמורות להשיב, אלא לשאול בלבד.
מה יותר טוב, גליל או m-16? 447528
אכן, כמעט ועברתי ל-#C, אבל אז גיליתי את רובי.

לא ציינתי שהדיון כאן הוא על העדפות אישיות ואני לא באמת מנסה לשכנע איש בעליונות אובייקטיבית, מה?
מה יותר טוב, גליל או m-16? 447530
לדעתי הדיון לגיטימי ומעניין, למרות שנבצר ממני לקחת בו חלק פעיל.
מה יותר טוב, גליל או m-16? 447574
הנה לינק משעשע שקשור בעקיפין לנושא.

טיזר: אין לנו מושג, אבל יש לנו כמה גרפים מאד מעניינים כמו: כמות ההיטים בגוגל פר שפה, כמות הצעות העבודה, כמות הצעות העבודה חלקי כמות ההיטים וכו' וכו'.

ואגב, נזכרתי במשפט של סטואי מהפרק האחרון של family guy שראיתי (נא לקרוא במבטא בריטי).
How can you say you don't like it, if you haven't really given it a chance?

לתשומת ליבו של הקורא אח של אייל.
מה יותר טוב, גליל או m-16? 447532
כשאני הייתי בצבא זה היה ברור, M-16 היה "מטאטא" של ג'ובניקים, וגליל זה נשק של הקרביים הקולים. כג'ובניק חזרתי הביתה בכל יום, והצלב שנאלצתי לשאת על גבי בכל ערב במשא המפרך היה הנשק הארוך, המסורבל והלא אטרקטיבי (לחיילות שלא מסתכלות עליך, ולנהגים שלא עוצרים לך). גם כשהתחלתי לתכנת זה היה ברור. היה פסקל בשביל ללמוד, C בשביל לעשות טריקים ובשביל לתחזק קוד שנכתב לפני שלוש שנים ויותר, C++ בשביל לעבוד על קוד חדש, וקובול בשביל בנקים ועורק. היום ג'ובניקים מסתובבים בלי נשק, צנחנים מסתובבים עם M-16, וכל מתכנת יודע 5 שפות.

C# זאת שפה שעובדת במערכת הפעלה אחת, של החברה שהמציאה אותה, לא?
מה יותר טוב, גליל או m-16? 447534
לפחות בתיאוריה לא (לא ברור לי מה קורה בפרקטיקה):

מה יותר טוב, גליל או m-16? 447538
(אבל M16 מקוצר)
מה יותר טוב, גליל או m-16? 447540
(אחרי יותר משנתיים עם M-16 ארוך באמת קיבלתי M-16 קצר. פתאום חיילות שלא ירקו לכיוון שלי ניסו להתחיל איתי. אבל אני כבר הייתי לפני שחרור וממש לא הייתי בקטע של ילדות מפגרות ששופטות אותך לפי סוג הנשק שלך)
מה יותר טוב, גליל או m-16? 447553
אני מקווה שאחרי כמעט 8 שנות נסיון אני ראוי להקרא מתכנת, אבל חוץ מהכרות לצורך קורסי חובה באוניברסיטה ובתיכון עם בייסיק, אסמבלר (8086), פסקל, ג'אווה ו++C, אני יודע למעשה רק שפה אחת.
מה יותר טוב, גליל או m-16? 447570
C# עובדת טוב במערכ(ו)ת הפעלה של החברה שהמציאה אותה.
ובנוסף, עובדת, בערך, על מע"ה אחרות:
הנוער של ימינו 447460
אם אתה רוצה משהו אלגנטי, אני חושב שאתה צריך לחוש ולמצוא את לוח המקשים עם כל הסימנים מיוחדים ולבדוק את שפת APL.
הנוער של ימינו 447472
עד כמה ש-APL היא שפה נהדרת, אני חושב ש-Malbolge [Wikipedia] מנצחת אותה בנוק-אאוט.
הנוער של ימינו 447474
(חרמפף, רק עכשיו ראיתי את תגובה 447123)

חזרה לעמוד הראשי המאמר המלא

מערכת האייל הקורא אינה אחראית לתוכן תגובות שנכתבו בידי קוראים