وابستگی های Firebase را به صورت ایستا یا پویا پیوند دهید

با شروع CocoaPods 1.9.0 و Firebase 7، می‌توانید انتخاب کنید که وابستگی‌های Firebase شما به‌عنوان چارچوب‌های ثابت یا پویا ساخته شوند. توصیه می کنیم از چارچوب های ثابت استفاده کنید مگر اینکه به رفتارهای کتابخانه پویا خاصی نیاز داشته باشید.

توجه داشته باشید که کتابخانه‌هایی که خارج از GitHub ایجاد شده‌اند، فقط می‌توانند به صورت ایستا حتی با CocoaPods 1.9.0 و نسخه‌های جدیدتر مرتبط شوند. در حال حاضر، این فهرست کتابخانه شامل AdMob ، Analytics ، Firebase ML و Performance Monitoring است. همه کانال‌های توزیع دیگر، از جمله فایل فشرده، مدیریت بسته سوئیفت، و کارتاژ فقط کتابخانه‌های پیوندی استاتیک را ارائه می‌کنند.

این سند دانش کاری پیوندهای پویا و استاتیک در پلتفرم‌های اپل را فرض می‌کند. اگر با این مفاهیم آشنا نیستید، به مستندات زیر نگاهی بیندازید:

از آنجایی که این سند به انواع پیوندهای کتابخانه مربوط می شود و نه بارگذاری بسته های منابع غیر قابل اجرا، اصطلاحات کتابخانه و چارچوب به جای یکدیگر استفاده می شوند.

پیوند استاتیک

کتابخانه‌هایی که به‌صورت ایستا پیوند داده شده‌اند، در زمان ساخت در برنامه شما قابل اجرا هستند. در نتیجه، فایل‌های شی موجود در کتابخانه استاتیک هنگام راه‌اندازی برنامه شما در آن وجود دارند و نیازی به حل شدن در زمان راه‌اندازی برنامه توسط پیوند دهنده پویا ندارند. در نتیجه، برنامه هایی که از پیوند استاتیک استفاده می کنند سریعتر راه اندازی می شوند. این به قیمت یک فایل اجرایی باینری / برنامه کمی بزرگتر تمام می شود، اگرچه باید توجه داشت که اندازه اجرایی بزرگتر با فقدان کتابخانه های پویای همراه جبران می شود.

می‌توانید با مشخص کردن صریح پیوند در Podfile خود، پیوند استاتیک وابستگی‌های Firebase را مجبور کنید:

# cocoapods >= 1.9.0
use_frameworks! :linkage => :static

پیوند پویا

کتابخانه‌های پیوندشده به‌صورت پویا در بسته نرم‌افزاری شما جدا از فایل اجرایی اصلی برنامه ذخیره می‌شوند و باید در زمان راه‌اندازی برنامه توسط پیوند دهنده پویا بارگیری شوند. فریمورک های اپل همگی به صورت پویا به هم مرتبط هستند تا اشتراک کد بین فرآیندها را فعال کنند. به طور مشابه، می توانید از چارچوب های پویا برای به اشتراک گذاری کد بین برنامه و اهداف برنامه افزودنی خود استفاده کنید. شما نمی توانید چارچوب های پویا را بین برنامه های جداگانه به اشتراک بگذارید، حتی اگر هر دو توسط یک توسعه دهنده امضا شده باشند.

اگر می خواهید از Firebase به عنوان وابستگی یک هدف چارچوب پویا استفاده کنید، همچنین باید Firebase را به صورت پویا پیوند دهید. در غیر این صورت با تعاریف کلاس تکراری در زمان اجرا برنامه خود مواجه خواهید شد. پیوند پویا رفتار پیش فرض با use_frameworks! ، اما همچنان می توانید به صراحت پیوند پویا را در پادفایل خود مشخص کنید:

# cocoapods >= 1.9.0
use_frameworks! :linkage => :dynamic

توجه داشته باشید که پیوند پویا ممکن است زمان راه اندازی برنامه شما را افزایش دهد، به خصوص اگر برنامه شما وابستگی های زیادی داشته باشد.

،

با شروع CocoaPods 1.9.0 و Firebase 7، می‌توانید انتخاب کنید که وابستگی‌های Firebase شما به‌عنوان چارچوب‌های ثابت یا پویا ساخته شوند. توصیه می کنیم از چارچوب های ثابت استفاده کنید مگر اینکه به رفتارهای کتابخانه پویا خاصی نیاز داشته باشید.

توجه داشته باشید که کتابخانه‌هایی که خارج از GitHub ایجاد شده‌اند، فقط می‌توانند به صورت ایستا حتی با CocoaPods 1.9.0 و نسخه‌های جدیدتر مرتبط شوند. در حال حاضر، این فهرست کتابخانه شامل AdMob ، Analytics ، Firebase ML و Performance Monitoring است. همه کانال‌های توزیع دیگر، از جمله فایل فشرده، مدیریت بسته سوئیفت، و کارتاژ فقط کتابخانه‌های پیوندی استاتیک را ارائه می‌کنند.

این سند دانش کاری پیوندهای پویا و استاتیک در پلتفرم‌های اپل را فرض می‌کند. اگر با این مفاهیم آشنا نیستید، به مستندات زیر نگاهی بیندازید:

از آنجایی که این سند به انواع پیوندهای کتابخانه مربوط می شود و نه بارگذاری بسته های منابع غیر قابل اجرا، اصطلاحات کتابخانه و چارچوب به جای یکدیگر استفاده می شوند.

پیوند استاتیک

کتابخانه‌هایی که به‌صورت ایستا پیوند داده شده‌اند، در زمان ساخت در برنامه شما قابل اجرا هستند. در نتیجه، فایل‌های شی موجود در کتابخانه استاتیک هنگام راه‌اندازی برنامه شما در آن وجود دارند و نیازی به حل شدن در زمان راه‌اندازی برنامه توسط پیوند دهنده پویا ندارند. در نتیجه، برنامه هایی که از پیوند استاتیک استفاده می کنند سریعتر راه اندازی می شوند. این به قیمت یک فایل اجرایی باینری / برنامه کمی بزرگتر تمام می شود، اگرچه باید توجه داشت که اندازه اجرایی بزرگتر با فقدان کتابخانه های پویای همراه جبران می شود.

می‌توانید با مشخص کردن صریح پیوند در Podfile خود، پیوند استاتیک وابستگی‌های Firebase را مجبور کنید:

# cocoapods >= 1.9.0
use_frameworks! :linkage => :static

پیوند پویا

کتابخانه‌های پیوندشده به‌صورت پویا در بسته نرم‌افزاری شما جدا از فایل اجرایی اصلی برنامه ذخیره می‌شوند و باید در زمان راه‌اندازی برنامه توسط پیوند دهنده پویا بارگیری شوند. فریمورک های اپل همگی به صورت پویا به هم مرتبط هستند تا اشتراک کد بین فرآیندها را فعال کنند. به طور مشابه، می توانید از چارچوب های پویا برای به اشتراک گذاری کد بین برنامه و اهداف برنامه افزودنی خود استفاده کنید. شما نمی توانید چارچوب های پویا را بین برنامه های جداگانه به اشتراک بگذارید، حتی اگر هر دو توسط یک توسعه دهنده امضا شده باشند.

اگر می خواهید از Firebase به عنوان وابستگی یک هدف چارچوب پویا استفاده کنید، همچنین باید Firebase را به صورت پویا پیوند دهید. در غیر این صورت با تعاریف کلاس تکراری در زمان اجرا برنامه خود مواجه خواهید شد. پیوند پویا رفتار پیش فرض با use_frameworks! ، اما همچنان می توانید به صراحت پیوند پویا را در پادفایل خود مشخص کنید:

# cocoapods >= 1.9.0
use_frameworks! :linkage => :dynamic

توجه داشته باشید که پیوند پویا ممکن است زمان راه اندازی برنامه شما را افزایش دهد، به خصوص اگر برنامه شما وابستگی های زیادی داشته باشد.