指针和字符串
char ch[]="hello world"; //栈区字符串
char* p=ch;
//
char* p="hello world"; //数据区常量区字符串
p[2]='m'; //err
*(p+1)='m'; //err 常量区内容不能修改
//字符串数组
char ch1="hello";
char ch2="world";
char ch3="test";
char* arr[]={ch1,ch2,ch3};
char* arr[]={"hello","world","test"};
for(int i=0;i<3-1;i++)
{
for(int j=0;j<3-1-i;j++)
{
if(arr[j][0]>arr[j+1][0])
{
char* temp=arr[j];
arr[j]=arr[j+1];
arr[j+1]=temp;
}
}
}
for(int i=0;i<3;i++)
{
printf("%s\n",arr[i];)
}
字符指针作为函数参数
int my_strlen(char* ch)
{
int i=0;
while(ch[i]) i++;
return i;
}
//指针操作
int strlen(char* ch)
{
char* temp=ch;
while(*temp!='\0') temp++;
return temp-ch;
}
int main()
{
char ch[]="hello world";
}
const 修饰的指针
int main()
{
char ch1[]="hello";
char ch2[]="world";
int* p=ch1;
const int* p=ch1;//不能修改*p值
int* const p=ch1;//不能修改p p=ch2;
...
//空指针作为验证条件
if(ch==NULL)
return 0;
}
主函数参数
int main(int argc,char* argv[])
//argc 表示传递参数的个数
//argv 表示字符串数组
实例演练
/* 字符串中查找字符串 */
char* mystrstr(char* src, char* dst)
{
char* fsrc = src; //遍历
char* rsrc = src; //记录相同首地址
char* tdst = dst; //目标字符串
while (*fsrc)
{
rsrc = fsrc;
while ((*fsrc == *tdst)&&(*fsrc!=0))
{
fsrc++; //字符匹配,地址+1
tdst++; //字符匹配,查看下个字符
}
if (*tdst==0) return rsrc;
tdst = dst; //如果不对,重新到目标起始位置
fsrc = rsrc; //回滚到源地址
fsrc++;
}
return NULL;
}
//查看字符串出现次数
int main()
{
char str[] = "llabcdkfjdeitabcsedfabcd";
char ch[] = "abc";
char* p = mystrstr(str, ch);
int count = 0;
while (p!=NULL)
{
count++;
p += strlen(ch);
p = mystrstr(p, ch);
}
printf("%s\n", p); //(null)
printf("%d\n", count); //3
return 0;
}