最近在作項目 ,用到了好幾回sprint,這個函數功能甚是強大啊。是轉換成字符串的利器。下面是我在網上找到的,感受比較好的總結。感謝各位網友,你們一塊兒進步!
sprintf函數的用法
一、該函數包含在stdio.h的頭文件中。
二、sprintf和平時咱們經常使用的printf函數的功能很類似。sprintf函數打印到字符串中,而printf函數打印輸出到屏幕上。sprintf函數在咱們完成其餘數據類型轉換成字符串類型的操做中應用普遍。
三、sprintf函數的格式:
int sprintf( char *buffer, const char *format [, argument,...] );
除了前兩個參數固定外,可選參數能夠是任意個。buffer是字符數組名;format是格式化字符串(像:"%3d%6.2f%#x%o",%與#合用時,自動在十六進制數前面加上0x)。只要在printf中可使用的格式化字符串,在sprintf均可以使用。其中的格式化字符串是此函數的精華。
四、char str[20];
double f=14.309948;
sprintf(str,"%6.2f",f);
能夠控制精度
五、char str[20];
int a=20984,b=48090;
sprintf(str,"%3d%6d",a,b);
str[]="20984 48090"
能夠將多個數值數據鏈接起來。
六、char str[20];
char s1={'A','B','C'};
char s2={'T','Y','x'};
sprintf(str,"%.3s%.3s",s1,s2);
能夠將多個字符串鏈接成字符串
%m.n在字符串的輸出中,m表示寬度,字符串共佔的列數;n表示實際的字符數。%m.n在浮點數中,m也表示寬度;n表示小數的位數。
七、能夠動態指定,須要截取的字符數
char s1={'A','B','C'};
char s2={'T','Y','x'};
sprintf(str,"%.*s%.*s",2,s1,3,s2);
sprintf(s, "%*.*f", 10, 2, 3.1415926);
八、sprintf(s, "%p", &i);
能夠打印出i的地址
上面的語句至關於
sprintf(s, "%0*x", 2 * sizeof(void *), &i);
九、sprintf的返回值是字符數組中字符的個數,即字符串的長度,不用在調用strlen(s)求字符串的長度html
STM32調用sprintf致使運行異常——越界
(2015-09-29 22:38:05)
void Grade3_Sub3_Debug(void)
{
char TEST_Buf[4];
sprintf( TEST_Buf, "M",Page1_Grade3_Sub3_IO);
LCD_P8x16Str(0,2,(uint8_t *)TEST_Buf);
}
編寫了這麼一段程序,在Cotex-M3下運行,發現一個其餘部分的菜單隻能進不能出,覺得是標誌沒作好,清零之類的問題,查找了許久並未找到問題,最後索性用SWD Debug一下,MDK提示說限制在32k,但我仍是嘗試去全速運行,並在相應的語句設置了斷點,發如今對應的菜單,進去以後,按了後退鍵,程序並無在斷點上面停留下來,這個歌斷點的語句是一個只要按了後退鍵就會執行的語句,爲何卻沒有停下來?
緣由只有1個!那就是程序死在某一個地方了!爲何程序會在按下按鍵的時候死掉,又沒有調用中斷?因此能夠很確定的定位到系統出錯的問題上!也就是Cotex-M3的系統異常中斷處理。這時候只要點擊「STOP」,那麼程序就會停下,並定位到死循環的位置上面,HardFault_Handler中斷。根據網友提供信息:
STM32出現HardFault_Handler故障的緣由主要有兩個方面:
一、內存溢出或者訪問越界。這個須要本身寫程序的時候規範代碼,遇到了須要慢慢排查。數組
二、堆棧溢出。增長堆棧的大小。安全
因此這時候就要去找內存溢出,數組越界的問題了,正常是數組大小設置和調用數組出問題,致使越界,函數
上面的程序通過修改:ui
void Grade3_Sub3_Debug(void)
{
char TEST_Buf[5];
sprintf( TEST_Buf, "M",Page1_Grade3_Sub3_IO);
LCD_P8x16Str(0,2,(uint8_t *)TEST_Buf);
}
也就是改變了數組大小,以後菜單進退自如了!!
這也是sprintf常出現的問題之一:
sprintf 是個變參函數,使用時常常出問題,並且只要出問題一般就是能致使程序崩潰的內存訪spa
問錯誤,但好在由sprintf 誤用致使的問題雖然嚴重,卻很容易找出,無非就是那麼幾種狀況,通3d
經常使用眼睛再把出錯的代碼多看幾眼就看出來了。調試
sprintf_s()是sprintf()的安全版本,經過指定緩衝區長度來避免sprintf()存在的溢出風險 。在使用VS2008時若是你使用了sprintf函數,那麼編譯器會發出警告:使用sprintf存在風險,建議使用sprintf_s。這個安全版本的原型是:orm
int sprintf_s(char *buffer,size_t sizeOfBuffer,const char *format [,argument] ... );htm
緩衝區溢出
第一個參數的長度過短了,沒的說,給個大點的地方吧。固然也多是後面的參數的問
題,建議變參對應必定要細心,而打印字符串時,儘可能使用」%.ns」的形式指定最大字符數。
忘記了第一個參數
低級得不能再低級問題,用printf 用得太慣了。//偶就常犯。:。(
變參對應出問題
一般是忘記了提供對應某個格式符的變參,致使之後的參數通通錯位,檢查檢查吧。尤
其是對應」*」的那些參數,都提供了嗎?不要把一個整數對應一個」%s」,編譯器會以爲你
欺她太甚了(編譯器是obj 和exe 的媽媽,應該是個女的,:P)。
strftime
sprnitf 還有個不錯的表妹:strftime,專門用於格式化時間字符串的,用法跟她表哥很像,也
是一大堆格式控制符,只是畢竟小姑娘家心細,她還要調用者指定緩衝區的最大長度,多是爲
了在出現問題時能夠推卸責任吧。這裏舉個例子:
time_t t = time(0);
//產生"YYYY-MM-DD hh:mm:ss"格式的字符串。
char s[32];
strftime(s, sizeof(s), "%Y-%m-%d %H:%M:%S", localtime(&t));
sprintf 在MFC 中也能找到他的知音:CString::Format,strftime 在MFC 中天然也有她的同道:
CTime::Format,這一對因爲從面向對象哪裏獲得了贊助,用以寫出的代碼更覺優雅。