דילוג לתוכן
  • דף הבית
  • קטגוריות
  • פוסטים אחרונים
  • משתמשים
  • חיפוש
  • חוקי הפורום
כיווץ
תחומים

תחומים - פורום חרדי מקצועי

💡 רוצה לזכור קריאת שמע בזמן? לחץ כאן!
  1. דף הבית
  2. תכנות
  3. References ב-PHP

References ב-PHP

מתוזמן נעוץ נעול הועבר תכנות
42 פוסטים 7 כותבים 981 צפיות
  • מהישן לחדש
  • מהחדש לישן
  • הכי הרבה הצבעות
התחברו כדי לפרסם תגובה
נושא זה נמחק. רק משתמשים עם הרשאות מתאימות יוכלו לצפות בו.
  • yossizY מנותק
    yossizY מנותק
    yossiz
    כתב ב נערך לאחרונה על ידי yossiz
    #11

    עזבו את ה"מטה-שיח", יש למישהו הסבר?

    @chagold אמר בReferences ב-PHP:

    ג. 2 השורות האחרונות השתנו בדוגמא שלי.

    צודק, לא שמתי לב.

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

    יופי, הסברת מצויין את המושג של references. זה אני מכיר כבר.

    אבל זה עדיין לא מסביר לי את התופעה.

    הרי בהעתקה רגילה של array לדוגמה:

    <?php
    $arr = [1,2,3];
    $arr2 = $arr;
    $arr2[0] = 99;
    print_r($arr);
    

    ה-array השני מקבל העתקים של הערכים של הראשון ולא references.

    אבל בקוד שאני שואל עליו רואים כמה דברים מוזרים מאוד.

    א. רואים שאם עשית reference למשתנה, זה משנה את המשתנה המקורי! שהוא כבר נהיה בעצמו reference. זה משהו מאוד לא צפוי שהשמה תשנה את הצד הימני.

    ב. רואים ש-reference הוא סוג חדש של משתנה! זה לא מוזכר בתיעוד. אני חשבתי שהוא פשוט עוד שם/ידית לאותו ערך בזכרון (כמו references ב-++C למי שמכיר). הם עצמם מסבירים את זה כמו hardlink במערכות קבצים של unix. אבל זה לא! כי שם hardlink הוא בדיוק קובץ רגיל, רק שהוא מצביע קובץ שכבר יש לו מצביע אחר במערכת הקבצים. אבל כאן זו משתנה עם התנהגות שונה!
    מה שהכי מוזר שבינתיים נתקלתי בהתנהגות שונה אך ורק בנוגע להעתקת array. האם יש עוד מקומות שבהם reference מתנהג בצורה שונה ממשתנה רגיל?

    ג. רואים שלמרות שהשמה מ-reference בד"כ עושה העתקה, ולא reference. לדוגמה:

    <?php
    $a = 1;
    $b = &$a;
    $c = $a;
    // או
    $c = $b;
    $c = 2;
    print "$a, $b, $c";
    

    בדוגמה הנ"ל, למרות ש-‎$a ו-b$ הם משתנים מסוג reference עדיין העתקה שלהם יתן משתנה חדש ולא reference.

    למרות זאת, בהעתקה של מערך (שכזכור גם עושה העתקה ולא reference) אם יש איבר במערך שהוא מסוג reference אז המערך החדש תקבל reference.

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

    למישהו יש שום לימוד זכות על שפה מוזרה זאת????

    📧 יוסי@מייל.קום | 🌎 בלוג | ☕ קפה

    nigunN תגובה 1 תגובה אחרונה
    3
    • yossizY מנותק
      yossizY מנותק
      yossiz
      כתב ב נערך לאחרונה על ידי
      #12

      אגב, למי שעוד לא יודע. reference לא דומה כלל וכלל למצביע ב-C ושפות אחרות. זה יותר דומה ל-reference ב-++C.

      📧 יוסי@מייל.קום | 🌎 בלוג | ☕ קפה

      תגובה 1 תגובה אחרונה
      1
      • nigunN מנותק
        nigunN מנותק
        nigun
        השיב לyossiz ב נערך לאחרונה על ידי
        #13

        @yossiz
        מצאתי דיון בנושא דומה.
        נראה שהמסקנה של מפתחי השפה היא "זה לא באג זה פיצ'ר".

        מייל: nigun@duck.com

        yossizY תגובה 1 תגובה אחרונה
        2
        • yossizY מנותק
          yossizY מנותק
          yossiz
          השיב לnigun ב נערך לאחרונה על ידי yossiz
          #14

          @nigun אוף! זה לא קשור כלל.

          אבל דוקא כאשר:
          @yossiz אמר בReferences ב-PHP:

          (יש לי עוד המון דוגמאות).

          התכוונתי גם לזה בתוכם.

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

          📧 יוסי@מייל.קום | 🌎 בלוג | ☕ קפה

          תגובה 1 תגובה אחרונה
          2
          • nigunN מנותק
            nigunN מנותק
            nigun
            השיב לyossiz ב נערך לאחרונה על ידי nigun
            #15

            @yossiz אמר בReferences ב-PHP:

            אם אני הגעתי לזה תוך 24 שעות, כל אחד היה אמור להגיע לזה תוך כמה שנים. לא?

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

            מייל: nigun@duck.com

            תגובה 1 תגובה אחרונה
            4
            • yossizY מנותק
              yossizY מנותק
              yossiz
              כתב ב נערך לאחרונה על ידי
              #16

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

              רואים ש-reference הוא סוג חדש של משתנה! זה לא מוזכר בתיעוד.

              מתוך הספר phpintenals

              While from a userland perspective references are not a separate type, internally references are represented as a wrapper around another zval, that can be shared by multiple places.

              כנראה שהנסיון לבודד את ה-userland מפרטי מימוש לא בדיוק הצליח...

              📧 יוסי@מייל.קום | 🌎 בלוג | ☕ קפה

              תגובה 1 תגובה אחרונה
              4
              • yossizY מנותק
                yossizY מנותק
                yossiz
                כתב ב נערך לאחרונה על ידי yossiz
                #17

                עדכון:
                https://www.phpinternalsbook.com/php7/zvals/references.html#reference-semantics:~:text=Intuitively this behavior is wrong

                סוף סוף הסבר להתנהגות (והודאה שזה מרגיש לא נכון)

                אגב, לא הבנתי את הטעם השני. (הראשון נראה לי שהבנתי אבל אני לא מסכים...)

                📧 יוסי@מייל.קום | 🌎 בלוג | ☕ קפה

                תגובה 1 תגובה אחרונה
                4
                • nigunN מנותק
                  nigunN מנותק
                  nigun
                  השיב לyossiz ב נערך לאחרונה על ידי nigun
                  #18

                  @yossiz אמר בReferences ב-PHP:

                  @nigun אמר בReferences ב-PHP:

                  איך אתה מגיע לנישות האלו כשאתה מתחיל ללמוד שפה?

                  אם אני הגעתי לזה תוך 24 שעות, כל אחד היה אמור להגיע לזה תוך כמה שנים. לא?

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

                  מייל: nigun@duck.com

                  yossizY תגובה 1 תגובה אחרונה
                  5
                  • yossizY מנותק
                    yossizY מנותק
                    yossiz
                    השיב לnigun ב נערך לאחרונה על ידי
                    #19

                    @nigun זה כלום, אין פה סיפור ארוך.
                    רציתי ללמוד את השפה.
                    נתקלתי במושג של reference.
                    הסתכלתי בתיעוד הרשמי.
                    אגב, בתיעוד של PHP תמיד תסתכל בהערות (רק 2/3 העליונים) של הקהילה. יש שם דברים יקרי ערך.
                    והנה בהערה הראשונה נתקלתי בזה.
                    התפלאתי מאוד.
                    המשך הסיפור כולו בפוסטים בנושא זה.

                    📧 יוסי@מייל.קום | 🌎 בלוג | ☕ קפה

                    תגובה 1 תגובה אחרונה
                    5
                    • yossizY מנותק
                      yossizY מנותק
                      yossiz
                      כתב ב נערך לאחרונה על ידי yossiz
                      #20

                      טוב, הגעתי פחות או יותר לסוף הדרך... 🤸 🚥
                      שאלתי כאן: https://chat.stackoverflow.com/transcript/message/51562731#51562731
                      ונעניתי על ידי אחד מהמפתחים העקריים של PHP בזה"ל:

                      I see you have discovered the joy that is references

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

                      📧 יוסי@מייל.קום | 🌎 בלוג | ☕ קפה

                      nigunN תגובה 1 תגובה אחרונה
                      3
                      • yossizY מנותק
                        yossizY מנותק
                        yossiz
                        כתב ב נערך לאחרונה על ידי
                        #21

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

                        נו נו, פל קל אמרנו?

                        📧 יוסי@מייל.קום | 🌎 בלוג | ☕ קפה

                        תגובה 1 תגובה אחרונה
                        4
                        • nigunN מנותק
                          nigunN מנותק
                          nigun
                          השיב לyossiz ב נערך לאחרונה על ידי
                          #22

                          @yossiz
                          אז סתם יצא כאן לעז על משתמשי השפה
                          גם אחרי עשרות שנים מפתח PHP ממוצע לא אמור להיכנס לפינה הזאת.

                          מייל: nigun@duck.com

                          chagoldC yossizY 2 תגובות תגובה אחרונה
                          0
                          • chagoldC מנותק
                            chagoldC מנותק
                            chagold
                            השיב לnigun ב נערך לאחרונה על ידי chagold
                            #23

                            @nigun אמר בReferences ב-PHP:

                            @yossiz
                            אז סתם יצא כאן לעז על משתמשי השפה
                            גם אחרי עשרות שנים מפתח PHP ממוצע לא אמור להיכנס לפינה הזאת.

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

                            בשבילי זה סיבה לנסות לא להיכנס לפינה ששמה הפניות.

                            תגובה 1 תגובה אחרונה
                            1
                            • yossizY מנותק
                              yossizY מנותק
                              yossiz
                              השיב לnigun ב נערך לאחרונה על ידי yossiz
                              #24

                              @nigun אמר בReferences ב-PHP:

                              אז סתם יצא כאן לעז על משתמשי השפה

                              לא דיברתי מטוב ועד רע על משתמשי השפה.
                              ולגבי השפה עצמה, שפה שיש בה פינות אפלות כאלו היא באמת שפה גרועה.

                              📧 יוסי@מייל.קום | 🌎 בלוג | ☕ קפה

                              תגובה 1 תגובה אחרונה
                              1
                              • yossizY מנותק
                                yossizY מנותק
                                yossiz
                                כתב ב נערך לאחרונה על ידי yossiz
                                #25

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

                                📧 יוסי@מייל.קום | 🌎 בלוג | ☕ קפה

                                תגובה 1 תגובה אחרונה
                                4
                                • yossizY מנותק
                                  yossizY מנותק
                                  yossiz
                                  כתב ב נערך לאחרונה על ידי
                                  #26

                                  עוד כתבה על הנושא:
                                  http://schlueters.de/blog/archives/125-Do-not-use-PHP-references.html

                                  טוב, נראה לי שממש מיציתי את הנושא... מספיק כבר! 🤢

                                  📧 יוסי@מייל.קום | 🌎 בלוג | ☕ קפה

                                  תגובה 1 תגובה אחרונה
                                  6
                                  • yossizY מנותק
                                    yossizY מנותק
                                    yossiz
                                    כתב ב נערך לאחרונה על ידי yossiz
                                    #27

                                    אופסס... כנראה שלא מיציתי את הנושא מספיק... 🤢
                                    מצאתי שיש קומפיילר וסביבת הרצה עבור PHP שממומש בדוטנט.
                                    ויקרא שמו בישראל Peachpie.
                                    (אגב, הם טוענים שהמימוש בדוטנט מביא שיפורים משמעותיים בביצועים. זה כבר בשל מספיק להריץ וורדפרס ועוד כמה אפליקציות גדולות - עם ביצועים יותר טובים ממנוע ה-PHP המקורי)
                                    כמובן שדבר ראשון רצתי לבדוק את המימוש שלהם ל-references, והנה יש להם באג 😂
                                    נפתח issue בגיטהאב שלהם...

                                    עריכה: פתחתי issue
                                    https://github.com/peachpiecompiler/peachpie/issues/906

                                    📧 יוסי@מייל.קום | 🌎 בלוג | ☕ קפה

                                    תגובה 1 תגובה אחרונה
                                    4
                                    • שואףש מנותק
                                      שואףש מנותק
                                      שואף
                                      כתב ב נערך לאחרונה על ידי שואף
                                      #28

                                      @yossiz אהבתי התשובה שענו לך https://chat.stackoverflow.com/transcript/message/51562731#51562731

                                      @yossizahn It's a bit like the answer to "how do you avoid being eaten by a shark?" Step 1) don't go swimming where there are sharks.
                                      
                                      

                                      ליצירת קשר: admin@i-call.me

                                      הידד! גישה למייל גם בלי מחשב ואינטרנט!

                                      yossizY תגובה 1 תגובה אחרונה
                                      3
                                      • yossizY מנותק
                                        yossizY מנותק
                                        yossiz
                                        השיב לשואף ב נערך לאחרונה על ידי
                                        #29

                                        @שואף מתכנת PHP דגול כמותך, זה כל מה שיש לך להוסיף בנושא? 🙂
                                        סתם... נראה שבאמת לא אמורים להשתמש ב-references בלי סיבה מספקת.

                                        📧 יוסי@מייל.קום | 🌎 בלוג | ☕ קפה

                                        שואףש תגובה 1 תגובה אחרונה
                                        2
                                        • שואףש מנותק
                                          שואףש מנותק
                                          שואף
                                          השיב לyossiz ב נערך לאחרונה על ידי
                                          #30

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

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

                                          ליצירת קשר: admin@i-call.me

                                          הידד! גישה למייל גם בלי מחשב ואינטרנט!

                                          תגובה 1 תגובה אחרונה
                                          6

                                          • 1
                                          • 2
                                          • 3
                                          בא תתחבר לדף היומי!
                                          • התחברות

                                          • אין לך חשבון עדיין? הרשמה

                                          • התחברו או הירשמו כדי לחפש.
                                          • פוסט ראשון
                                            פוסט אחרון
                                          0
                                          • דף הבית
                                          • קטגוריות
                                          • פוסטים אחרונים
                                          • משתמשים
                                          • חיפוש
                                          • חוקי הפורום