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

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

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

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

[[219130]]

版本一

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

  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除到是一位數的時候退出 
  16.     while (0 != temp / 10)  
  17.     { 
  18.         char ch = temp % 10 + 48; 
  19.         temp = temp / 10; 
  20.         str[i++] = ch; 
  21.     } 
  22.  
  23.     //處理原始數據的***位 
  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]# 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;  ^ 

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

版本二

對于版本一存在的問題,很自然的會想到有兩種解決方案,***:使用malloc分配動態內存存放結果,但是題目中明確說明不能不能分配動態內存。因此自然排除掉。第二種方案就是將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除到是一位數的時候退出 
  16.     while (0 != temp / 10)  
  17.     { 
  18.         char ch = temp % 10 + 48; 
  19.         temp = temp / 10; 
  20.         str[i++] = ch; 
  21.     } 
  22.  
  23.     //處理原始數據的***位 
  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 

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

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

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

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

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

版本三

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

  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除到是一位數的時候退出 
  19.     while (0 != temp / 10)  
  20.     { 
  21.         char ch = temp % 10 + 48; 
  22.         temp = temp / 10; 
  23.         str[i++] = ch; 
  24.     } 
  25.  
  26.     //處理原始數據的***位 
  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 

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

責任編輯:武曉燕 來源: 碼農有道
相關推薦

2009-08-11 10:12:07

C#算法

2009-08-11 14:59:57

一道面試題C#算法

2024-10-11 17:09:27

2009-08-11 15:09:44

一道面試題C#算法

2011-05-23 11:27:32

面試題面試java

2018-03-06 15:30:47

Java面試題

2023-02-04 18:24:10

SeataJava業務

2013-05-29 10:36:08

Android開發移動開發字符串反轉

2021-05-31 07:55:44

smartRepeatJavaScript函數

2017-11-21 12:15:27

數據庫面試題SQL

2022-04-08 07:52:17

CSS面試題HTML

2023-08-01 08:10:46

內存緩存

2021-03-16 05:44:26

JVM面試題運行時數據

2021-10-28 11:40:58

回文鏈表面試題數據結構

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讀寫文件函數

2021-03-27 10:59:45

JavaScript開發代碼
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产精品久久国产精品 | 国产精品一区三区 | 欧美性猛片aaaaaaa做受 | 久草青青草 | 婷婷色国产偷v国产偷v小说 | 国产一二区视频 | 国产精品乱码一区二区三区 | 成人精品一区二区三区中文字幕 | 中文字幕加勒比 | 日韩欧美国产一区二区 | 国产成人99久久亚洲综合精品 | 嫩草视频网 | 国产超碰人人爽人人做人人爱 | 欧美精品一二三 | 欧美一区视频 | 日日想夜夜操 | www国产成人免费观看视频,深夜成人网 | 日韩一区二区三区在线看 | 91精品国产91久久久久久吃药 | 一级片免费视频 | 婷婷丁香综合网 | 国产69久久精品成人看动漫 | 国产免费xxx | 日韩中文字幕在线观看视频 | 久久激情视频 | 亚洲精品68久久久一区 | 最新av在线播放 | 久久久高清 | 久久成人国产 | 精品亚洲一区二区 | 亚洲视频中文字幕 | 国产福利观看 | 欧美日韩一区不卡 | 天堂av免费观看 | 一区二区视频免费观看 | 在线免费观看欧美 | 老头搡老女人毛片视频在线看 | 五月天天色 | 男女污污动态图 | 亚洲精品永久免费 | 日韩在线国产 |