本文主要是介绍常见C语言基础说明五:数组名当函数参数传入,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
一. 简介
前面几篇学习了 C语言中基础问题,文章如下:
常见C语言基础题说明一-CSDN博客
常见C语言基础说明二:位运算问题-CSDN博客
常见C语言基础说明三:static修饰的函数或变量-CSDN博客
常见C语言基础说明四:#define宏定义与 a---CSDN博客
本文继续学习 嵌入式C开发中,可能涉及的一些C语言基础问题。
二. 常见C语言基础说明四:数组名当函数参数传入
1. 字符串常量、函数内的定义的指针
(1)示例一有如下代码,计算出运行结果:
#include <stdio.h>void get_string(char* p)
{char* ptr = "welcome";p = ptr;
}int main(void)
{ char buf[] = "how are you!";get_string(buf);printf("%s\n", buf);return 0;
}
打印结果为:
how are you!
分析:
数组名是一个指针常量,其只能指向数组的首个元素所在地址。当数组作为函数参数时,会转化(有的也称退化)为一个指针,可以进行一些指针的操作,比如,a++ 来读取下一个元素,但是其转化为的指针也还是指向这个数组的。
这里将 数组名 buf(也就是数组的首个元素的地址)作为函参传入函数中。
buf = ptr 这一句就是将 函数中一个局部变量指针 ptr的地址,而没有改变 数组buf中的内容。 ptr其实是函数的局部变量(局部变量存储在栈区),也就是说当函数执行结束后 ptr会被销毁。
ptr 指向的是一个字符串常量,字符串常量存储在静态存储区。静态存储区的数据,一直存在,只有当程序执行结束退出才会被销毁。
get_string函数执行结束后,由于 ptr这个指针已经销毁,所以,当最后返回到 main函数后,数组buf仍然是 "how are you!"
(2) 示例2 有如下代码,计算结果:
#include <stdio.h>
char* get_string(void)
{char* ptr = "welcome!"; //"welcome"是字符串常量,存储在静态存储区return ptr;
}int main(void)
{ char* ptr2 = "Hello world!";ptr2 = get_string();printf("%s\n", ptr2);return 0;
}
输出结果为:
welcome!
分析如下:
ptr指针是函数 get_string中定义的一个局部变量,函数中局部变量存放在栈区,函数执行完后存放在栈区的变量就释放了,为什么指针还可以返回正常的字符串呢?
这里 ptr 指向的是一个字符常量的字符串,字符串常量存储在静态存储区,所以,"welcome!"这个字符串会一直存在,直到程序运行结束才会销毁。
main主函数中,定义了一个指针 ptr2 指向了 该字符常量的存放地址,所以,main函数最终可以打印出 "welcome!" 该字符串常量。
示例3:而如果是 如下代码,那么就存在问题了:
char* get_string(void)
{char buf[] = "welcome!"; //"welcome"是字符串常量,存储在静态存储区return buf;
}int main(void)
{char* ptr2 = get_string();printf("%s\n", ptr2);return 0;
}
运行会提示段错误。
get_string 函数中定义的是一个局部变量数组,所以存放在栈区,是不能返回。
因为在 get_string函数被调用结束后,数组 buf就已经释放,也就是不存在了。
这篇关于常见C语言基础说明五:数组名当函数参数传入的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!