সংখ্যা

একটি সংখ্যা মান সংখ্যাসূচক অক্ষরের যেকোনো সিরিজ দিয়ে গঠিত, উদাহরণস্বরূপ:

5

সংখ্যা ডেটা টাইপের মধ্যে কয়েকটি বিশেষ বৈশ্বিক বৈশিষ্ট্যও রয়েছে যা সংখ্যাসূচক ধারণাগুলিকে প্রতিনিধিত্ব করে, যেমন Infinity এবং NaN একটি মান যার অর্থ "সংখ্যা নয়", অ-সংখ্যা মানের উপর গাণিতিক গণনা করার চেষ্টা করার একটি সম্ভাব্য ফলাফল।

যখন একটি মান Number() ফাংশনে পাস করা হয়, তখন সেই মানটি সংখ্যার সমতুল্যে রূপান্তরিত হয়। উদাহরণস্বরূপ, একটি সাংখ্যিক স্ট্রিং একটি সমতুল্য সংখ্যা আদিম ফলাফল:

Number( "10" );
> 10

Number() এ একটি false বা null মান পাস করা 0 প্রদান করে এবং true 1 প্রদান করে।

Number( null );
> 0

Number( false );
> 0

Number( true );
> 1`

যদি একটি মান রূপান্তরিত করা না যায়, যেমন undefined বা অ-সংখ্যাসূচক অক্ষর ধারণকারী একটি স্ট্রিংয়ের ক্ষেত্রে, Number ফাংশনটি NaN প্রদান করে:

Number( undefined );
> NaN

Number( "The number 3." );
> NaN

প্রোটোটাইপল ইনহেরিট্যান্সে বিশদ হিসাবে, আপনার সম্ভবত Number অবজেক্টটিকে কনস্ট্রাক্টর হিসাবে ব্যবহার করার খুব কম কারণ থাকবে না, কারণ এটি একটি সংখ্যার আক্ষরিক পরিবর্তে একটি Number অবজেক্ট তৈরি করে।

let numObject = new Number( 15 );

numObject;
> Number { 15 }

এই বস্তুটি গাণিতিক ক্রিয়াকলাপের জন্য নির্ধারিত মান হিসাবে আচরণ করে, তবে এটি সংখ্যার আক্ষরিকগুলির সাথে কঠোর সমতা তুলনা করতে ব্যর্থ হয় কারণ আক্ষরিক মানের উপর কোনও ব্যবহারিক সুবিধা প্রদান না করে ডেটা প্রকারগুলি মেলে না৷

let tenObject = new Number( 10 );

tenObject + 5;
> 15

tenObject === 10;
> false

ফ্লোট এবং পূর্ণসংখ্যা

জাভাস্ক্রিপ্টে শুধুমাত্র একটি সংখ্যার ধরন রয়েছে: 64-বিট IEEE 754-1985 -2^1024 এবং 2^1024 এর মধ্যে দ্বিগুণ নির্ভুলতা ফ্লোটিং-পয়েন্ট সংখ্যা । জাভাস্ক্রিপ্ট মেমরিতে কোনো সংখ্যা সংরক্ষণ করার আগে, এটি প্রথমে সেই সংখ্যাটিকে একটি বাইনারি ফ্লোটিং-পয়েন্ট নম্বরে রূপান্তর করে, যাকে ফ্লোটও বলা হয়।

এই 64-বিট স্টোরেজ (একটি ধনাত্মক বা নেতিবাচক "চিহ্ন" বিট, একটি সূচকের জন্য 11 বিট, এবং একটি ভগ্নাংশের জন্য 52 বিট) যে কোনও সংখ্যার সাথে স্পষ্টতা ত্রুটির কারণ হতে পারে যা একটি অনুমোদিত সীমার মধ্যে মাপসই হয় না। এই সীমাবদ্ধতা জাভাস্ক্রিপ্টের সংখ্যা ডেটা টাইপের অন্তর্নিহিত।

0.1 + 0.7
> 0.7999999999999999

একটি সংখ্যার মান পরিবর্তে একটি পূর্ণসংখ্যা হিসাবে সংরক্ষণ করা যেতে পারে, একটি ভাসমান-বিন্দু সংখ্যা -(2^53 − 1) এবং 2^53 − 1 এর মধ্যে কোনো ভগ্নাংশ ছাড়াই। যেহেতু ফ্লোট এবং পূর্ণসংখ্যা একই মৌলিক উপায়ে সংরক্ষণ করা হয়, এই সংখ্যাগুলি কীভাবে কাজ করে তাতে কোনও বাস্তব পার্থক্য নেই। যাইহোক, যথার্থ ত্রুটি এড়াতে আমরা যখনই সম্ভব পূর্ণ সংখ্যা ব্যবহার করার পরামর্শ দিই।

সংখ্যা অপারেটর

আপনি যখন সংখ্যা আদিম সহ স্ট্যান্ডার্ড গাণিতিক অপারেটর ব্যবহার করেন, তখন ক্রিয়াকলাপের গাণিতিক ক্রম প্রযোজ্য হয়: বন্ধনীতে মোড়ানো যেকোন অভিব্যক্তিগুলি প্রথমে মূল্যায়ন করা হয়, তারপরে সূচক, গুণ, ভাগ, যোগ এবং বিয়োগ।

অপারেটর নাম বর্ণনা ব্যবহার ফলাফল
+ সংযোজন 2+2 4
- বিয়োগ 4-2 2
* গুণ 2*5 10
/ বিভাগ 10/5 2
++ ইনক্রিমেন্ট একটি সংখ্যার সাথে একটি যোগ করে 2++ 3
-- হ্রাস একটি সংখ্যা থেকে একটি বিয়োগ করে 3-- 2
** সূচক প্রথম উত্থাপনের ফলাফল প্রদান করে
দ্বিতীয় অপারেন্ডের শক্তি থেকে অপারেন্ড।
2**4 16
% অবশিষ্ট অবশিষ্ট অবশিষ্ট ফেরত দেয় যখন
প্রথম অপারেন্ডটি দ্বিতীয় অপারেন্ড দ্বারা বিভক্ত।
12%5 2

আপনি একটি ভেরিয়েবলের মানের উপর একটি গাণিতিক ক্রিয়াকলাপ সঞ্চালনের জন্য গাণিতিক অ্যাসাইনমেন্ট অপারেটরগুলি ব্যবহার করতে পারেন এবং অবিলম্বে সেই নতুন-গণনা করা মানটি পরিবর্তনশীলকে বরাদ্দ করতে পারেন।

অপারেটর নাম ব্যবহার
+= সংযোজন অ্যাসাইনমেন্ট myValue += 2
-= বিয়োগ অ্যাসাইনমেন্ট myValue -= 2
*= গুণ বরাদ্দ myValue *= 2
/= ডিভিশন অ্যাসাইনমেন্ট myValue /= 2
**= এক্সপোনেন্ট অ্যাসাইনমেন্ট myValue **= 2
%= অবশিষ্ট অ্যাসাইনমেন্ট myValue %= 2

প্রতীকী মান

আদিম সংখ্যাটি কয়েকটি বিশেষ ক্ষেত্রেও প্রযোজ্য: "একটি সংখ্যা নয়" মান ( NaN ) এবং অসীমের প্রতিনিধিত্বকারী একটি মান যা হয় ধনাত্মক ( Infinity ) বা ঋণাত্মক ( -Infinity ) হতে পারে।

আপনি শূন্য দ্বারা ভাগ করার ফলে খুব কমই Infinity মুখোমুখি হতে পারেন, এমন একটি ক্ষেত্রে যেখানে বেশিরভাগ প্রোগ্রামিং ভাষা পরিবর্তে একটি ত্রুটি ফেলে:

10 / 0
> Infinity

মনে রাখবেন জাভাস্ক্রিপ্ট কেস-সংবেদনশীল। Infinity হল একটি সংখ্যা ডেটা টাইপ যা অসীমের ধারণার প্রতিনিধিত্ব করে, কিন্তু infinity কোন বিশেষ অর্থ নেই:

Infinity
> Infinity

infinity
> Uncaught ReferenceError: infinity is not defined

NaN (অর্থাৎ " একটি সংখ্যা নয় ") আরও ঘন ঘন দেখায়, যখন একটি গাণিতিক অপারেশনের ফলাফল একটি সংখ্যা হিসাবে প্রকাশ করা যায় না। উদাহরণস্বরূপ, যেহেতু জাভাস্ক্রিপ্ট মান এবং প্রসঙ্গ থেকে ডেটা টাইপ অনুমান করার চেষ্টা করে, একটি গাণিতিক অপারেশনে শুধুমাত্র একটি সংখ্যা ধারণকারী একটি স্ট্রিং আক্ষরিক ব্যবহার করা যেতে পারে:

"2" * 2;
> 4

যাইহোক, যদি সেই স্ট্রিংটিকে একটি সংখ্যার মান হিসাবে পার্স করা না যায়, তাহলে গাণিতিক ক্রিয়াকলাপের ফলে একটি অ-সংখ্যা হয়:

"two" * 2;
> NaN

যে কোনও ক্ষেত্রেই NaN ফেরত দেওয়া হয় যেখানে একটি গাণিতিক ক্রিয়াকলাপে একটি সংখ্যা হিসাবে একটি অবৈধ মান উপস্থাপন করা হয়। উদাহরণ নিম্নলিখিত অন্তর্ভুক্ত:

  • ব্যর্থ সংখ্যা রূপান্তর (উদাহরণস্বরূপ, parseInt( undefined ) )
  • পাটিগণিত ক্রিয়াকলাপ যেখানে ফলাফল একটি বাস্তব সংখ্যা নয় (উদাহরণস্বরূপ, 0 / 0 , Math.sqrt( -10 ) )
  • একটি অনির্দিষ্ট ফলাফল সহ একটি গাণিতিক অপারেশন ( 0 * Infinity )
  • একটি গাণিতিক ক্রিয়াকলাপ যাতে একটি স্পষ্ট NaN ( NaN + 2 ) বা একটি NaN ফলাফল ( 2 * "string" / 2 ) অন্তর্ভুক্ত থাকে

আপনার উপলব্ধি পরীক্ষা করুন

Number()false পাস করার ফলাফল কী?

0
NaN
মিথ্যা
1

নিম্নলিখিত গাণিতিক অপারেশনের ফলাফল কী?

"Six" * 3

18
2
0
সত্য
NaN