রুবি ইচ্ছাকৃতভাবে আপনার কাছ থেকে কিছু ত্রুটি এবং ব্যতিক্রম লুকিয়ে রাখবে।
কখনও কখনও এটি দরকারী হতে পারে৷
যেমন Kernel#loop
ব্যবহার করার সময় ব্লক সহ পদ্ধতি, loop
StopIteration
হলে থামবে ব্যতিক্রম উত্থাপিত হয়৷
কিন্তু অন্য সময় এটি আপনার ডিবাগিং সেশনগুলিকে অনেক কঠিন করে তুলতে পারে৷
আসুন কিছু উদাহরণ দেখি!
লুকানো ব্যতিক্রম:তুলনামূলক মডিউল + <=> পদ্ধতি
প্রথম উদাহরণে Comparable
জড়িত মডিউল এবং <=>
পদ্ধতি।
এখানে উদাহরণ দেওয়া হল :
class MyObject attr_accessor :value include Comparable def initialize(value) @value = value end def <=>(other) raise ArgumentError, "can't compare #{other.class} with #{self.class}" unless other.is_a?(MyObject) value <=> other.valuee end end mo1 = MyObject.new(10) mo2 = MyObject.new(10) p mo1 == mo2
আসুন এই উদাহরণ সম্পর্কে কথা বলি।
প্রথম :
আমাদের MyObject
নামে একটি ক্লাস আছে , একটি attr_accessor value
সহ , এবং Comparable
এর অন্তর্ভুক্তি মডিউল, যা তুলনা পদ্ধতি যোগ করে (যেমন ==
, <
, >
) আমাদের ক্লাসে।
এই তুলনা পদ্ধতিগুলি <=>
-এর উপর ভিত্তি করে পদ্ধতি।
ঠিক যেমন গণনাযোগ্য পদ্ধতিগুলি each
এর উপর ভিত্তি করে পদ্ধতি।
তারপর :
আমরা দুটি বস্তু তৈরি করছি (MyObject.new
) একই মান সহ (10
)।
লক্ষ্য করুন যে তাদের একই মান থাকলেও তারা ভিন্ন বস্তু , এটি গুরুত্বপূর্ণ।
এখন যদি আমরা এই দুটি বস্তু mo1
তুলনা করি &mo2
আমরা false
পাই …
কেন?
কারণ আমাদের <=>
এ একটি ত্রুটি আছে পদ্ধতি, কিন্তু রুবি সেই ত্রুটি লুকাচ্ছে!
ঘনিষ্ঠভাবে দেখুন...
আপনি ত্রুটি খুঁজে পেতে পারেন?
আপনি যদি এটি ভাল কাজ খুঁজে পাওয়া যায়! না হলে ঠিক আছে 🙂
এটি এখানে :
value <=> other.valuee
এই valuee
দেখুন ?
দেখা যাচ্ছে আমাদের একটি টাইপো আছে!
সাধারণত আমরা একটি NoMethodError
পাব ব্যতিক্রম এবং আমরা খুব দ্রুত সমস্যা কি তা জানতে হবে. কিন্তু এই উদাহরণে নয়।
ভাল খবর হল রুবি 2.3 থেকে এটি পরিবর্তিত হয়েছে। আপনি এখন ত্রুটি দেখতে পাচ্ছেন কারণ এটি আর লুকানো নেই।
আপনি যদি এখনও পুরানো রুবি সংস্করণগুলি চালান তবে আপগ্রেড করার আরেকটি কারণ৷
৷লুকানো ব্যতিক্রম:সংখ্যাসূচক বস্তু + জবরদস্তি পদ্ধতি
লুকানো ব্যতিক্রমের আরেকটি উদাহরণ হল Numeric
বস্তু (Float
, Integer
) প্লাস coerce
পদ্ধতি।
এখানে একটি উদাহরণ আছে :
class MyObject attr_accessor :value def initialize(value) @value = value end def +(other) other = MyObject.new(other) if other.kind_of?(Numeric) value + other.value end def coerce(other) mo = MyObject.new mo.valuee = other [mo, self] end end mo1 = MyObject.new 10 mo2 = MyObject.new 10 p mo1 + mo2 # 20 p mo1 + 20 # 30
এটি আরেকটি MyObject
ক্লাস, কিন্তু নতুন পদ্ধতির সাথে, +
&coerce
.
coerce
পদ্ধতিটি আপনাকে দুটি বেমানান প্রকারের সাথে কাজ করার অনুমতি দেয় এবং তাদের একই প্রকারে রূপান্তর করতে দেয় যাতে তারা একসাথে কাজ করতে পারে।
এই ক্ষেত্রে আমাদের ক্লাস কিছু সাংখ্যিক মানের প্রতিনিধিত্ব করে, যা কয়েক সেকেন্ডের সংখ্যা, একটি মূল্য বা এরকম কিছু হতে পারে...
এবং আমরা এই ধরনের অপারেশন করতে সক্ষম হতে চাই :
mo1 + 20 20 + mo1
প্রথমটি (mo1 + 20
) সহজ কারণ আমরা +
নিয়ন্ত্রণ করি আমাদের ক্লাসে পদ্ধতি।
কিন্তু Integer
সম্পর্কে কি ক্লাস?
আমরা পূর্ণসংখ্যার +
পরিবর্তন করতে পারি এটি বাস্তবায়ন করার পদ্ধতি, কিন্তু এটি সম্ভবত একটি ভাল ধারণা নয় 🙂
সমাধান?
coerce
প্রয়োগ করুন আপনার নিজের ক্লাসে পদ্ধতি।
এক জিনিস +
Integer
এ পদ্ধতি আপনার বস্তুটি এই পদ্ধতিটি প্রয়োগ করে কিনা তা পরীক্ষা করা হবে এবং যদি এটি করে তবে এটি কল করবে।
এখন, এই বিভাগের শুরুতে কোড উদাহরণ মনে রাখবেন?
যদি আমরা এটি করার চেষ্টা করি :
20 + mo1
আমরা 30
দেখতে চাই , কারণ mo1
এর মান হল 10
. কিন্তু আমরা যা দেখি তা হল:
MyObject can't be coerced into Fixnum
আগের মতোই একই সমস্যা!
coerce
এর ভিতরে একটি ত্রুটি আমাদের থেকে লুকিয়ে রাখা হচ্ছে পদ্ধতি।
এটি:mo.valuee = other
আবার আমাদের একটি টাইপো আছে, কিন্তু ত্রুটিটি যা বলছে তা নয়!
MyObject can't be coerced into Fixnum
আপনার জন্য আমার কাছে সুসংবাদ আছে, রুবি 2.5-এ এই আচরণটি পরিবর্তিত হচ্ছে, তাই এটি আরেকটি লুকানো ত্রুটি দূর হবে তাই আপনাকে এটি নিয়ে চিন্তা করতে হবে না৷
সারাংশ
আপনি দেখতে পাচ্ছেন কেন আপনি ব্যতিক্রমগুলি লুকিয়ে রাখতে চান তার ভাল উদাহরণ। আপনি আমার বই রুবি ডিপ ডাইভ থেকে ব্যতিক্রম সম্পর্কে আরও জানতে পারেন৷
৷আপনি যদি এই পোস্টটি আপনার বন্ধুদের সাথে শেয়ার করেন তাহলে আমি কৃতজ্ঞ হব যাতে আরও বেশি লোক এটি দেখতে পারে৷
পড়ার জন্য ধন্যবাদ!