הגרסה הראשונה של אלפא של Room 3.0 יצאה! Room 3.0 היא גרסה ראשית של הספרייה שכוללת שינויים משמעותיים. היא מתמקדת ב-Kotlin Multiplatform (KMP) ומוסיפה תמיכה ב-JavaScript וב-WebAssembly (WASM) בנוסף לתמיכה הקיימת ב-Android, ב-iOS וב-JVM desktop.
בפוסט הזה בבלוג נפרט את השינויים שעלולים לשבור את התאימות, נסביר את ההיגיון מאחורי Room 3.0 ונציג את הפעולות השונות שאפשר לבצע כדי לעבור מ-Room 2.0.
שינויי תוכנה שעלולים לגרום לכשלים
גרסה 3.0 של Room כוללת את שינויי ה-API הבאים שעלולים לגרום לכשל:
- הפסקת התמיכה ב-SupportSQLite APIs: גרסה 3.0 של Room נתמכת באופן מלא על ידי androidx.sqlite driver APIs. ממשקי ה-API של SQLiteDriver תואמים ל-KMP, והסרת התלות של Room ב-API של Android מפשטת את משטח ה-API של Android, כי היא מונעת מצב שבו יש שני קצוות עורפיים אפשריים.
- אין יותר יצירת קוד Java: גרסה Room 3.0 יוצרת קוד Kotlin בלבד. הגישה הזו תואמת לפרדיגמה המתפתחת של Kotlin-first, אבל היא גם מפשטת את בסיס הקוד ואת תהליך הפיתוח, ומאפשרת לבצע איטרציות מהר יותר.
- התמקדות ב-KSP: אנחנו מפסיקים גם את התמיכה ב-Java Annotation Processing (AP) וב-KAPT. Room 3.0 הוא מעבד KSP (עיבוד סמלים של Kotlin) בלבד, שמאפשר עיבוד טוב יותר של בסיסי קוד של Kotlin בלי להיות מוגבל על ידי שפת Java.
- קודם קורוטינות: ב-Room 3.0 נעשה שימוש בקורוטינות של Kotlin, ולכן ממשקי ה-API שלו מבוססים על קורוטינות. שגרות המשנה הן מסגרת אסינכרונית שתואמת ל-KMP, והפיכת Room לאסינכרוני מטבעו היא דרישה קריטית לתמיכה בפלטפורמות אינטרנט.
חבילה חדשה
כדי למנוע בעיות תאימות עם הטמעות קיימות של Room 2.x ועם ספריות עם יחסי תלות טרנזיטיביים ב-Room (לדוגמה, WorkManager), Room 3.0 נמצא בחבילה חדשה, מה שאומר שיש לו גם מזהי קבוצה וארטיפקט חדשים של Maven. לדוגמה, androidx.room:room-runtime הפך ל-androidx.room3:room3-runtime, ושיעורים כמו androidx.room.RoomDatabase ימוקמו עכשיו ב-androidx.room3.RoomDatabase.
Kotlin ו-Coroutines First
ב-Room 3.0, שבו כבר לא מתבצעת יצירה של קוד Java, נדרשים גם KSP ומהדר Kotlin, גם אם בסיס הקוד שמבצע אינטראקציה עם Room הוא ב-Java. מומלץ להשתמש בפרויקט מרובה מודולים שבו השימוש ב-Room מרוכז, ואפשר להחיל את התוסף Kotlin Gradle ואת KSP בלי להשפיע על שאר בסיס הקוד.
בנוסף, ב-Room 3.0 נדרשות קורוטינות, ובאופן ספציפי, פונקציות DAO צריכות להיות מושהות, אלא אם הן מחזירות סוג תגובתי, כמו Flow. ב-Room 3.0 אי אפשר לחסום פונקציות של DAO. במאמר Coroutines on Android מוסבר איך מתחילים לשלב שגרות המשך באפליקציה.
מיגרציה ל-SQLiteDriver APIs
בגלל המעבר מ-SupportSQLite, האפליקציות יצטרכו לעבור ל-SQLiteDriver APIs. המיגרציה הזו חיונית כדי ליהנות מכל היתרונות של Room 3.0, כולל שימוש בספריית SQLite שצורפה דרך BundledSQLiteDriver. אתם יכולים להתחיל במיגרציה ל-Driver APIs כבר היום באמצעות Room 2.7.0 ואילך. מומלץ מאוד להימנע משימוש נוסף ב-SupportSQLite. אם מעבירים את השילובים של Room לממשקי SQLiteDriver API, המעבר ל-Room 3.0 קל יותר כי השינוי בחבילה כולל בעיקר עדכון של הפניות לסמלים (ייבוא) ועשוי לדרוש שינויים מינימליים במיקומי הקריאה.
סקירה קצרה של ממשקי ה-API של SQLiteDriver זמינה במאמרי העזרה של SQLiteDriver APIs.
לפרטים נוספים על העברה של Room לשימוש בממשקי SQLiteDriver API, אפשר לעיין במסמכי התיעוד הרשמיים בנושא העברה מ-SupportSQLite.
Room SupportSQLite wrapper
אנחנו מבינים שלא תמיד אפשר להסיר את SupportSQLite מכל הפרויקטים באופן מיידי. כדי להקל על המעבר הזה, בגרסה 2.8.0 של Room, הגרסה האחרונה בסדרת Room 2.0, הושק ארטיפקט חדש בשם androidx.room:room-sqlite-wrapper. הארטיפקט הזה מציע API לתאימות שמאפשר להמיר RoomDatabase ל-SupportSQLiteDatabase, גם אם ממשקי ה-API של SupportSQLite במסד הנתונים הושבתו בגלל התקנה של SQLiteDriver. האפשרות הזו מספקת פתרון זמני למפתחים שצריכים עוד זמן כדי להעביר את בסיס הקוד שלהם באופן מלא. הארטיפקט הזה ממשיך להתקיים ב-Room 3.0 כ-androidx.room3:room3-sqlite-wrapper כדי לאפשר את המעבר ל-Room 3.0, תוך המשך תמיכה בשימוש קריטי ב-SupportSQLite.
לדוגמה, אפשר להחליף קריאות של roomDatabase.openHelper.writableDatabase בקריאות של roomDatabase.getSupportWrapper(), ויינתן wrapper גם אם מתבצעת קריאה של setDriver() ב-builder של Room.
פרטים נוספים זמינים בתיעוד של room-sqlite-wrapper.
תמיכה ב-Room וב-SQLite באינטרנט
התמיכה ב-Kotlin Multiplatform מכוונת ל-JS ול-WasmJS, ומביאה איתה כמה מהשינויים המשמעותיים ביותר ב-API. בפרט, הרבה ממשקי API ב-Room 3.0 הם פונקציות השהיה, כי התמיכה המתאימה באחסון אינטרנט היא אסינכרונית. ממשקי ה-API של SQLiteDriver עודכנו גם הם כדי לתמוך באינטרנט, ומנהל התקן אסינכרוני חדש לאינטרנט זמין בכתובת androidx.sqlite:sqlite-web. זהו מנהל התקן מבוסס Web Worker שמאפשר לשמור את מסד הנתונים במערכת הקבצים הפרטית של המקור (OPFS).
פרטים נוספים על הגדרת Room בדפדפן זמינים בהערות על הגרסה Room 3.0.
סוגי החזרה של DAO בהתאמה אישית
ב-Room 3.0 נוספה האפשרות להוסיף שילובים בהתאמה אישית ל-Room, בדומה ל-RxJava ול-Paging. באמצעות API חדש של הערות בשם @DaoReturnTypeConverter, אפשר ליצור שילוב משלכם כך שהקוד שנוצר על ידי Room יהיה נגיש בזמן הריצה. כך אפשר להשתמש בפונקציות @Dao עם סוגי החזרה מותאמים אישית בלי לחכות שצוות Room יוסיף את התמיכה. השילובים הקיימים מועברים לשימוש בפונקציונליות הזו, ולכן מי שמסתמך עליה יצטרך להוסיף את הממירים להגדרות של @Database או @Dao.
לדוגמה, הממיר Paging ימוקם בארטיפקט androidx.room3:room3-paging ויקרא PagingSourceDaoReturnTypeConverter. בינתיים, עבור LiveData, הכלי להמרת קבצים נמצא בandroidx.room3:room3-livedata והשם שלו הוא LiveDataDaoReturnTypeConverter.
פרטים נוספים זמינים בקטע בנושא ממירים של סוג החזרה של DAO בנתוני הגרסה של Room 3.0.
מצב תחזוקה של Room 2.x
הפיתוח של Room יתמקד ב-Room 3, ולכן הגרסה הנוכחית Room 2.x תעבור למצב תחזוקה. המשמעות היא שלא יפותחו תכונות חדשות, אבל עדיין יפורסמו תיקוני באגים ועדכונים של יחסי תלות (patch releases) (גרסאות 2.8.1, 2.8.2 וכו'). הצוות מחויב לעבודה הזו עד שהחדר 3 יהיה יציב.
מחשבות לסיכום
אנחנו מאוד מתרגשים מהפוטנציאל של Room 3.0 ומההזדמנויות שהוא פותח לאקוסיסטם של Kotlin. אנחנו ממשיכים במסע הזה, אז כדאי לעקוב אחרי עדכונים נוספים.
להמשך הקריאה
-
חדשות על מוצרים
אנחנו ב-Google Play מחויבים לספק למשתמשים את החוויה הכי טובה שאפשר, ולוודא שלמפתחים יש את הכלים והגמישות הדרושים כדי להצליח.
Paul Feng • משך הקריאה: 3 דקות
-
חדשות על מוצרים
בשנה שעברה השקנו אימות מפתחים ב-Android כדי לחזק את אבטחת הסביבה העסקית ולמנוע מגורמים זדוניים להסתתר מאחורי אנונימיות כדי לפרסם אפליקציות מזיקות.
Matthew Forsythe • משך הקריאה: 2 דקות
-
חדשות על מוצרים
מממשקי שכבות רבודים ועד סביבות סוחפות לחלוטין, מערכת Android XR מתרחבת במהירות, ומכשיר Samsung Galaxy XR כבר זמין היום.
Stevan Silva, Vinny DaSilva • משך הקריאה: 3 דקות
כדאי תמיד להיות בעניינים
רוצים לקבל טיפים עדכניים לפיתוח Android ישירות לאימייל כל שבוע?