-
רשום שיטות מחלקות
Object
equals()
hashCode()
toString()
getClass()
notify()
notifyAll()
wait()
wait(long timeOut)
wait(long timeOut, int nanos)
-
מדוע דרושים
equals
ושיטותhashCode
?משמש להשוואת אובייקטים.
מטרת השיטה
equals
היא לקבוע האם אובייקטים זהים מבחינה פנימית על ידי השוואה בין התוכן הפנימי של האובייקטים. זהequals
עובד לאט, תחילה משווים קודי הגיבוב של האובייקטים, ואם קודי הגיבוב שווים, מתבצעת בדיקה מולequals
-
מה קורה אם תעקוף שווה אבל לא תעקוף
hashCode
?בתחילה
hashCode
, מספר אקראי.equals
אוספים ב-Java תמיד מחפשים/משווים אותם באמצעות השיטה לפני השוואת אובייקטים באמצעותhashCode()
. ואם לאובייקטים זהים יש שוניםhashCode
, אז האובייקטים ייחשבו שונים - פשוט לא ניתן יהיה להשוות באמצעותםequals
. -
מדוע השיטות
wait
,notify
,notifyAll
?לפעמים בתוכנית יכול להיות מצב שבו שרשור הכניס גוש קוד
synchronized
, חסם את המוניטור ולא יכול לעבוד יותר, בגלל חלק מהנתונים עדיין חסרים: לדוגמה, הקובץ שעליו לעבד עדיין לא נטען או משהו כזה. הומצאה שיטה כדי לפתור בעיה זוwait()
. קריאה לשיטה זו גורמת לשרשור לשחרר את המוניטור ו"להשהות".כדי לבטל את ההשהיה, נעשה שימוש בשיטות
notify
.notifyAll
השיטהnotify
"משחררת" חוט אקראי אחד, השיטהnotifyAll
- כל החוטים "קפואים" של מוניטור נתון. -
איך לשכפל אובייקט בצורה נכונה?
שני סוגי שיבוט.
כדי לשכפל אובייקט ברירת מחדל:
- הוסף ממשק
Cloneable
לכיתה שלך - עוקף את השיטה
clone
וקרא למימוש הבסיס בה:
class Point implements Cloneable { int x; int y; public Object clone() { return super.clone(); } }
או שאתה יכול לכתוב את יישום השיטה
clone
בעצמך:class Point { int x; int y; public Object clone() { Point point = new Point(); point.x = this.x; point.y = this.y; return point; } }
- הוסף ממשק
-
מדוע נדרשת השיטה
finalize()
וכיצד היא פועלת?אם אתה זוכר, זו
finalize()
שיטה מיוחדת שנקראת על חפץ לפני שהאספן משמיד אותו.המטרה העיקרית של שיטה זו היא לשחרר משאבים חיצוניים משומשים שאינם Java: סגירת קבצים, זרמי I/O וכו'.
finalize()
עובד לא יציב.שיטה זו אינה עומדת בציפיות המונחות ממנה. מכונת ה-Java יכולה לעכב הרס של אובייקט, כמו גם קריאה של שיטה,
finalize
כל עוד היא רוצה. יתר על כן, זה לא מבטיח ששיטה זו תיקרא בכלל. בהרבה מצבים, לשם "אופטימיזציה" זה לא נקרא. -
מה ההבדל
final
,finally
,finalize
?final
- משנה- לא ניתן לשנות שדות, שיטות מוחלף
- כיתות לא ניתנות בירושה
- משנה זה חל רק על מחלקות, שיטות ומשתנים (גם משתנים מקומיים)
- ארגומנטים של שיטה המסומנים כקריאה
final
בלבד; ניסיון לשנות אותם יגרום לשגיאת קומפילציה. - Переменные
final
не инициализируются по умолчанию, им необходимо явно присвоить meaning при объявлении or в конструкторе, иначе – ошибка компиляции - Если final переменная содержит ссылку на an object, an object может быть изменен, но переменная всегда будет ссылаться на тот же самый an object
- Также это справедливо и для массивов, потому что массивы являются an objectми, – массив может быть изменен, а переменная всегда будет ссылаться на тот же самый массив
- Если класс объявлен
final
иabstract
(взаимоисключающие понятия), произойдет ошибка компиляции - Так How
final
класс не может наследоваться, его методы никогда не могут быть переопределены
finally
— блок в связкеtry-catch-finally
, code в котором выполнится независимо от того вылетело ли исключение в блокеtry
or нет. Используется для освобождения ресурсов.finalize
— метод в классеObject
см 6. -
What такое
try-with-resources
?Это специальная конструкция
try
, называемаяtry-with-resources
, в которой Обрати внимание – послеtry
следуют круглые скобки, где объявляются переменные и создаются an objectы. Эти an objectы можно использовать внутри блокаtry
, обозначенного скобками{}
. Когда выполнение команд блокаtry
закончится, независимо от того – нормально оно закончилось or было исключение, для an object, созданного внутри круглых скобок()
, будет вызван методclose()
; -
Чем отличаются методы
wait(1000)
иsleep(1000)
?sleep()
приостанавливает поток на указанное. состояние меняется на TIMED_WAITING, по истечению — RUNNABLEwait()
меняет состояние потока на WAITINGможет быть вызвано только у an object владеющего блокировкой, в противном случае выкинется исключение IllegalMonitorStateException. при срабатывании метода блокировка отпускается, что позволяет продолжить работу другим потокам ожидающим захватить ту же самую блокировку . в случае
wait(int)
с аргументом состояние будет TIMED_WAITING -
В чем отличие
i++
и++i
?++i
,i
сначала увеличивается на 1, затем участвует в выражении.i++
,i
сначала участвует в выражении, затем увеличивается на 1.
GO TO FULL VERSION