#include <stdio.h> #include <string.h> char *strlong(char *str1, char *str2){ if(strlen(str1) >= strlen(str2)){ return str1; }else{ return str2; } } int main(){ char str1[30], str2[30], *str; gets(str1); gets(str2); str = strlong(str1, str2); printf("Longer string: %s\n", str); return 0; }運行結果:
C Language↙
c.biancheng.net↙
Longer string: c.biancheng.net
#include <stdio.h> int *func(){ int n = 100; return &n; } int main(){ int *p = func(), n; n = *p; printf("value = %d\n", n); return 0; }運行結果:
value = 100
n 是 func() 內部的局部變量,func() 返回了指向 n 的指針,根據上面的觀點,func() 運行結束後 n 將被銷毀,使用 *p 應該獲取不到 n 的值。但是從運行結果來看,我們的推理好像是錯誤的,func() 運行結束後 *p 依然可以獲取局部變量 n 的值,這個上面的觀點不是相悖嗎?#include <stdio.h> int *func(){ int n = 100; return &n; } int main(){ int *p = func(), n; printf("c.biancheng.net\n"); n = *p; printf("value = %d\n", n); return 0; }運行結果:
c.biancheng.net
value = -2
關於函數調用的原理以及函數如何占用內存的更多細節,我們將在《C語言和內存》專題中深入探討,相信你必將有所頓悟,解開心中的謎團。第一個例子在調用其他函數之前使用 *p 搶先獲得了 n 的值並將它保存起來,第二個例子顯然沒有抓住機會,有其他函數被調用後才使用 *p 獲取數據,這個時候已經晚了,內存已經被後來的函數覆蓋了,而覆蓋它的究竟是一份什麼樣的數據我們無從推斷(一般是一個沒有意義甚至有些怪異的值)。