الفرق بين المراجعتين لصفحة: «Kotlin/kotlin.text/toBigInteger»

من موسوعة حسوب
أنشأ الصفحة ب'<noinclude>{{DISPLAYTITLE: التابع text.toBigInteger()‎ في لغة Kotlin}}</noinclude> تحلّل الدالة <code>toBigInteger()</code>‎ Kotlin/String|ا...'
 
لا ملخص تعديل
سطر 4: سطر 4:
== البنية العامة ==
== البنية العامة ==
<syntaxhighlight lang="kotlin">
<syntaxhighlight lang="kotlin">
inline fun String.toBigDecimal(): BigDecimal
inline fun String.toBigInteger(): BigInteger


</syntaxhighlight>'''بيئة التشغيل المطلوبة: Kotlin 1.2, JVM'''
</syntaxhighlight>'''بيئة التشغيل المطلوبة: Kotlin 1.2, JVM'''


تحلّل الدالة <code>toBigInteger()</code>‎ [[Kotlin/String|السلسلة النصية]] التي استٌدعيت عبرها وتحوّلها إلى عدد من النوع <code>java.math.BigDecimal</code>  وتعيد الناتج.
تحلّل الدالة <code>toBigInteger()</code>‎ [[Kotlin/String|السلسلة النصية]] التي استٌدعيت عبرها وتحوّلها إلى عدد من النوع <code>java.math.BigInteger</code>  وتعيد الناتج.


في حال لم تكن  [[Kotlin/String|السلسلة النصية]] تمثل عددًا فستطلق الدالةُ استثناءً <code>NumberFormatException</code>.<syntaxhighlight lang="kotlin">
في حال لم تكن  [[Kotlin/String|السلسلة النصية]] تمثل عددًا فستطلق الدالةُ استثناءً <code>NumberFormatException</code>.<syntaxhighlight lang="kotlin">
inline fun String.toBigDecimal(
inline fun String.toBigInteger(radix: Int): BigInteger
    mathContext: MathContext
 
): BigDecimal
</syntaxhighlight>'''بيئة التشغيل المطلوبة: Kotlin 1.2, JVM'''
</syntaxhighlight>'''بيئة التشغيل المطلوبة: Kotlin 1.2, JVM'''


تحلّل الدالة <code>toBigInteger()</code>‎ [[Kotlin/String|السلسلة النصية]] التي استٌدعيت عبرها وتحوّلها إلى عدد من النوع <code>java.math.BigDecimal</code> وتعيد الناتج.
تحلّل الدالة <code>toBigInteger()</code>‎ [[Kotlin/String|السلسلة النصية]] التي استٌدعيت عبرها وتحوّلها إلى عدد من النوع <code>java.math.BigInteger</code> وتعيد الناتج.
 
في حال لم تكن  [[Kotlin/String|السلسلة النصية]] تمثل عددًا فستطلق الدالةُ استثناءً <code>NumberFormatException</code>. أما في حال كانت هناك ضرورة للقيام بالتقريب (rounding) لكنّ وضع التقريب مُعد على الوضع <code>java.math.RoundingMode.UNNECESSARY</code>،  فستطلق استثناءً <code>ArithmeticException</code>.


الوسيط <code>mathContext</code> يحدد دقة وضع التقريب (rounding mode).
في حال لم تكن  [[Kotlin/String|السلسلة النصية]] تمثل عددًا فستطلق الدالةُ استثناءً <code>NumberFormatException</code>. أما في حال كان الوسيط المُمرّر <code>radix</code> غير صالح للتحويل من  [[Kotlin/String|سلسلة نصية]] إلى عدد  فستطلق استثناءً <code>IllegalArgumentException</code>.


يُلاحَظ وجود الكلمة المفتاحية <code>inline</code> للدلالة على أن هذه الدالة مباشرة، وللمزيد من التفاصيل راجع <nowiki/>[[Kotlin/inline functions|توثيق الدوال المباشرة (inline functions)]].
يُلاحَظ وجود الكلمة المفتاحية <code>inline</code> للدلالة على أن هذه الدالة مباشرة، وللمزيد من التفاصيل راجع <nowiki/>[[Kotlin/inline functions|توثيق الدوال المباشرة (inline functions)]].


== القيم المعادة ==
== القيم المعادة ==
عدد من النوع <code>BigDecimal</code>.
عدد من النوع <code>BigInteger</code>.


== أمثلة ==
== أمثلة ==


=== استخدام الدالة <code>toBigDecimal()‎</code> مع سلسلة نصية ===
=== استخدام الدالة <code>toBigBigInteger()‎</code> مع سلسلة نصية ===
تُعرّف الشيفرة الآتية <nowiki/>[[Kotlin/String|سلسلة نصية]] باسم <code>str</code> ثم تستدعي الدالة <code>toBigInteger()‎</code> عبرها مع تمرير  [[Kotlin/String|سلسلة نصية]] كوسيط، ثم تطبع الناتج:<syntaxhighlight lang="kotlin">
تُعرّف الشيفرة الآتية <nowiki/>[[Kotlin/String|سلسلة نصية]] باسم <code>str</code> ثم تستدعي الدالة <code>toBigInteger()‎</code> عبرها مع تمرير  [[Kotlin/String|سلسلة نصية]] كوسيط، ثم تطبع الناتج:<syntaxhighlight lang="kotlin">
fun main(args: Array<String>) {
fun main(args: Array<String>) {
     val str = "12344565656"
     val str = "12344565656"
      
      
     println(str.toBigDecimal()) // 12344565656
     println(str.toBigInteger()) // 12344565656
}
}
</syntaxhighlight>
</syntaxhighlight>
سطر 42: سطر 39:
     val str = "aa12344565656"
     val str = "aa12344565656"
      
      
     println(str.toBigDecimal()) // الدالة ستطلق استثناء
     println(str.toBigInteger()) // الدالة ستطلق استثناء
}
}
</syntaxhighlight>
</syntaxhighlight>
المُخرجات:<syntaxhighlight lang="kotlin">
المُخرجات:<syntaxhighlight lang="kotlin">
Exception in thread "main" java.lang.NumberFormatException
Exception in thread "main" java.lang.NumberFormatException: For input string: "aa32"
     at java.math.BigDecimal.&amp;lt;init&amp;gt;(BigDecimal.java:494)
    at java.lang.NumberFormatException.forInputString(NumberFormatException.java:65)
     at java.math.BigDecimal.&amp;lt;init&amp;gt;(BigDecimal.java:383)
     at java.lang.Integer.parseInt(Integer.java:580)
     at java.math.BigDecimal.&amp;lt;init&amp;gt;(BigDecimal.java:806)
     at java.math.BigInteger.&amp;lt;init&amp;gt;(BigInteger.java:461)
     at java.math.BigInteger.&amp;lt;init&amp;gt;(BigInteger.java:597)
     at Simplest_versionKt.main(Simplest version.kt:4)
     at Simplest_versionKt.main(Simplest version.kt:4)
</syntaxhighlight>
</syntaxhighlight>

مراجعة 22:03، 12 يوليو 2018

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

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

inline fun String.toBigInteger(): BigInteger

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

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

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

inline fun String.toBigInteger(radix: Int): BigInteger

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

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

في حال لم تكن السلسلة النصية تمثل عددًا فستطلق الدالةُ استثناءً NumberFormatException. أما في حال كان الوسيط المُمرّر radix غير صالح للتحويل من سلسلة نصية إلى عدد فستطلق استثناءً IllegalArgumentException.

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

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

عدد من النوع BigInteger.

أمثلة

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

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

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

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

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

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

المُخرجات:

Exception in thread "main" java.lang.NumberFormatException: For input string: "aa32"
    at java.lang.NumberFormatException.forInputString(NumberFormatException.java:65)
    at java.lang.Integer.parseInt(Integer.java:580)
    at java.math.BigInteger.&amp;lt;init&amp;gt;(BigInteger.java:461)
    at java.math.BigInteger.&amp;lt;init&amp;gt;(BigInteger.java:597)
    at Simplest_versionKt.main(Simplest version.kt:4)

انظر أيضًا

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

مصادر