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

12個有趣的C語言問答

開發 后端 開發工具
本文一共介紹了12個C語言的有趣問答,內容相當給力,對C的開發者應該好好看看。。

0,gets() 方法

Q:以下代碼有個被隱藏住的問題,你能找到它嗎?

A:這個不顯眼的問題就是使用了 gets() 方法。此方法接受一個string類型參數,但是卻沒有檢測此數值是否 有足夠的空間來拷貝數據。所以這里我們一般用 fgets() 方法將來的更好。

  1. #include<stdio.h>  
  2.    
  3. int main(void)  
  4. {  
  5.     char buff[10];  
  6.     memset(buff,0,sizeof(buff));  
  7.    
  8.     gets(buff);  
  9.    
  10.     printf("\n The buffer entered is [%s]\n",buff);  
  11.    
  12.     return 0;  

1,strcpy() 方法

Q:密碼防護是很基本的功能,看看能否搞定下面這段代碼?

  1. #include<stdio.h>  
  2.    
  3. int main(int argc, char *argv[])  
  4. {  
  5.     int flag = 0;  
  6.     char passwd[10];  
  7.    
  8.     memset(passwd,0,sizeof(passwd));  
  9.    
  10.     strcpy(passwd, argv[1]);  
  11.    
  12.     if(0 == strcmp("LinuxGeek", passwd))  
  13.     {  
  14.         flag = 1;  
  15.     }  
  16.    
  17.     if(flag)  
  18.     {  
  19.         printf("\n Password cracked \n");  
  20.     }  
  21.     else 
  22.     {  
  23.         printf("\n Incorrect passwd \n");  
  24.    
  25.     }  
  26.     return 0;  
12個有趣的C語言問答

2,main() 方法的返回類型

Q:請問下面這段代碼能否通過編譯?如果能的話,那么這段代碼中隱含什么問題嗎?

  1. #include<stdio.h>  
  2.    
  3. void main(void)  
  4. {  
  5.     char *ptr = (char*)malloc(10);  
  6.     if(NULL == ptr)  
  7.     {  
  8.         printf("\n Malloc failed \n");  
  9.         return;  
  10.     }  
  11.     else 
  12.     {  
  13.         // Do some processing  
  14.         free(ptr);  
  15.     }  
  16.     return;  

A:答案是代碼能通過編譯,但是會留下針對main()方法的返回類型的警告。main()方法的真正返回類型應該為’int’而非’void’。這是因為’int’返回類型能夠讓程序返回狀態值。尤其是當這段程序作為其他應用的附屬程序時這個狀態值將更加重要。

3,內存泄露

Q:請問以下代碼有內存泄露嗎?

  1. #include<stdio.h>  
  2.    
  3. void main(void)  
  4. {  
  5.     char *ptr = (char*)malloc(10);  
  6.    
  7.     if(NULL == ptr)  
  8.     {  
  9.         printf("\n Malloc failed \n");  
  10.         return;  
  11.     }  
  12.     else 
  13.     {  
  14.         // Do some processing  
  15.     }  
  16.    
  17.     return;  

A:好,雖然上面的代碼沒有對指針 ptr 進行內存釋放,但實際上即使是程序結束也不會造成內存泄露,因為當程序結束時所有一開始被占據的內存就全部清空了。但如果上面這段代碼是在 while 循環里面那將會造成嚴重的問題

Note: 如果你需要了解更多關于內存泄露的問題以及如何使用工具檢測內存泄露,你可以參考這篇文章 Valgrind

4,free() 方法

Q:以下代碼當用戶輸入’freeze’時會奔潰,而如果輸入’zebra’則運行正常,這是為什么?

  1. #include<stdio.h>  
  2.    
  3. int main(int argc, char *argv[])  
  4. {  
  5.     char *ptr = (char*)malloc(10);  
  6.    
  7.     if(NULL == ptr)  
  8.     {  
  9.         printf("\n Malloc failed \n");  
  10.         return -1;  
  11.     }  
  12.     else if(argc == 1)  
  13.     {  
  14.         printf("\n Usage  \n");  
  15.     }  
  16.     else 
  17.     {  
  18.         memset(ptr, 0, 10);  
  19.    
  20.         strncpy(ptr, argv[1], 9);  
  21.    
  22.         while(*ptr != 'z')  
  23.         {  
  24.             if(*ptr == '')  
  25.                 break;  
  26.             else 
  27.                 ptr++;  
  28.         }  
  29.    
  30.         if(*ptr == 'z')  
  31.         {  
  32.             printf("\n String contains 'z'\n");  
  33.             // Do some more processing  
  34.         }  
  35.    
  36.        free(ptr);  
  37.     }  
  38.    
  39.     return 0;  

A:問題的根源是因為代碼在while循環中改變了 ptr 指針的地址。當輸入為’zebra’時,while循環甚至在執行 ***遍前就結束了,所以free()釋放的內存地址就是一開始malloc()分配的地址。但是當輸入’freeze’時, ptr記錄的地址在while循環中被更改,因為將會是錯誤的地址傳遞到free()方法中引起崩潰。

5,atexit with _exit

Q:在以下代碼,atexit()方法并沒有被調用,你知道為什么嗎?

  1. #include<stdio.h>  
  2.    
  3. void func(void)  
  4. {  
  5.     printf("\n Cleanup function called \n");  
  6.     return;  
  7. }  
  8.    
  9. int main(void)  
  10. {  
  11.     int i = 0;  
  12.    
  13.     atexit(func);  
  14.    
  15.     for(;i<0xffffff;i++);  
  16.    
  17.     _exit(0);  

A:這是因為使用了 _exit() 方法。此方法并沒有調用清除數據相關的方法,比如 atexit()等。

6,void* 與 C 結構體

Q:能否設計一個方法接受任意類型的參數然后返回整數?同時是否有辦法傳遞多個這樣的參數?

A:一個能接受任意類型參數的方法像下面這個樣子:

  1. int func(void *ptr) 

如果需要傳遞多個參數,那么我們可以傳遞一個包含這些參數的結構體

7,* 與 ++ 操作符

Q:以下代碼將輸出什么?為什么?

  1. #include<stdio.h>  
  2.    
  3. int main(void)  
  4. {  
  5.     char *ptr = "Linux";  
  6.     printf("\n [%c] \n",*ptr++);  
  7.     printf("\n [%c] \n",*ptr);  
  8.    
  9.     return 0;  

A:以上的輸出將是:

因為++與 * 的優先級一樣,所以 *ptr++ 將會從右向左操作。按照這個邏輯,ptr++ 會先執行然后執行*ptr。所以***個結果是’L'。也因為 ++ 被執行了,所以下一個printf() 結果是’i'。

8,Making changes in Code segment

Q:以下代碼運行時一定會崩潰,你能說出原因嗎?

  1. #include<stdio.h>  
  2.    
  3. int main(void)  
  4. {  
  5.     char *ptr = "Linux";  
  6.     *ptr = 'T';  
  7.    
  8.     printf("\n [%s] \n", ptr);  
  9.    
  10.     return 0;  

A:這是因為,通過 *ptr = ‘T’,此行代碼嘗試更改只讀內存存儲的字符串’Linux’。此操作當然行不通所以才會造成崩潰。

9,Process that changes its own name

Q:你能否寫一個程序在它運行時修改它的名稱?

A:以下代碼可以完成

  1. #include<stdio.h>  
  2.    
  3. int main(int argc, char *argv[])  
  4. {  
  5.     int i = 0;  
  6.     char buff[100];  
  7.    
  8.     memset(buff,0,sizeof(buff));  
  9.    
  10.     strncpy(buff, argv[0], sizeof(buff));  
  11.     memset(argv[0],0,strlen(buff));  
  12.    
  13.     strncpy(argv[0], "NewName", 7);  
  14.    
  15.     // Simulate a wait. Check the process  
  16.     // name at this point.  
  17.     for(;i<0xffffffff;i++);  
  18.    
  19.     return 0;  

A,局部變量的返回地址

Q:下面的代碼有問題嗎?如果有,如何修改?

  1. #include<stdio.h>  
  2.    
  3. int* inc(int val)  
  4. {  
  5.   int a = val;  
  6.   a++;  
  7.   return &a;  
  8. }  
  9.    
  10. int main(void)  
  11. {  
  12.     int a = 10;  
  13.    
  14.     int *val = inc(a);  
  15.    
  16.     printf("\n Incremented value is equal to [%d] \n", *val);  
  17.    
  18.     return 0;  

A:雖然上面的代碼有時運行會很好,但是在方法 inc() 中有很嚴重的隱患。當inc()方法執行后,再次使用局部變量的地址就會造成不可估量的結果。解決之道就是傳遞變量a的地址給main()。

B,處理 printf() 參數

Q:以下代碼輸出請問是什么?

  1. #include<stdio.h>  
  2.    
  3. int main(void)  
  4. {  
  5.     int a = 10, b = 20, c = 30;  
  6.    
  7.     printf("\n %d..%d..%d \n", a+b+c, (b = b*2), (c = c*2));  
  8.    
  9.     return 0;  

A:輸出將是

  1. 110..40..60 

這是因為參數都是從右向左處理的,然后打印出來卻是從左向右。

英文原文:http://www.thegeekstuff.com/2012/08/c-interview-questions/

譯文鏈接:http://www.oschina.net/question/213217_69069

責任編輯:林師授 來源: OSCHINA
相關推薦

2020-04-25 19:00:15

Linux終端命令

2011-02-13 13:04:00

HTML 5Web

2010-08-18 08:53:53

Scala

2011-06-13 10:30:07

Linus Torva

2020-06-20 14:18:53

Kubernetes容器開發

2020-10-31 17:33:18

Scala語言函數

2022-10-10 23:19:02

Python腳本語言工具庫

2022-03-31 11:56:34

Android 12智能手機功能

2014-11-14 17:08:24

代碼

2013-08-20 09:23:06

Scala遞歸

2013-12-30 10:42:42

C++特性

2020-10-27 07:56:35

Python

2021-04-19 08:35:44

PythonPython語言Python基礎

2022-05-13 08:47:55

爬蟲lxmlhtml

2019-12-03 19:09:19

JavaScriptNumbers阿里云計算

2009-08-25 14:25:19

Eclipse 3.5

2023-08-13 08:29:27

ChatGPT指令AI

2011-12-05 16:03:52

編程語言

2022-06-16 08:35:10

CSS屬性前端

2011-07-11 10:16:07

JavaScript
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产一区二区在线免费观看 | 91一区二区 | 精品久久久久久久久亚洲 | 男人的天堂在线视频 | 日韩在线资源 | 中文字幕不卡视频在线观看 | 岛国毛片 | 999精品网| 欧美不卡在线 | 91就要激情| 黄色a级一级片 | 亚洲欧美激情国产综合久久久 | 黄色免费在线网址 | 欧美激情精品久久久久 | 中文字幕av一区 | 欧美一级大片免费看 | 91新视频| 农村真人裸体丰满少妇毛片 | 91香蕉| 精品网站999 | 精品一区欧美 | 日韩视频中文字幕 | 国产精品区一区二区三区 | www.youjizz.com日韩| 国产视频一区二区三区四区五区 | 999久久久免费精品国产 | 午夜在线影院 | 日韩av一区在线观看 | 看片网站在线 | 亚洲人成人网 | 91精品国产91久久久久游泳池 | www.久久艹| 91在线观看免费 | 精品1区2区| 视频在线观看亚洲 | 国产精品国产三级国产aⅴ浪潮 | 国产精品一级在线观看 | 91短视频网址| 天天躁天天操 | 国产在线播放一区二区三区 | 毛片黄片|