تابع doubleval() در PHP
تابع doubleval() در PHP وظیفه تبدیل مقدار به نوع عدد اعشاری (float/double) را بر عهده دارد. این تابع در عمل همان کاری را انجام میدهد که floatval() یا تایپکست (float) و (double) انجام میدهند؛ بنابراین بیشتر جنبهٔ تاریخی و نگارشی دارد ولی درک دقیق رفتار آن برای جلوگیری از خطاها و نتایج ناخواسته مهم است.
معادلها و نکات زبانشناسی
- doubleval() معادل floatval() است.
- تایپکست
(float)یا(double)نیز همان نتیجه را میدهد. - در خروجی تابع
gettype()گاهی عبارت “double” نشان داده میشود، هرچند نوع داخلی همان float است.
قواعد کلی تبدیل
- اگر ورودی عددی باشد، مقدار معادل اعشاری برگردانده میشود.
- اگر ورودی رشتهای باشد، PHP سعی میکند عدد را از ابتدای رشته بخواند. اگر رشته با عدد شروع نشود، نتیجه 0.0 خواهد بود.
- کاراکترهای سفید (مثل فاصله و تب) قبل از عدد نادیده گرفته میشوند.
- برای جداکننده اعشار معمولا نقطه (.) استفاده میشود. توابع خاصی که وابسته به locale هستند ممکن است رفتار متفاوتی داشته باشند؛ اما تبدیل رشته به عدد عموماً وابسته به نقطه است.
- برای آرایهها، اشیاء و منابع رفتار تبدیل مشخص است: آرایه به float تبدیل نمیشود و معمولا هشدار میدهد؛ اشیاء اگر متد
__toString()داشته باشند، از آن استفاده میشود (و سپس مقدار رشتهای تبدیل میشود).
مثالهای عملی
doubleval("123"),
"123.45" => doubleval("123.45"),
" -7.8e2" => doubleval(" -7.8e2"),
"abc123" => doubleval("abc123"),
"12abc34" => doubleval("12abc34"),
"" => doubleval(""),
null => doubleval(null),
true => doubleval(true),
false => doubleval(false),
[1,2] => @doubleval([1,2]),
];
var_dump($examples);
در این مثال، برای رشتههایی که با عدد شروع میشوند (مثل “123.45” یا “12abc34”) مقدار عددی خوانده میشود. رشتههایی که با حروف شروع شوند مثل “abc123” به 0.0 تبدیل میشوند. مقدارهای بولی به 1.0 یا 0.0 تبدیل میشوند و null به 0.0 میشود. تبدیل آرایهها هشدار تولید میکند و معمولا نتیجهٔ 0.0 یا false است (با توجه به نسخه PHP و خطای سرکوبشده).
نمونهٔ خروجی برای درک بهتر
| ورودی | خروجی (doubleval) | توضیح |
|---|---|---|
| “123” | 123.0 | رشتهٔ عددی ساده |
| “123.45” | 123.45 | اعداد اعشاری با نقطه |
| ” -7.8e2″ | -780.0 | نمای علمی پشتیبانی میشود |
| “12abc” | 12.0 | خواندن عدد از ابتدای رشته |
| “abc12” | 0.0 | شروع با حروف → صفر |
| null | 0.0 | تبدیل null به صفر |
| true | 1.0 | بولین به عدد |
نکات مربوط به دقت و مقایسهٔ اعشاری
اعداد اعشاری در PHP (مثل دیگر زبانها) از نوع ممیز شناور هستند و محدودیت دقت دارند. بنابراین مقایسهٔ مستقیم == یا === ممکن است به نتایجی منجر شود که انتظار ندارید. بهتر است برای مقایسههای عددی از روش فاصلهٔ مطلق با یک eps استفاده کنید یا از توابعی مانند bccomp() یا کتابخانههای عدد درجشده برای دقت بالا بهره ببرید.
<?php
$a = doubleval(0.1 + 0.2);
$b = doubleval(0.3);
$epsilon = 1e-10;
var_dump(abs($a - $b) در این قطعه، به علت خطاهای شناور، ممکن است $a === $b برابر false شود؛ اما با بررسی تفاوت مطلق و مقدار کوچک $epsilon میتوان مقایسهٔ امنتری داشت.
روشهای امنتر برای تبدیل
- قبل از تبدیل، از
is_numeric()استفاده کنید تا مطمئن شوید رشته واقعاً عددی است. - برای ورودیهای کاربر، از
filter_var($var, FILTER_VALIDATE_FLOAT)بهره ببرید تا اعتبارسنجی و تبدیل دقیقتر انجام شود. - برای مباحث مالی و نیاز به دقت هزارم یا بیشتر، از
bcmathیا ذخیرهسازی مقادیر به صورت integer (مثلاً سانتیواحد پول) استفاده کنید تا از خطای شناور در محاسبات جلوگیری شود.
موارد کاربرد و توصیههای نهایی
- برای تبدیل سریع از
(float)$valueیاfloatval($value)استفاده کنید؛doubleval()صرفاً معادل است. - قبل از تبدیل ورودی خارجی را اعتبارسنجی کنید (با
is_numericیاfilter_var). - در مقایسههای حساس از روش eps استفاده کنید یا کتابخانههایی با دقت بالا به کار ببرید.
- اگر نیاز به نمایش و قالببندی دارید، از
number_format()یا توابع locale-aware استفاده کنید ولی به یاد داشته باشید که این توابع فقط نمایش را تغییر میدهند نه مقدار ذخیرهشده.
در مجموع، doubleval() ابزار ساده و مفیدی برای تبدیل به عدد اعشاری است؛ اما آگاهی از جزئیات رفتار تبدیل و محدودیتهای ممیز شناور برای نوشتن برنامههای دقیق و ایمن ضروری است.
آیا این مطلب برای شما مفید بود ؟



