成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

由一道面試題所引出的C語言static變量特性

開發(fā) 后端
當時覺得蠻簡單的,這不就是類似字符串逆轉嘛,紙上得來終覺淺,絕知此事要躬行,自己嘗試做了一下,發(fā)現(xiàn)還是有一些地方值得注意。今天在此整理一下常見的坑,鞏固下基礎東西。

最近部門在準備春招筆試題時,有這樣一道題目:用C/C++語言實現(xiàn)一個函數(shù),給定一個int類型的整數(shù),函數(shù)輸出逆序的整數(shù)對應的字符串,例如輸入1234,則輸出字符串"4321",,輸入-1234,則輸出字符串"-4321"。題目要求,不使用標準庫,以及不能分配動態(tài)內存。當時覺得蠻簡單的,這不就是類似字符串逆轉嘛,紙上得來終覺淺,絕知此事要躬行,自己嘗試做了一下,發(fā)現(xiàn)還是有一些地方值得注意。今天在此整理一下常見的坑,鞏固下基礎東西。

[[219130]]

版本一

算法思路其實很簡單:使用對10取余和除法操作依次獲取每一位的數(shù)字,然后根據(jù)ASSIC碼轉換為字符,將結果存放在一個char型數(shù)組中,***返回字符串數(shù)組結果,如下所示:

  1. #include<stdio.h> 
  2.  
  3. //版本一 
  4. const char * reverseInt(int n) 
  5.     char str[16] = {0}; 
  6.     int temp = n; 
  7.     int i = 0; 
  8.      
  9.     if (n < 0) 
  10.     { 
  11.         temp = -n; 
  12.         str[i++] = '-'
  13.     } 
  14.  
  15.     //當temp除到是一位數(shù)的時候退出 
  16.     while (0 != temp / 10)  
  17.     { 
  18.         char ch = temp % 10 + 48; 
  19.         temp = temp / 10; 
  20.         str[i++] = ch; 
  21.     } 
  22.  
  23.     //處理原始數(shù)據(jù)的***位 
  24.     str[i++] = temp % 10 + 48; 
  25.  
  26.     return str; 
  27.  
  28. int main(int argc, char **agrv) 
  29. {     
  30.     int test_data1 = 12345;     
  31.     int test_data2 = 789; 
  32.  
  33.     printf("[test_data1] %d--->%s\n",  
  34.     test_data1, reverseInt(test_data1)); 
  35.  
  36.     printf("[test_data2] %d--->%s\n",  
  37.     test_data2, reverseInt(test_data2));     
  38.     return 0; 

發(fā)現(xiàn)編譯出現(xiàn)了警告,如下:

  1. [root@epc.baidu.com ctest]# gcc -g -o test test.c  
  2. test.c: In function 'reverseInt'
  3. test.c:24:2: warning: function returns address of local variable [-Wreturn-local-addr]   
  4.   return str;  ^ 

從編譯器給出的信息很清楚的說明了問題:返回了一個局部變量的地址,但是我們知道,函數(shù)的局部變量是存在stack中的,當這個函數(shù)調用過程結束時,這個局部變量都是要釋放掉的,自然就不可再使用了,所以就會產(chǎn)生這樣的warning,這個是和變量的生命周期相關的。

版本二

對于版本一存在的問題,很自然的會想到有兩種解決方案,***:使用malloc分配動態(tài)內存存放結果,但是題目中明確說明不能不能分配動態(tài)內存。因此自然排除掉。第二種方案就是將char result[16]改為static型:static char result[16];對,就是這么一點改動。

  1. #include<stdio.h> 
  2.  
  3. //版本二 
  4. const char * reverseInt(int n) 
  5.     static char str[16] = {0}; 
  6.     int temp = n; 
  7.     int i = 0; 
  8.      
  9.     if (n < 0) 
  10.     { 
  11.         temp = -n; 
  12.         str[i++] = '-'
  13.     } 
  14.  
  15.     //當temp除到是一位數(shù)的時候退出 
  16.     while (0 != temp / 10)  
  17.     { 
  18.         char ch = temp % 10 + 48; 
  19.         temp = temp / 10; 
  20.         str[i++] = ch; 
  21.     } 
  22.  
  23.     //處理原始數(shù)據(jù)的***位 
  24.     str[i++] = temp % 10 + 48; 
  25.  
  26.     return str; 
  27.  
  28. int main(int argc, char **agrv) 
  29. {     
  30.     int test_data1 = 12345;     
  31.     int test_data2 = 789; 
  32.  
  33.     printf("[test_data1] %d--->%s\n",  
  34.     test_data1, reverseInt(test_data1)); 
  35.  
  36.     printf("[test_data2] %d--->%s\n",  
  37.     test_data2, reverseInt(test_data2));     
  38.     return 0; 

運行結果如下:

  1. [root@epc.baidu.com ctest]# ./test                 
  2. [test_data1] 12345--->54321 
  3. [test_data2] 789--->98721 

從運行結果上看,***個測試數(shù)據(jù)其結果是正確的,但是第二個輸出結果確實錯誤的。這是什么原因?先來回一下用static修飾所修飾的局部變量(也稱靜態(tài)局部變量)特點,如下:

1:靜態(tài)局部變量定義時未賦初值,則默認初始化為0;

2:靜態(tài)局部變量其作用域為函數(shù)或代碼塊,其生命周期為整個程序的運行期間;注意這兩個概念不要混淆;

3:在一個進程的運行期間,靜態(tài)局部變量只會初始化一次,就是***次調用該靜態(tài)局部變量所在函數(shù)的時候初始化,此后再調用不會初始化。

好了,到這里,其實問題的原因已經(jīng)很明顯了:在上面程序中,static char str[16] = {0}只會初始化一次,既在執(zhí)行reverseInt(test_data1)時初始化,執(zhí)行完該語句,將結果存放到str中,此時str中的內容為54321,既str[16] = {'5','4','3','2','1','\0'};當再次對第二個測試數(shù)進行轉換調用reverseInt(test_data2)時,str仍然是上次的結果{'5','4','3','2','1','\0'},因此在轉換后為98721。

版本三

那么如何解決版本二的問題了,一個很簡單的辦法就是在reverseInt函數(shù)中對static變量str每次使用for循環(huán)進行初始化,如下,鑒于篇幅,就不將main函數(shù)也貼出來了:

  1. const char * reverseInt(int n) 
  2.     static char str[16] = {0}; 
  3.     int temp = n; 
  4.     int i = 0; 
  5.     int j = 0; 
  6.  
  7.     for (; j < 16; j++)  
  8.     { 
  9.         str[j] = '\0'
  10.     } 
  11.  
  12.     if (n < 0) 
  13.     { 
  14.         temp = -n; 
  15.         str[i++] = '-'
  16.     } 
  17.  
  18.     //當temp除到是一位數(shù)的時候退出 
  19.     while (0 != temp / 10)  
  20.     { 
  21.         char ch = temp % 10 + 48; 
  22.         temp = temp / 10; 
  23.         str[i++] = ch; 
  24.     } 
  25.  
  26.     //處理原始數(shù)據(jù)的***位 
  27.     str[i++] = temp % 10 + 48; 
  28.  
  29.     return str; 

運行,能得到我們期望的結果了:

  1. [root@epc.baidu.com ctest]# ./test                 
  2. [test_data1] 12345--->54321 
  3. [test_data2] 789--->987 

其實,版本三還有很多細節(jié)需要考慮的,比如:當輸入的整數(shù)超過int的范圍如何處理等等,雖然是小細節(jié),但卻十分重要,大家有興趣可以思考下練練手。

責任編輯:武曉燕 來源: 碼農(nóng)有道
相關推薦

2009-08-11 14:59:57

一道面試題C#算法

2009-08-11 10:12:07

C#算法

2024-10-11 17:09:27

2009-08-11 15:09:44

一道面試題C#算法

2018-03-06 15:30:47

Java面試題

2011-05-23 11:27:32

面試題面試java

2023-02-04 18:24:10

SeataJava業(yè)務

2013-05-29 10:36:08

Android開發(fā)移動開發(fā)字符串反轉

2017-11-21 12:15:27

數(shù)據(jù)庫面試題SQL

2022-04-08 07:52:17

CSS面試題HTML

2021-05-31 07:55:44

smartRepeatJavaScript函數(shù)

2023-08-01 08:10:46

內存緩存

2021-10-28 11:40:58

回文鏈表面試題數(shù)據(jù)結構

2021-03-16 05:44:26

JVM面試題運行時數(shù)據(jù)

2022-02-08 18:09:20

JS引擎解析器

2015-09-02 14:09:19

面試題程序設計

2017-03-10 09:33:16

JavaScript類型

2011-03-02 10:58:16

SQL server入門面試題

2017-09-13 07:15:10

Python讀寫文件函數(shù)

2021-03-27 10:59:45

JavaScript開發(fā)代碼
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美aⅴ | 中文字幕av中文字幕 | 国产精品国产精品国产专区不卡 | 免费国产一区二区 | 久久99久久 | 中文字幕一区二区三区精彩视频 | 天天干视频 | 丝袜 亚洲 欧美 日韩 综合 | 国产精品99久久久久久www | 99精品一区二区三区 | 亚洲黄色在线免费观看 | 日韩一级免费看 | 午夜二区 | 国产99精品 | 国产一极毛片 | 91精品国产综合久久精品 | 天堂资源最新在线 | 国产在线一区二区三区 | av免费网站在线观看 | 国产高清视频 | 亚洲国产高清在线观看 | 天天艹逼网 | 亚洲自拍偷拍视频 | 国产区精品在线观看 | 久久一 | 欧洲尺码日本国产精品 | 成人网av| 国内毛片毛片毛片毛片 | 欧州一区二区三区 | 亚洲一区二区久久 | 久久久免费电影 | 亚洲欧美一区二区三区视频 | 在线午夜| 亚洲成人av| 蜜桃视频成人 | 亚洲午夜小视频 | 中文字幕乱码视频32 | 91久久久久久久久久久 | 日本久草视频 | 日韩中文字幕一区二区 | 日韩在线视频免费观看 |