হাস্কেলের ধরণের পরীক্ষক যুক্তিসঙ্গত হচ্ছে। সমস্যাটি হ'ল আপনি যে লাইব্রেরিটি ব্যবহার করছেন তার লেখকরা কিছু করেছেন ... কম যুক্তিসঙ্গত।
সংক্ষিপ্ত উত্তরটি হ'ল: হ্যাঁ, 10 :: (Float, Float)
যদি কোনও উদাহরণ থাকে তবে তা পুরোপুরি কার্যকর Num (Float, Float)
। সংকলকের বা ভাষার দৃষ্টিকোণ থেকে এটি সম্পর্কে "খুব ভুল" কিছুই নেই। এটি সংখ্যাগত আক্ষরিক কী করে তা আমাদের স্বজ্ঞাততার সাথে বর্গক্ষেত্র নয়। যেহেতু আপনি যে ধরণের ত্রুটি করেছেন তার ধরণের সিস্টেমটি আপনি অভ্যস্ত, সুতরাং আপনি ন্যায়সঙ্গতভাবে অবাক এবং হতাশ!
Num
উদাহরণস্বরূপ এবং fromInteger
সমস্যা
আপনি অবাক হলেন যে সংকলক গ্রহণ করে 10 :: Coord
, যেমন 10 :: (Float, Float)
। এটি ধরে নেওয়া যুক্তিসঙ্গত যে সংখ্যাসূচক অক্ষরগুলিকে 10
"সংখ্যাসূচক" প্রকারের অনুমান করা হবে। বাক্সের বাইরে, সাংখ্যিক লিটারেল ব্যাখ্যা করা যেতে পারে যেমন Int
, Integer
, Float
, অথবা Double
। সংখ্যাগুলির একটি দ্বিগুণ, অন্য কোনও প্রসঙ্গ নয়, এই চার প্রকারের সংখ্যাটি যেভাবে একটি সংখ্যা বলে মনে হয় না। আমরা যে বিষয়ে কথা না Complex
।
ভাগ্যক্রমে বা দুর্ভাগ্যক্রমে, তবে, হাস্কেল একটি খুব নমনীয় ভাষা। মানটি নির্দিষ্ট করে যে কোনও পূর্ণসংখ্যার আক্ষরিক মতোকে 10
ব্যাখ্যা করা হবে fromInteger 10
, যা টাইপ করে Num a => a
। সুতরাং এটির জন্য উদাহরণ লিখেছে এমন কোনও ধরণের 10
হিসাবে অনুমান করা যায়। আমি এটি আরও উত্তরে আরেকটি উত্তরে ব্যাখ্যা করি ।Num
সুতরাং আপনি যখন আপনার প্রশ্ন পোস্ট করেছেন, একজন অভিজ্ঞ হাস্কেলর তত্ক্ষণাত স্পষ্ট করে দিয়েছিলেন যে 10 :: (Float, Float)
গ্রহণযোগ্য হওয়ার জন্য , এর মতো Num a => Num (a, a)
উদাহরণ থাকতে হবে বা Num (Float, Float)
। এর মধ্যে এরকম কোনও উদাহরণ নেই Prelude
, সুতরাং এটি অন্য কোথাও সংজ্ঞায়িত করা উচিত। প্যাকেজটি ব্যবহার করে :i Num
আপনি খুব তাড়াতাড়ি চিহ্নিত করেছেন gloss
।
প্রতিশব্দ এবং এতিম দৃষ্টান্ত টাইপ করুন
তবে এক মিনিট ধরে রাখুন। আপনি gloss
এই উদাহরণে কোনও ধরণের ব্যবহার করছেন না ; উদাহরণটি gloss
আপনাকে প্রভাবিত করেছিল কেন ? উত্তর দুটি ধাপে আসে।
প্রথমত, কীওয়ার্ডের সাথে প্রবর্তিত কোনও প্রকারের সমার্থক শব্দটি type
কোনও নতুন ধরণের তৈরি করে না । আপনার মডিউলে, লেখার Coord
জন্য কেবল সংক্ষিপ্তকরণ (Float, Float)
। একইভাবে Graphics.Gloss.Data.Point
, Point
মানে (Float, Float)
। অন্য কথায়, আপনার Coord
এবং gloss
এর Point
আক্ষরিক সমতুল্য।
সুতরাং gloss
রক্ষণাবেক্ষণকারীরা যখন লিখতে পছন্দ করেছেন instance Num Point where ...
, তারা আপনার Coord
টাইপটিকে একটি উদাহরণও তৈরি করেছেন Num
। এটি instance Num (Float, Float) where ...
বা এর সমতুল্য instance Num Coord where ...
।
(ডিফল্টরূপে, হাস্কেল টাইপ প্রতিশব্দটিকে শ্রেণীর উদাহরণ হিসাবে মঞ্জুরি দেয় না uth gloss
লেখকদের ভাষা এক্সটেনশনের একটি জোড়া সক্ষম করতে হবে TypeSynonymInstances
এবং FlexibleInstances
উদাহরণটি লিখতে হবে))
দ্বিতীয়ত, এটি আশ্চর্যজনক কারণ এটি একটি অনাথ উদাহরণ , উদাহরণস্বরূপ একটি ঘোষণার instance C A
যেখানে উভয়ই C
এবং A
অন্যান্য মডিউলগুলিতে সংজ্ঞায়িত। এখানে এটা কারণ প্রতিটি অংশ জড়িত বিশেষ করে কুটিল আছে, অর্থাত Num
, (,)
এবং Float
থেকে আসে Prelude
এবং সর্বত্র সুযোগ হতে পারে।
আপনার প্রত্যাশাটি এটিতে Num
সংজ্ঞায়িত Prelude
, এবং টিপলস এবং Float
সংজ্ঞায়িত করা হয় Prelude
, সুতরাং এই তিনটি জিনিস কীভাবে কাজ করে সে সম্পর্কে সমস্ত কিছু সংজ্ঞায়িত হয় Prelude
। সম্পূর্ণ ভিন্ন মডিউল আমদানি করলে কেন কিছু পরিবর্তন হবে? আদর্শভাবে এটি হবে না, তবে এতিম দৃষ্টান্তগুলি সেই স্বজ্ঞাতাকে ভঙ্গ করে।
(নোট করুন যে জিএইচসি অনাথ ঘটনার বিষয়ে সতর্ক করেছে - gloss
বিশেষত লেখকরা সেই সতর্কবাণীকে ছাড়িয়ে গেছে That এটি একটি লাল পতাকা উত্থাপন করা উচিত ছিল এবং ডকুমেন্টেশনে কমপক্ষে একটি সতর্কতা জাগানো উচিত ছিল।)
শ্রেণীর উদাহরণগুলি বিশ্বব্যাপী এবং লুকানো যায় না
তদুপরি, শ্রেণীর উদাহরণগুলি বিশ্বব্যাপী : আপনার মডিউল থেকে ট্রান্সজিটিভ আমদানি করা কোনও মডিউলে সংজ্ঞায়িত কোনও উদাহরণ প্রসঙ্গত থাকতে পারে এবং উদাহরণ রেজুলেশন করার সময় টাইপচেকারের কাছে উপলব্ধ। এটি বৈশ্বিক যুক্তিটিকে সুবিধাজনক করে তোলে, কারণ আমরা (সাধারণত) ধরে নিতে পারি যে কোনও শ্রেণির ফাংশন (+)
কোনও নির্দিষ্ট ধরণের জন্য সর্বদা একই থাকে। তবে এটিরও অর্থ হ'ল স্থানীয় সিদ্ধান্তগুলির বিশ্বব্যাপী প্রভাব রয়েছে; শ্রেণীর উদাহরণ সংজ্ঞায়িত অদলবদলভাবে ডাউনস্ট্রিম কোডের প্রেক্ষাপটকে পরিবর্তন করে, মডিউল সীমানার পিছনে মুখোশ বা গোপন করার কোনও উপায় ছাড়াই।
আপনি আমদানি তালিকা ব্যবহার করতে পারবেন না দৃষ্টান্ত আমদানি এড়াতে । একইভাবে, আপনি যে মডিউলগুলি সংজ্ঞায়িত করেছেন তা থেকে রফতানির ঘটনা এড়াতে পারবেন না।
এটি হ্যাস্কেল ভাষা ডিজাইনের একটি সমস্যাযুক্ত এবং বহুল আলোচিত অঞ্চল। এই reddit থ্রেডে সম্পর্কিত সমস্যাগুলির একটি আকর্ষণীয় আলোচনা রয়েছে । উদাহরণস্বরূপ, উদাহরণস্বরূপ, দৃশ্যমানতা নিয়ন্ত্রণের অনুমতি দেওয়ার বিষয়ে এডওয়ার্ড কেমেটের মন্তব্য দেখুন: "আপনি যে কোডগুলি লিখেছেন তার প্রায় সমস্তটিরই আপনি মূলত বাইরে রেখে দিয়েছেন।"
(যাইহোক, এই উত্তরটি যেমন প্রকাশিত হয়েছে , আপনি অনাথ দৃষ্টান্ত ব্যবহার করে কিছু ক্ষেত্রে বিশ্বব্যাপী দৃষ্টান্তকে ভেঙে ফেলতে পারেন !)
লাইব্রেরি প্রয়োগকারীদের জন্য কী
বাস্তবায়নের আগে দু'বার ভাবুন Num
। আপনি fromInteger
সমস্যার আশপাশে কাজ করতে পারবেন না - সংজ্ঞায়িত করা এটি আরও ভাল fromInteger = error "not implemented"
করে না । আপনার ব্যবহারকারীরা কি বিভ্রান্ত বা অবাক হবেন - বা আরও খারাপ, কখনই খেয়াল করবেন না their যদি তাদের পূর্ণসংখ্যার অক্ষরগুলি দুর্ঘটনাক্রমে আপনি যে ধরণের ইনস্ট্যান্ট করছেন সেটির জন্য অনুমান করা হয়? সরবরাহ করছে (*)
এবং (+)
সেই সমালোচনা-বিশেষত যদি আপনাকে এটি হ্যাক করতে হয়?
কনাল এলিয়টের vector-space
(ধরণের ধরণের জন্য *
) বা এডওয়ার্ড কেমেটের linear
( ধরণের ধরণের জন্য ) লাইব্রেরিতে সংজ্ঞায়িত বিকল্প গাণিতিক অপারেটরগুলি ব্যবহার করার বিষয়ে বিবেচনা করুন * -> *
। এই আমি নিজেই ঝোঁক।
ব্যবহার -Wall
। এতিম দৃষ্টান্তগুলি প্রয়োগ করবেন না এবং অনাথ দৃষ্টান্তের সতর্কতাটি অক্ষম করবেন না।
পর্যায়ক্রমে, linear
এবং আরও অনেক ভাল আচরণিত গ্রন্থাগারগুলির নেতৃত্ব অনুসরণ করুন এবং এথাম দৃষ্টান্তগুলি পৃথক মডিউলে .OrphanInstances
বা এর মধ্যে শেষ করুন .Instances
। এবং অন্য কোনও মডিউল থেকে সেই মডিউলটি আমদানি করবেন না । তারপরে ব্যবহারকারীরা এতিমদের তারা চাইলে স্পষ্টভাবে আমদানি করতে পারেন।
যদি আপনি নিজেকে অনাথ সংজ্ঞায়িত করতে দেখেন তবে সম্ভব এবং যথাযথ হলে পরিবর্তে প্রবাহের রক্ষণাবেক্ষণকারীদের তাদের বাস্তবায়নের জন্য জিজ্ঞাসা করুন। আমি এতিম উদাহরণটি প্রায়শই লিখতাম Show a => Show (Identity a)
, যতক্ষণ না তারা এটিকে যুক্ত করে transformers
। এমনকি আমি এটি সম্পর্কে একটি বাগ রিপোর্ট উত্থাপিত হতে পারে; মনে নেই।
গ্রাহক গ্রাহকদের জন্য কী করবেন do
আপনার কাছে অনেক বিকল্প নেই। লাইব্রেরি রক্ষণাবেক্ষণকারীদের কাছে - বিনয়ের সাথে এবং গঠনমূলকভাবে পৌঁছান। তাদের এই প্রশ্নের দিকে নির্দেশ করুন। সমস্যাযুক্ত এতিম লেখার জন্য তাদের কিছু বিশেষ কারণ থাকতে পারে বা তারা বুঝতে পারে না।
আরও বিস্তৃতভাবে: এই সম্ভাবনা সম্পর্কে সচেতন হন। এটি হাস্কেলের কয়েকটি অঞ্চলগুলির মধ্যে একটি যেখানে সত্যিকারের বিশ্বব্যাপী প্রভাব রয়েছে; আপনাকে যাচাই করতে হবে যে প্রতিটি মডিউল আপনি আমদানি করেন এবং প্রতিটি মডিউল সেই মডিউলগুলি আমদানি করে, অনাথ দৃষ্টান্ত প্রয়োগ করে না। টাইপ টীকাগুলি আপনাকে মাঝে মাঝে সমস্যার বিষয়ে সতর্ক করতে পারে এবং অবশ্যই আপনি :i
চেক করতে GHCi এ ব্যবহার করতে পারেন ।
প্রতিশব্দের newtype
পরিবর্তে আপনার নিজস্ব সংজ্ঞা দিন type
যদি এটি যথেষ্ট গুরুত্বপূর্ণ হয়। আপনি পুরোপুরি নিশ্চিত হতে পারেন যে তাদের সাথে কেউ গণ্ডগোল করবে না।
যদি আপনার কোনও ওপেন-সোর্স লাইব্রেরি থেকে ঘন ঘন সমস্যা দেখা দেয় তবে আপনি অবশ্যই লাইব্রেরির নিজস্ব সংস্করণ তৈরি করতে পারেন তবে রক্ষণাবেক্ষণ দ্রুত মাথা ব্যথার কারণ হয়ে উঠতে পারে।