الفرق بين المراجعتين ل"Kotlin/kotlin.text/toBigDecimal"

من موسوعة حسوب
اذهب إلى التنقل اذهب إلى البحث
سطر 20: سطر 20:
 
في حال لم تكن  [[Kotlin/String|السلسلة النصية]] تمثل عددًا فستطلق الدالةُ استثناءً <code>NumberFormatException</code>. أما في حال كانت هناك ضرورة للقيام بالتقريب (rounding) لكنّ وضع التقريب مُعد على الوضع <code>java.math.RoundingMode.UNNECESSARY</code>،  فستطلق استثناءً <code>ArithmeticException</code>.
 
في حال لم تكن  [[Kotlin/String|السلسلة النصية]] تمثل عددًا فستطلق الدالةُ استثناءً <code>NumberFormatException</code>. أما في حال كانت هناك ضرورة للقيام بالتقريب (rounding) لكنّ وضع التقريب مُعد على الوضع <code>java.math.RoundingMode.UNNECESSARY</code>،  فستطلق استثناءً <code>ArithmeticException</code>.
  
الوسيط <code>mathContext</code> يحدد دقة التقريب.
+
الوسيط <code>mathContext</code> يحدد دقة وضع التقريب (rounding mode).
  
 
يُلاحَظ وجود الكلمة المفتاحية <code>inline</code> للدلالة على أن هذه الدالة مباشرة، وللمزيد من التفاصيل راجع <nowiki/>[[Kotlin/inline functions|توثيق الدوال المباشرة (inline functions)]].
 
يُلاحَظ وجود الكلمة المفتاحية <code>inline</code> للدلالة على أن هذه الدالة مباشرة، وللمزيد من التفاصيل راجع <nowiki/>[[Kotlin/inline functions|توثيق الدوال المباشرة (inline functions)]].
  
 
== القيم المعادة ==
 
== القيم المعادة ==
عدد من النوع <code>java.math.BigDecimal.</code>
+
عدد من النوع <code>java.math.BigDecimal</code>
  
 
== أمثلة ==
 
== أمثلة ==
  
 
=== استخدام الدالة <code>toBigDecimal()‎</code> مع سلسلة نصية ===
 
=== استخدام الدالة <code>toBigDecimal()‎</code> مع سلسلة نصية ===
تُعرّف الشيفرة الآتية <nowiki/>[[Kotlin/String|سلسلة نصية]] باسم <code>str</code> ثم تستدعي الدالة <code>toBigDecimal()‎</code> عبرها، ثم تطبع الناتج:<syntaxhighlight lang="kotlin">
+
تُعرّف الشيفرة الآتية <nowiki/>[[Kotlin/String|سلسلة نصية]] باسم <code>str</code> ثم تستدعي الدالة <code>toBigDecimal()‎</code> عبرها مع تمرير  [[Kotlin/String|سلسلة نصية]] كوسيط، ثم تطبع الناتج:<syntaxhighlight lang="kotlin">
 
fun main(args: Array<String>) {
 
fun main(args: Array<String>) {
 
     val str = "12344565656"
 
     val str = "12344565656"
سطر 36: سطر 36:
 
     println(str.toBigDecimal()) // 12344565656
 
     println(str.toBigDecimal()) // 12344565656
 
}
 
}
 +
</syntaxhighlight>
 +
=== استخدام الدالة <code>toBigDecimal()‎</code> مع سلسلة نصية: الحالة الثانية ===
 +
تُعرّف الشيفرة الآتية [[Kotlin/String|سلسلة نصية]] باسم <code>str</code> ثم تستدعي الدالة <code>toBigDecimal()‎</code> عبرها مع تمرير  [[Kotlin/String|سلسلة نصية]] كوسيط، ثم تطبع الناتج:<syntaxhighlight lang="kotlin">
 +
fun main(args: Array<String>) {
 +
    val str = "aa12344565656"
 +
   
 +
    println(str.toBigDecimal()) // الدالة ستطلق استثناء
 +
}
 +
</syntaxhighlight>
 +
المُخرجات:<syntaxhighlight lang="kotlin">
 +
Exception in thread "main" java.lang.NumberFormatException
 +
    at java.math.BigDecimal.&amp;lt;init&amp;gt;(BigDecimal.java:494)
 +
    at java.math.BigDecimal.&amp;lt;init&amp;gt;(BigDecimal.java:383)
 +
    at java.math.BigDecimal.&amp;lt;init&amp;gt;(BigDecimal.java:806)
 +
    at Simplest_versionKt.main(Simplest version.kt:4)
 
</syntaxhighlight>
 
</syntaxhighlight>
 
=== انظر أيضًا ===
 
=== انظر أيضًا ===

مراجعة 19:34، 12 يوليو 2018

تحلّل الدالة toBigDecimal()السلسلة النصية التي استٌدعيت عبرها وتحوّلها إلى عدد من النوع BigDecimal.

البنية العامة

inline fun String.toBigDecimal(): BigDecimal

بيئة التشغيل المطلوبة: Kotlin 1.2, JVM

تحلّل الدالة toBigDecimal()السلسلة النصية التي استٌدعيت عبرها وتحوّلها إلى عدد من النوع java.math.BigDecimal وتعيد الناتج.

في حال لم تكن السلسلة النصية تمثل عددًا فستطلق الدالةُ استثناءً NumberFormatException.

inline fun String.toBigDecimal(
    mathContext: MathContext
): BigDecimal

بيئة التشغيل المطلوبة: Kotlin 1.2, JVM

تحلّل الدالة toBigDecimal()السلسلة النصية التي استٌدعيت عبرها وتحوّلها إلى عدد من النوع java.math.BigDecimal وتعيد الناتج.

في حال لم تكن السلسلة النصية تمثل عددًا فستطلق الدالةُ استثناءً NumberFormatException. أما في حال كانت هناك ضرورة للقيام بالتقريب (rounding) لكنّ وضع التقريب مُعد على الوضع java.math.RoundingMode.UNNECESSARY، فستطلق استثناءً ArithmeticException.

الوسيط mathContext يحدد دقة وضع التقريب (rounding mode).

يُلاحَظ وجود الكلمة المفتاحية inline للدلالة على أن هذه الدالة مباشرة، وللمزيد من التفاصيل راجع توثيق الدوال المباشرة (inline functions).

القيم المعادة

عدد من النوع java.math.BigDecimal

أمثلة

استخدام الدالة toBigDecimal()‎ مع سلسلة نصية

تُعرّف الشيفرة الآتية سلسلة نصية باسم str ثم تستدعي الدالة toBigDecimal()‎ عبرها مع تمرير سلسلة نصية كوسيط، ثم تطبع الناتج:

fun main(args: Array<String>) {
    val str = "12344565656"
    
    println(str.toBigDecimal()) // 12344565656
}

استخدام الدالة toBigDecimal()‎ مع سلسلة نصية: الحالة الثانية

تُعرّف الشيفرة الآتية سلسلة نصية باسم str ثم تستدعي الدالة toBigDecimal()‎ عبرها مع تمرير سلسلة نصية كوسيط، ثم تطبع الناتج:

fun main(args: Array<String>) {
    val str = "aa12344565656"
    
    println(str.toBigDecimal()) // الدالة ستطلق استثناء
}

المُخرجات:

Exception in thread "main" java.lang.NumberFormatException
    at java.math.BigDecimal.&amp;lt;init&amp;gt;(BigDecimal.java:494)
    at java.math.BigDecimal.&amp;lt;init&amp;gt;(BigDecimal.java:383)
    at java.math.BigDecimal.&amp;lt;init&amp;gt;(BigDecimal.java:806)
    at Simplest_versionKt.main(Simplest version.kt:4)

انظر أيضًا

  • toUpperCase()‎ : تحوّل الدالة toUpperCase()‎ الحرف أو السلسلة النصية التي استٌدعيت عبرها إلى حالة الأحرف الكبيرة (uppercase).
  • isDefined(): تعيد القيمة true في حال كان الحرف (Unicode code point) الذي استٌدعيت عبره مُعرّفًا في اليونيكود (Unicode).
  • isDefined(): تعيد القيمة true في حال كان الحرف (Unicode code point) الذي استٌدعيت عبره مُعرّفًا في اليونيكود (Unicode).

مصادر