C語言實(shí)現(xiàn)字符串轉(zhuǎn)浮點(diǎn)函數(shù)的示例
字符串不僅可以轉(zhuǎn)換為整數(shù),也可以轉(zhuǎn)換為浮點(diǎn)數(shù),字符串轉(zhuǎn)浮點(diǎn)數(shù)函數(shù)原型如下:
float __cdecl __mingw_strtof (const char * __restrict__, char ** __restrict__); double __cdecl __mingw_strtod (const char * __restrict__, char ** __restrict__);
strtof函數(shù)返回值是一個單精度浮點(diǎn)數(shù),strtod返回值是一個雙精度浮點(diǎn)數(shù)。
首先來看strtof函數(shù),它的參數(shù)有兩個。第一個參數(shù)指向要解釋的以空字符結(jié)尾的字節(jié)字符串。第二個參數(shù)指向數(shù)字后的第一個字符。
該函數(shù)首先丟棄盡可能多的空白字符,直到找到第一個非空白字符為止。然后從該字符開始,采用與浮點(diǎn)字面量類似的語法,盡可能多地使用有效的字符,并將其解釋為數(shù)值。指向最后一個有效字符之后的字符串其余部分的指針存儲在函數(shù)第二個參數(shù)中。
有效的浮點(diǎn)值可以是以下值之一:
十進(jìn)制浮點(diǎn)表達(dá)式。它由以下部分組成:
- (可選)加號或減號
- 非空十進(jìn)制數(shù)字序列可選地包含小數(shù)點(diǎn)字符(由當(dāng)前C確定
locale
)(定義有效數(shù)字) - (可選),
e
或者E
跟隨可選的負(fù)號或加號和非空序列的十進(jìn)制數(shù)字(定義指數(shù))
二進(jìn)制浮點(diǎn)表達(dá)式。它由以下部分組成:
(可選)加號或減號
0x
或0X
- 非空的十六進(jìn)制數(shù)字序列可選地包含小數(shù)點(diǎn)字符(由當(dāng)前C確定
locale
)(定義有效數(shù)字) - (可選),
p
或者P
跟隨可選的負(fù)號或加號和非空序列的十進(jìn)制數(shù)字(定義指數(shù))
無窮大表達(dá)式。它由以下部分組成:
- (可選)加號或減號
INF
或者INFINITY
無視事件
非數(shù)字表達(dá)式。它由以下部分組成:
- (可選)加號或減號
NAN
或NAN(
char_sequence)
忽略該NAN
部分的情況。char_sequence只能包含字母數(shù)字字符。結(jié)果是靜態(tài)的NaN浮點(diǎn)值。
任何其他可能被當(dāng)前安裝的C接受的表達(dá)式 locale
下面通過一個簡單的例子演示strtof函數(shù)的用法。
#include <stdio.h> #include <stdlib.h> int main(int argc, char** argv) { char str[30] = "-123.456 5.672451e3 acde"; char *pEnd; float ret1,ret2; ret1 = strtof(str, &pEnd); ret2 = strtof(pEnd, &pEnd); printf("數(shù)字1是: %.3f\n", ret1); printf("數(shù)字2是: %.3f\n", ret2); printf("字符串部分是: %s \n", pEnd); return 0; }
代碼運(yùn)行結(jié)果如下:
在轉(zhuǎn)換數(shù)字的過程中,遇到空白字符函數(shù)就會退出。同時函數(shù)的第二個參數(shù)會存儲退出的位置,當(dāng)再次調(diào)用函數(shù)的時候,就會接著上次退出的位置繼續(xù)轉(zhuǎn)換。
strtod函數(shù)和strtof函數(shù)用法基本一樣,可以直接在上面程序的基礎(chǔ)上修改。
#include <stdio.h> #include <stdlib.h> int main(int argc, char** argv) { char str[30] = "-123.456 5.672451e3 acde"; char *pEnd; double ret1,ret2; ret1 = strtod(str, &pEnd); ret2 = strtod(pEnd, &pEnd); printf("數(shù)字1是: %lf\n", ret1); printf("數(shù)字2是: %lf\n", ret2); printf("字符串部分是: %s \n", pEnd); return 0; }
將返回值的類型修改為double
類型就可以了,執(zhí)行結(jié)果如下:
到此這篇關(guān)于C語言實(shí)現(xiàn)字符串轉(zhuǎn)浮點(diǎn)函數(shù)的示例的文章就介紹到這了,更多相關(guān)C語言 字符串轉(zhuǎn)浮點(diǎn)函數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C語言 超詳細(xì)介紹與實(shí)現(xiàn)線性表中的帶頭雙向循環(huán)鏈表
帶頭雙向循環(huán)鏈表:結(jié)構(gòu)最復(fù)雜,一般用在單獨(dú)存儲數(shù)據(jù)。實(shí)際中使用的鏈表數(shù)據(jù)結(jié)構(gòu),都是帶頭雙向循環(huán)鏈表。另外這個結(jié)構(gòu)雖然結(jié)構(gòu)復(fù)雜,但是使用代碼實(shí)現(xiàn)以后會發(fā)現(xiàn)結(jié)構(gòu)會帶來很多優(yōu)勢,實(shí)現(xiàn)反而簡單2022-03-03C語言實(shí)現(xiàn)刪除某一個數(shù)組值的方法
這篇文章主要給大家分享C語言數(shù)組中刪除數(shù)組中某個值的方法,既然要學(xué)習(xí)刪除數(shù)組中的元素,我們就必須得先知道數(shù)組中有哪些元素。同時還要定義一個變量,并將需要刪除的元素賦值給那個變量。下面來看看文章的詳細(xì)內(nèi)容吧2021-11-11C++實(shí)現(xiàn)紅黑樹應(yīng)用實(shí)例代碼
紅黑樹它一種特殊的二叉查找樹,這意味著它滿足二叉查找樹的特征,但是也有許多自己的特性,這篇文章主要給大家介紹了關(guān)于C++實(shí)現(xiàn)紅黑樹的相關(guān)資料,需要的朋友可以參考下2021-11-11基于c++的中國象棋游戲設(shè)計與實(shí)現(xiàn)
這篇文章主要介紹了基于c++的中國象棋游戲設(shè)計與實(shí)現(xiàn),主要操作是possibleMove(int?x,?int?y),通過整個棋盤每個位置上的信息、中國象棋的規(guī)則來獲得位置(x,?y)這個棋子可以移動到的位置,需要的朋友可以參考一下2022-02-02C++訪問std::variant類型數(shù)據(jù)的幾種方式小結(jié)
std::variant是?C++17中引入的一個新的類模板,提供了一種存儲不同類型的值的方式,本文主要介紹了C++訪問std::variant類型數(shù)據(jù)的幾種方式小結(jié),具有一定的參考價值,感興趣的可以了解一下2024-02-02