要利用函数实现字符串的互换,首先得弄懂一个概念,看看下面的代码:
char *str1 = "hello";
char *str2 = "world";
第一行代码的意思是定义了一个char*类型的指针,我们将关注的是代码的存储问题,这里str变量是存储于栈区的,而”hello”, 则是存放在字符串常量区,我们应该知道,字符串常量区的数据是不可更改的。所以无法直接更改“hello”和“world”的存储位置来达到交换的目的,否则会报段错误。 正确的思路是,再分别定义一个指针来指向str1和str2,即指向指针的指针(二级指针)——把函数的参数定义为二级指针,作用是为了通过交换栈区的str1, 和str2存储的字符串所在内存空间的地址来达到目的, 如图:
图片中,假设hello本来的存储位置为1000,world本来的存储位置为1004,即在交换前str1和str2所存储的位置,此时指针指向为红线, 我们的代码要实现的功能是交换str1和str2 中的存储的地址,交换后由蓝色小框标出,最终要达到的目的由蓝色线标出。
代码实现:
#include <stdio.h>
void swop(char **str1, char **str2)
{
char *temp = NULL;
temp = *str1;
*str1 = *str2;
*str2 = temp;
}
int main()
{
char *str1 = "hello";
char *str2 = "world";
printf("str1 = %s, str2 = %s\n", str1, str2);
swop(&str1, &str2);
printf("str1 = %s, str2 = %s\n", str1, str2);
return 0;
}