উত্তর:
তাদের প্ল্যাটফর্মের ধরণ বলা হয় এবং তাদের অর্থ হ'ল কোটলিন জানেন না যে সেই মানটি হতে পারে বা নাও পারে null
এবং এটি নির্ধারণযোগ্য কি না তা সিদ্ধান্ত নেওয়া আপনার পক্ষে।
সংক্ষেপে, সমস্যাটি হ'ল জাভা থেকে আসা কোনও রেফারেন্স শূন্য হতে পারে এবং ডিজাইন অনুসারে কোটলিন নাল-নিরাপদ থাকায় ব্যবহারকারীকে প্রতিটি জাভা মান বাতিল করতে বা নিরাপদ কলগুলি ব্যবহার করতে বাধ্য করেছিল (
?.
) অথবা নাল-নথী (!!
)। খাঁটি কোটলিন বিশ্বে যারা খুব সুবিধাজনক বৈশিষ্ট্যযুক্ত তারা কোটলিন / জাভা সেটিংয়ে আপনাকে প্রায়শই ব্যবহার করতে হয় তখন বিপর্যয়ে পরিণত হয়।এই কারণেই আমরা জাভা আন্তঃবিদ্যুতের বিষয়টি বিবেচনা করে কোটলিনের টাইপ সিস্টেমটিকে আরও স্বচ্ছন্দ করে তুলেছি: এখন জাভা থেকে আসা রেফারেন্সগুলিতে বিশেষভাবে চিহ্নিত চিহ্ন রয়েছে - কোটলিন ব্লগ
প্ল্যাটফর্ম ধরণের জন্য এটি স্বরলিপি :
T!
অর্থ " T
বা T?
"
T
" T!
বা T?
" অর্থ নয়
T
"অ-অযোগ্য" তৈরি করা হয়েছিল, এবং
প্রকারের সাথে চিহ্নিত একটি প্রকারকে প্ল্যাটফর্ম টাইপ!
বলা হয় যা জাভা থেকে আগত একটি প্রকার এবং সম্ভবত এটি হতে পারে । এটা কি ডিফল্টরূপে Kotlin কম্পাইলার infers যখন জাভা কলিং (অধিকাংশ মৌলিক ক্ষেত্রে, জাভা পদ্ধতি করা যেতে পারে সটীক এই কাছাকাছি পেতে)। আপনার অবশ্যই প্ল্যাটফর্মের প্রকারগুলি হ্রাসযোগ্য প্রকার হিসাবে হ্যান্ডেল করা উচিত , যদি না আপনি অবশ্যই জানেন যে নির্দিষ্ট এপিআই আর ফিরে আসবে না । সংকলকটি প্ল্যাটফর্মের প্রকারগুলিকে নাল এবং অ-নাল উভয় প্রকারের ভেরিয়েবলগুলিতে বরাদ্দ করতে দেয়।null
null
প্ল্যাটফর্ম প্রকারের জন্য স্বরলিপি
[...]
T!
মানে "T or T?
" [...]
আপনি প্ল্যাটফর্মের প্রকারগুলিকে " অজানা নালাগ্রতার ধরণ " হিসাবে উল্লেখ করতে পারেন । এটিও জেনে রাখা জরুরী যে আপনি নিজের প্রকারের জন্য উদ্দীপনা চিহ্নযুক্ত ধরণটি ব্যবহার করতে পারবেন না, এটি কোটলিন সিনট্যাক্সের অংশ নয়, এটি কেবল একটি স্বরলিপি ।
একক বিস্ময়কর চিহ্ন দিয়ে শেষ হওয়া ধরণের নাম বা শ্রেণীর নামগুলিকে কোটলিনে প্ল্যাটফর্ম প্রকারগুলি!
বলা হয় । আপনি পুরানো জাভা কোড সহ কোটলিনে কাজ করার সময় আপনি এগুলি খুঁজে পাবেন যাতে ননযোগ্যতার তথ্য থাকে না।
উদাহরণ স্বরূপ:
@Nullable String
জাভা মধ্যে String?
কোটলিন হিসাবে বিবেচনা করা হয়।
@NotNull String
জাভা মধ্যে String
কোটলিন হিসাবে বিবেচনা করা হয়।
String
জাভাতে টিকা ছাড়াই String!
কোটলিন হিসাবে বিবেচিত ।
আপনি একটি প্ল্যাটফর্ম ধরণের সাথে কাজ করতে পারেন হয় নাল বা নন-নাল হিসাবে। সংকলক আপনাকে এই ধরণের সমস্ত পদ্ধতি কল করার অনুমতি দেবে। এগুলি কীভাবে ব্যবহার করবেন এটি আপনার দায়িত্ব। যদি আপনি জানেন যে মানটি নালাগুলি হতে পারে তবে এর উপর পদ্ধতিগুলি বলার আগে আপনাকে নাল দিয়ে তুলনা করা উচিত। যদি আপনি জানেন যে এটি নাল নয়, তবে আপনি সরাসরি এটি ব্যবহার করতে পারেন তবে জাভা হিসাবে, যদি আপনার শূন্যতা সম্পর্কে ধারণা অনুমান করা যায় তবে আপনি ব্যতিক্রম পাবেন।
নোট করুন যে আপনি কোটলিন কোডে প্ল্যাটফর্মের প্রকারগুলি ঘোষণা করতে পারবেন না, সেগুলি কেবল জাভা কোড থেকে আসে।
কোটলিন কোডে জাভা পদ্ধতিগুলিকে ওভাররাইড করার সময়, আপনার কাছে প্যারামিটারগুলি ঘোষণা করতে হবে এবং প্রকারগুলি বাতিল বা অ-নাল হিসাবে প্রেরণ করতে হবে। আপনার এটিকে বিজ্ঞতার সাথে চয়ন করতে হবে, কারণ আপনি যদি প্যারামিটারগুলি নন-নাল করার সিদ্ধান্ত নেন তবে কোটলিন সংকলক এই নন-নাল প্যারামিটারগুলির জন্য নন-নাল জেনারেশন তৈরি করে। এবং পরের বার যখন আপনি এই কোটলিন কোডটি জাভা থেকে ফিরে অ্যাক্সেস করবেন এবং আপনি একটি নাল মান পাস করবেন, আপনি ব্যতিক্রম পাবেন।
আশা করি যা প্ল্যাটফর্মের প্রকারগুলি সম্পর্কে আপনার সমস্ত সন্দেহ দূর করতে সহায়তা করে।
আমি এটি কয়েকবার দেখেছি বিশেষত জাভা এপিআই ব্যবহার করার সময়
হিসাবে s1m0nw1 দ্বারা উল্লিখিত, T!
মানে T or T?
। পরের প্রশ্নটি: কী T?
? এটি https://kotlinlang.org/docs/references/null-safety.html এ সুন্দরভাবে নথিভুক্ত করা হয়েছে । Kotlin নির্দিষ্ট উপাদানের হতে করার অনুমতি দেয় না null
, যেমন String
, জাভা অসদৃশ
নালগুলিকে অনুমতি দেওয়ার জন্য, আমরা স্ট্রিং লিখিত নালিং স্ট্রিং হিসাবে একটি ভেরিয়েবল ঘোষণা করতে পারি ?:
var b: String? = "abc" b = null // ok
[...]
b?.length
এটি খ.শক্তি ফেরত দেয় যদি বি শূন্য না হয় এবং অন্যথায় নাল হয়। এই প্রকাশের ধরণটি
Int?
।
কোটলিনে প্ল্যাটফর্ম ধরণ থেকে অংশ :
কোনও
Person?
প্রকারকে alচ্ছিক (উদাঃ ) হিসাবে স্পষ্টভাবে উল্লেখ করার পাশাপাশি কোটলিন আমাদের অন্য একটি জন্তুটির সাথে উপস্থাপন করেন, যাকে বলা হয়Platform Type
, পরিবর্তে একক বিস্মৃত চিহ্ন দিয়ে নির্দিষ্ট করে (যেমনPerson!
)। জাভা-র মতো নাল-অনিরাপদ প্ল্যাটফর্মগুলি থেকে কোড অ্যাক্সেস করার সময়, এই ধারণাটি সামঞ্জস্যতার কারণে তৈরি করা হয়েছে। এটি প্রায়শই ক্ষেত্রে হয় যে জাভা লাইব্রেরি ব্যবহার করার সময়, অনেকগুলি পদ্ধতি ফিরে আসেSomeType!
, যেহেতু কোটলিন সংকলক ফলাফলটি অগ্রহণযোগ্য হয় বা না হয় তা নির্ধারণ করতে পারে না।
উদাহরণ স্বরূপ:
(Mutable)Collection<T>!
কেবলমাত্র নিম্নলিখিতটির অর্থ: " টি এর জাভা সংগ্রহটি পরিবর্তনীয় হতে পারে বা নাও পারে, আড়ালযোগ্য বা নাও হতে পারে "।
আশাকরি এটা সাহায্য করবে.
platform types