অ্যান্ড্রয়েড গ্রেডল প্লাগইন 3.0.0 এবং পরবর্তীতে সমস্ত জাভা 7 ভাষার বৈশিষ্ট্য এবং জাভা 8 ভাষার বৈশিষ্ট্যগুলির একটি উপসেট সমর্থন করে যা প্ল্যাটফর্ম সংস্করণ অনুসারে পরিবর্তিত হয়। Android Gradle প্লাগইন 4.0.0 এবং উচ্চতর ব্যবহার করে আপনার অ্যাপ তৈরি করার সময়, আপনি আপনার অ্যাপের জন্য ন্যূনতম API স্তরের প্রয়োজন ছাড়াই কিছু Java 8 ভাষা API ব্যবহার করতে পারেন।
এই পৃষ্ঠাটি আপনি ব্যবহার করতে পারেন এমন Java 8 ভাষার বৈশিষ্ট্যগুলি বর্ণনা করে, কীভাবে সেগুলি ব্যবহার করার জন্য আপনার প্রকল্পটি সঠিকভাবে কনফিগার করবেন এবং আপনার সম্মুখীন হতে পারে এমন কোনো পরিচিত সমস্যা। Java 8 ভাষার বৈশিষ্ট্যগুলির একটি ওভারভিউয়ের জন্য নিম্নলিখিত ভিডিওটি দেখুন।
অ্যান্ড্রয়েড গ্রেডল প্লাগইন নির্দিষ্ট জাভা 8 ভাষার বৈশিষ্ট্য এবং তৃতীয় পক্ষের লাইব্রেরিগুলি ব্যবহার করার জন্য অন্তর্নির্মিত সমর্থন প্রদান করে যা তাদের ব্যবহার করে। ডিফল্ট টুলচেইন বাইটকোড ট্রান্সফরমেশনের মাধ্যমে নতুন ভাষার বৈশিষ্ট্য প্রয়োগ করে, যাকে বলা হয় desugar
, D8/R8 ক্লাস ফাইলের DEX কোডে সংকলনের অংশ হিসেবে, চিত্র 1-এ দেখানো হয়েছে।
জাভা 8 ভাষা বৈশিষ্ট্য সমর্থন (অ্যান্ড্রয়েড গ্রেডল প্লাগইন 3.0.0+)
সমর্থিত জাভা 8 ভাষা বৈশিষ্ট্য ব্যবহার শুরু করতে:
- Android Gradle প্লাগইনটি 3.0.0 বা উচ্চতর সংস্করণে আপডেট করুন ।
- জাভা 8 ভাষার বৈশিষ্ট্য ব্যবহার করে এমন প্রতিটি মডিউলের জন্য (হয় তার সোর্স কোডে বা নির্ভরতার মাধ্যমে), মডিউলের
build.gradle
বাbuild.gradle.kts
ফাইলটি নীচে দেখানো হিসাবে আপডেট করুন:
কোটলিন
android { ... // Configure only for each module that uses Java 8 // language features (either in its source code or // through dependencies). compileOptions { sourceCompatibility = JavaVersion.VERSION_1_8 targetCompatibility = JavaVersion.VERSION_1_8 } // For Kotlin projects kotlinOptions { jvmTarget = "1.8" } }
গ্রোভি
android { ... // Configure only for each module that uses Java 8 // language features (either in its source code or // through dependencies). compileOptions { sourceCompatibility JavaVersion.VERSION_1_8 targetCompatibility JavaVersion.VERSION_1_8 } // For Kotlin projects kotlinOptions { jvmTarget = "1.8" } }
অ্যান্ড্রয়েড গ্রেডল প্লাগইন 3.0.0 এবং উচ্চতর ব্যবহার করে আপনার অ্যাপ তৈরি করার সময়, প্লাগইনটি জাভা 8 ভাষার সমস্ত বৈশিষ্ট্য সমর্থন করে না। নিম্নলিখিত ভাষার বৈশিষ্ট্যগুলি যে কোনও API স্তরে উপলব্ধ:
জাভা 8 ভাষার বৈশিষ্ট্য | নোট |
---|---|
ল্যাম্বডা এক্সপ্রেশন | অ্যান্ড্রয়েড ল্যাম্বডা এক্সপ্রেশনের সিরিয়ালাইজেশন সমর্থন করে না। |
পদ্ধতির উল্লেখ | |
টীকা টাইপ করুন | টাইপ টীকা তথ্য শুধুমাত্র কম্পাইল সময়ে পাওয়া যায়, রানটাইমে নয়। প্ল্যাটফর্মটি API স্তর 24 এবং তার নীচে TYPE সমর্থন করে, কিন্তু ElementType.TYPE_USE বা ElementType.TYPE_PARAMETER নয়। |
ডিফল্ট এবং স্ট্যাটিক ইন্টারফেস পদ্ধতি | |
পুনরাবৃত্তি করা টীকা |
এই জাভা 8 ভাষার বৈশিষ্ট্যগুলি ছাড়াও, অ্যান্ড্রয়েড গ্রেডল প্লাগইন সংস্করণ 3.0.0 এবং উচ্চতর সমস্ত অ্যান্ড্রয়েড এপিআই স্তরে সম্পদের সাথে try
জন্য সমর্থন প্রসারিত করে।
Desugar MethodHandle.invoke
বা MethodHandle.invokeExact
সমর্থন করে না। যদি আপনার সোর্স কোড বা আপনার মডিউল নির্ভরতাগুলির মধ্যে একটি এই পদ্ধতিগুলির মধ্যে একটি ব্যবহার করে, তাহলে আপনাকে minSdkVersion 26
বা উচ্চতর নির্দিষ্ট করতে হবে। অন্যথায়, আপনি নিম্নলিখিত ত্রুটি পাবেন:
Dex: Error converting bytecode to dex:
Cause: signature-polymorphic method called without --min-sdk-version >= 26
কিছু ক্ষেত্রে, আপনার মডিউলটি লাইব্রেরি নির্ভরতার অন্তর্ভুক্ত থাকা সত্ত্বেও invoke
বা invokeExact
পদ্ধতি ব্যবহার নাও করতে পারে। minSdkVersion 25
বা তার নিচের লাইব্রেরি ব্যবহার করা চালিয়ে যেতে, অব্যবহৃত পদ্ধতিগুলি সরাতে কোড সঙ্কুচিত করা সক্ষম করুন । যদি এটি কাজ না করে, একটি বিকল্প লাইব্রেরি ব্যবহার করার কথা বিবেচনা করুন যা অসমর্থিত পদ্ধতিগুলি ব্যবহার করে না।
জাভা 8+ ল্যাঙ্গুয়েজ ফিচারগুলি অ্যান্ড্রয়েড গ্রেডল প্লাগইন 3.0.0 এবং উচ্চতর ডিসুগার করে এবং পুরানো অ্যান্ড্রয়েড রিলিজে ব্যবহারের জন্য কোনও অতিরিক্ত ক্লাস এবং API (যেমন java.util.stream.*
) উপলব্ধ করে না। আংশিক Java API desugaring-এর জন্য সমর্থন Android Gradle প্লাগইন 4.0.0 বা উচ্চতর থেকে পাওয়া যায়, যেমনটি নিম্নলিখিত বিভাগে বর্ণিত হয়েছে।
Java 8+ API desugaring সমর্থন (Android Gradle Plugin 4.0.0+)
আপনি যদি অ্যান্ড্রয়েড গ্রেডল প্লাগইন 4.0.0 বা উচ্চতর ব্যবহার করে আপনার অ্যাপ তৈরি করেন, তাহলে প্লাগইনটি আপনার অ্যাপের জন্য ন্যূনতম API স্তরের প্রয়োজন ছাড়াই বেশ কয়েকটি জাভা 8 ভাষার API ব্যবহার করার জন্য সমর্থন প্রসারিত করে। অ্যান্ড্রয়েড গ্রেডল প্লাগইন 7.4.0 বা উচ্চতর, ডিসুগারেড লাইব্রেরি 2.0.0 বা উচ্চতর সহ বেশ কয়েকটি জাভা 11 ভাষা API-গুলি উপলব্ধ।
পুরানো প্ল্যাটফর্ম সংস্করণগুলির জন্য এই অতিরিক্ত সমর্থন সম্ভব কারণ প্লাগইন 4.0.0 এবং উচ্চতর ডিসুগারিং ইঞ্জিনকে জাভা ল্যাঙ্গুয়েজ এপিআইগুলিকেও প্রসারিত করে। আপনি স্ট্যান্ডার্ড ল্যাঙ্গুয়েজ এপিআই অন্তর্ভুক্ত করতে পারেন যেগুলি শুধুমাত্র সাম্প্রতিক অ্যান্ড্রয়েড রিলিজে (যেমন java.util.streams
) উপলব্ধ ছিল যেগুলি Android এর পুরানো সংস্করণগুলিকে সমর্থন করে৷
Android Gradle প্লাগইন 4.0.0 বা উচ্চতর ব্যবহার করে আপনার অ্যাপ তৈরি করার সময় নিম্নলিখিত API গুলি সমর্থিত:
- অনুক্রমিক স্ট্রীম (
java.util.stream
) -
java.time
এর একটি উপসেট -
java.util.function
-
java.util.{Map,Collection,Comparator}
- ঐচ্ছিক (
java.util.Optional
,java.util.OptionalInt
, এবংjava.util.OptionalDouble
) এবং কিছু নতুন ক্লাস -
java.util.concurrent.atomic
এ কিছু সংযোজন (AtomicInteger
,AtomicLong
, এবংAtomicReference
এ নতুন পদ্ধতি) -
ConcurrentHashMap
(Android 5.0 এর জন্য বাগ ফিক্স সহ)
Android Gradle প্লাগইন 7.4.0 বা উচ্চতর, অতিরিক্ত Java 11 API সমর্থিত যেমন java.nio.file
প্যাকেজের একটি উপসেট।
সমর্থিত API-এর সম্পূর্ণ তালিকার জন্য, desugaring-এর মাধ্যমে উপলব্ধ Java 8+ API এবং desugaring-এর মাধ্যমে উপলব্ধ Java 11+ API-গুলি দেখুন।
এই ভাষা APIগুলিকে সমর্থন করার জন্য, প্লাগইনটি একটি পৃথক DEX ফাইল কম্পাইল করে যাতে অনুপস্থিত APIগুলির একটি বাস্তবায়ন থাকে এবং এটি আপনার অ্যাপে অন্তর্ভুক্ত করে৷ ডিসুগারিং প্রক্রিয়া রানটাইমে এই লাইব্রেরিটি ব্যবহার করার পরিবর্তে আপনার অ্যাপের কোড পুনরায় লিখবে।
Android প্ল্যাটফর্মের যেকোনো সংস্করণে এই ভাষা APIগুলির জন্য সমর্থন সক্ষম করতে:
- Android Gradle প্লাগইনটি 4.0.0 (বা উচ্চতর) তে আপডেট করুন ।
- আপনার অ্যাপ মডিউলের
build.gradle
বাbuild.gradle.kts
ফাইলে নিম্নলিখিতগুলি অন্তর্ভুক্ত করুন:
কোটলিন
android { defaultConfig { // Required when setting minSdkVersion to 20 or lower multiDexEnabled = true } compileOptions { // Flag to enable support for the new language APIs // For AGP 4.1+ isCoreLibraryDesugaringEnabled = true // For AGP 4.0 // coreLibraryDesugaringEnabled = true // Sets Java compatibility to Java 8 sourceCompatibility = JavaVersion.VERSION_1_8 targetCompatibility = JavaVersion.VERSION_1_8 } } dependencies { // For AGP 7.4+ coreLibraryDesugaring("com.android.tools:desugar_jdk_libs:2.0.3") // For AGP 7.3 // coreLibraryDesugaring("com.android.tools:desugar_jdk_libs:1.2.3") // For AGP 4.0 to 7.2 // coreLibraryDesugaring("com.android.tools:desugar_jdk_libs:1.1.9") }
গ্রোভি
android { defaultConfig { // Required when setting minSdkVersion to 20 or lower multiDexEnabled true } compileOptions { // Flag to enable support for the new language APIs coreLibraryDesugaringEnabled true // Sets Java compatibility to Java 8 sourceCompatibility JavaVersion.VERSION_1_8 targetCompatibility JavaVersion.VERSION_1_8 } } dependencies { // For AGP 7.4+ coreLibraryDesugaring 'com.android.tools:desugar_jdk_libs:2.0.3' // For AGP 7.3 // coreLibraryDesugaring 'com.android.tools:desugar_jdk_libs:1.2.3' // For AGP 4.0 to 7.2 // coreLibraryDesugaring 'com.android.tools:desugar_jdk_libs:1.1.9' }
মনে রাখবেন যে আপনাকে একটি লাইব্রেরি মডিউলের build.gradle
বা build.gradle.kts
ফাইলে পূর্ববর্তী কোড স্নিপেট অন্তর্ভুক্ত করতে হতে পারে যদি:
লাইব্রেরি মডিউলের ইনস্ট্রুমেন্টেড পরীক্ষাগুলি এই ভাষা APIগুলি ব্যবহার করে (হয় সরাসরি বা লাইব্রেরি মডিউল বা এর নির্ভরতার মাধ্যমে)। এটি যাতে অনুপস্থিত APIগুলি আপনার ইনস্ট্রুমেন্টেড টেস্ট APK এর জন্য প্রদান করা হয়।
আপনি বিচ্ছিন্নভাবে লাইব্রেরি মডিউলে লিন্ট চালাতে চান। এটি লিন্টকে ভাষা API-এর বৈধ ব্যবহার সনাক্ত করতে এবং মিথ্যা সতর্কতা প্রতিবেদন করা এড়াতে সহায়তা করার জন্য।
এছাড়াও মনে রাখবেন যে API ডিসুগারিং সঙ্কুচিত হওয়ার সাথে মিলিত হতে পারে, তবে শুধুমাত্র R8 সঙ্কুচিত করার সময়।
সংস্করণ
নিম্নলিখিত সারণীটি Java 8+ API লাইব্রেরির সংস্করণ এবং ন্যূনতম Android Gradle প্লাগইন সংস্করণ দেখায় যা প্রতিটি সংস্করণ সমর্থন করে:
সংস্করণ | ন্যূনতম Android Gradle প্লাগইন সংস্করণ |
---|---|
1.1.9 | 4.0.0 |
1.2.3 | 7.3.0 |
2.0.3 | 7.4.0-আলফা10 |
জাভা 8+ এপিআই লাইব্রেরির সংস্করণগুলির বিশদ বিবরণের জন্য, desugar_jdk_libs
GitHub সংগ্রহস্থলে CHANGELOG.md ফাইলটি দেখুন।