C語言如何把浮點數(shù)轉(zhuǎn)換為字符串
把浮點數(shù)轉(zhuǎn)換為字符串
1、把float/double格式化輸出到字符串
標(biāo)準(zhǔn)的C語言提供了atof函數(shù)把字符串轉(zhuǎn)double,但是沒有提供把float/double轉(zhuǎn)換為字符串的庫函數(shù),而是采用sprintf和snprintf函數(shù)格式化輸出到字符串。
函數(shù)聲明:
int sprintf(char *str, const char *format, ...); int snprintf(char *str, size_t size, const char *format, ...);
示例(book99.c)
int sprintf(char *str, const char *format, ...); int snprintf(char *str, size_t size, const char *format, ...); 示例(book99.c) /* * 程序名:book99.c,此程序演示格式化輸出sprintf和snprintf函數(shù)。 * 作者:C語言技術(shù)網(wǎng)(www.freecplus.net) 日期:20190525 */ #include <stdio.h> #include <string.h> int main() { float ff=1024.58; double dd=12345678901234.58; char strff[21],strdd[21]; memset(strff,0,sizeof(strff)); memset(strdd,0,sizeof(strdd)); // 把浮點數(shù)ff轉(zhuǎn)換為字符串,存放在strff中。 sprintf(strff,"%.2f",ff); printf("strff=%s\n",strff); // 輸出strff=1024.58 // 把雙精度浮點數(shù)dd轉(zhuǎn)換為字符串,存放在strdd中。 sprintf(strdd,"%.2lf",dd); printf("strdd=%s\n",strdd); // 輸出strdd=12345678901234.58 memset(strff,0,sizeof(strff)); memset(strdd,0,sizeof(strdd)); // 把浮點數(shù)ff轉(zhuǎn)換為字符串,存放在strff中,只保留前10個字符。 snprintf(strff,11,"%.2f",ff); printf("strff=%s\n",strff); // 輸出strff=1024.58 // 把雙精度浮點數(shù)dd轉(zhuǎn)換為字符串,存放在strdd中,只保留前10個字符。 snprintf(strdd,11,"%.2lf",dd); printf("strdd=%s\n",strdd); // 輸出strdd=1234567890 }
運行結(jié)果
2、注意事項
snprintf函數(shù)在unix和windows平臺下的表現(xiàn)略有不同,在Linux平臺下,保留size-1個字符,在windows平臺下,保留size個字符。
整型、浮點型和字符串間轉(zhuǎn)換
1.整型、浮點型——>字符串
整數(shù)轉(zhuǎn)換為字符串:
將浮點型值轉(zhuǎn)換為字符串:
2.字符串——>整型、浮點型
下列函數(shù)可以將字符串轉(zhuǎn)換為數(shù)字:
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
C++實現(xiàn)查找二叉樹中和為某一值的所有路徑的示例
這篇文章主要介紹了C++實現(xiàn)查找二叉樹中和為某一值的所有路徑的示例,文中的方法是根據(jù)數(shù)組生成二叉排序樹并進行遍歷,需要的朋友可以參考下2016-02-02詳解C/C++ QT QChart 繪制組件應(yīng)用
Qtcharts 組件基于GraphicsView模式實現(xiàn),其核心是QChartView和QChart的二次封裝版。本文重點給大家介紹C/C++ QT QChart 繪制組件應(yīng)用的相關(guān)知識,感興趣的朋友一起看看吧2021-11-11淺析棧區(qū)和堆區(qū)內(nèi)存分配的區(qū)別
以下是對棧區(qū)和堆區(qū)內(nèi)存分配的區(qū)別進行了詳細的分析介紹,需要的朋友可以過來參考下2013-08-08C++實現(xiàn)LeetCode(146.近最少使用頁面置換緩存器)
這篇文章主要介紹了C++實現(xiàn)LeetCode(146.近最少使用頁面置換緩存器),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下2021-07-07