টি এল; ডিআর
সর্বজনীন রূপান্তর প্রয়োজনের জন্য এর মধ্যে একটি ব্যবহার করুন
//Java 7 or below
bigDecimal.setScale(0, RoundingMode.DOWN).intValueExact()
//Java 8
bigDecimal.toBigInteger().intValueExact()
যুক্তি
প্রয়োজনীয়তাগুলি কী এবং আপনি এই প্রশ্নের উত্তর কীভাবে দেয় তার উপর উত্তর নির্ভর করে।
- হবে
BigDecimal
সম্ভাব্য একটি নন-জিরো ভগ্ন অংশ আছে?
- হবে
BigDecimal
সম্ভাব্য ধরছে না Integer
পরিসর?
- আপনি কি শূন্য-বিভাজনযুক্ত অংশগুলি বৃত্তাকার বা কাটা কাটাতে চান?
- আপনি কীভাবে শূন্য-বিভাজক অংশগুলি বৃত্তাকার চান?
যদি আপনি প্রথম 2 টি প্রশ্নের উত্তর না দিয়ে থাকেন তবে BigDecimal.intValueExact()
অন্যরা যেভাবে পরামর্শ দিয়েছিলেন ঠিক তেমনই আপনি ব্যবহার করতে পারেন এবং যখন অপ্রত্যাশিত কিছু ঘটে তখন তা ফুটিয়ে উঠতে দেয়।
আপনি একেবারে 100% প্রশ্ন সংখ্যা 2 সম্পর্কে আত্মবিশ্বাসী না হন, তাহলে, তারপর intValue()
হয় সবসময় ভুল উত্তর।
এটি আরও ভাল করা
অন্যান্য উত্তরের উপর ভিত্তি করে নিম্নলিখিত অনুমানগুলি ব্যবহার করি use
- যথার্থতা হারাতে এবং মান কেটে ফেলার সাথে আমরা ঠিক আছি কারণ এটাই
intValueExact()
এবং অটো-বক্সিং করে
- রেঞ্জের
BigDecimal
চেয়ে বড় হয়ে গেলে আমরা একটি ব্যতিক্রম ছুঁড়ে ফেলাতে চাই Integer
কারণ যখন আপনি হাই-অর্ডার বিটগুলি ফেলে রাখেন তখন আপনার চারপাশের মোড়কের খুব নির্দিষ্ট প্রয়োজন না থাকলে অন্য কোনও কিছু পাগল হয়ে যায়।
এই প্যারামগুলি দেওয়া, intValueExact()
একটি ব্যতিক্রম ছুঁড়ে ফেলা হয় যখন আমরা এটি না চাই যদি আমাদের ভগ্নাংশের অংশটি শূন্য হয় না। অন্যদিকে, intValue()
আমাদের BigDecimal
খুব বড় যদি এটি করা উচিত তখনও একটি ব্যতিক্রম ছুঁড়ে না ।
উভয় বিশ্বের সেরা পেতে, BigDecimal
প্রথমে গোল করুন , তারপরে রূপান্তর করুন। রাউন্ডিং প্রক্রিয়াটিতে আপনাকে আরও নিয়ন্ত্রণ দেওয়ার সুবিধাও রয়েছে।
গ্রোক অভ্যাস পরীক্ষা করুন
void 'test BigDecimal rounding'() {
given:
BigDecimal decimal = new BigDecimal(Integer.MAX_VALUE - 1.99)
BigDecimal hugeDecimal = new BigDecimal(Integer.MAX_VALUE + 1.99)
BigDecimal reallyHuge = new BigDecimal("10000000000000000000000000000000000000000000000")
String decimalAsBigIntString = decimal.toBigInteger().toString()
String hugeDecimalAsBigIntString = hugeDecimal.toBigInteger().toString()
String reallyHugeAsBigIntString = reallyHuge.toBigInteger().toString()
expect: 'decimals that can be truncated within Integer range to do so without exception'
//GOOD: Truncates without exception
'' + decimal.intValue() == decimalAsBigIntString
//BAD: Throws ArithmeticException 'Non-zero decimal digits' because we lose information
// decimal.intValueExact() == decimalAsBigIntString
//GOOD: Truncates without exception
'' + decimal.setScale(0, RoundingMode.DOWN).intValueExact() == decimalAsBigIntString
and: 'truncated decimal that cannot be truncated within Integer range throw conversionOverflow exception'
//BAD: hugeDecimal.intValue() is -2147483648 instead of 2147483648
//'' + hugeDecimal.intValue() == hugeDecimalAsBigIntString
//BAD: Throws ArithmeticException 'Non-zero decimal digits' because we lose information
//'' + hugeDecimal.intValueExact() == hugeDecimalAsBigIntString
//GOOD: Throws conversionOverflow ArithmeticException because to large
//'' + hugeDecimal.setScale(0, RoundingMode.DOWN).intValueExact() == hugeDecimalAsBigIntString
and: 'truncated decimal that cannot be truncated within Integer range throw conversionOverflow exception'
//BAD: hugeDecimal.intValue() is 0
//'' + reallyHuge.intValue() == reallyHugeAsBigIntString
//GOOD: Throws conversionOverflow ArithmeticException because to large
//'' + reallyHuge.intValueExact() == reallyHugeAsBigIntString
//GOOD: Throws conversionOverflow ArithmeticException because to large
//'' + reallyHuge.setScale(0, RoundingMode.DOWN).intValueExact() == reallyHugeAsBigIntString
and: 'if using Java 8, BigInteger has intValueExact() just like BigDecimal'
//decimal.toBigInteger().intValueExact() == decimal.setScale(0, RoundingMode.DOWN).intValueExact()
}