排序交换内存块
#include <stdio.h>#include <string.h>
void sort (char **p,int num)
{
int i,j;
//char *temp = NULL;
char temp01 ;
for (i = 0;i < num;i++)
{
for (j = i;j < num;j++)
{
if (strcmp (p,p ) > 0)
{
/*
temp = p ;
p = p ;
p = temp;
*/
strcpy (temp01,p); //这边为什么会出错?
strcpy (p ,p);
strcpy (p,temp01);
}
}
}
}
void print_sort (char **mystring,int num)
{
int i;
for (i = 0;i < num;i++)
{
printf ("%s\n",*(mystring + i));
}
}
int main ()
{
int i;
char *mystring [] = {"age","13thr","thr"};
int num = sizeof (mystring) / sizeof (mystring );
sort (mystring,num);
print_sort (mystring,num);
return 0;
}
请问这是怎么回事?谢谢各位!!! //这边为什么会出错? 是知道为什么出错。
不知道你是要干嘛,能把你要实现的功能说下? ba21 发表于 2018-4-20 21:16
//这边为什么会出错? 是知道为什么出错。
不知道你是要干嘛,能把你要实现的功能说下?
只是实现简单的交换,注释部分可以让指针数组里的元素排序(改变指针指向),出错的地方我想交换指针所指的内存块进行排序。 本帖最后由 ba21 于 2018-4-21 19:05 编辑
fdsf 发表于 2018-4-21 12:40
只是实现简单的交换,注释部分可以让指针数组里的元素排序(改变指针指向),出错的地方我想交换指针所指 ...
你直接说数组排序别人不就理解了。
//char *temp = NULL;
/*
temp = p ;
p = p ;
p = temp;
*/
这注释掉的部份不就实现了功能。
1,首先不说strcpy多此一举。
2,字符串的长度都不一样。"age","13thr","thr"长度一样吗?
3, char *mystring [] = {"age","13thr","thr"}; 这3个字符串肯定在一个连续的内存块中。
下面测试代码。自己去找原因吧:
void sort (char *p[],int num) 这个地方我也改了下,不影响,我只是觉得你**难理解。 指针数组,形参你不认为用 char *p[] 人家好理解些
#include <stdio.h>
#include <string.h>
void sort (char *p[],int num)
{
int i,j;
//char *temp = NULL;
char temp01;
strcpy (temp01,p); //这边为什么会出错?
printf("%s\n\n", temp01);
}
void print_sort (char **mystring,int num)
{
int i;
for (i = 0;i < num;i++)
{
printf ("%s\n",*(mystring + i));
}
}
int main ()
{
int i;
char *mystring[] = {"age","13thr","thr"};
int num = sizeof (mystring) / sizeof (mystring );
sort (mystring,num);
print_sort (mystring,num);
return 0;
}
页:
[1]