‘’‘ctf比赛结束了,人生中的第一场,也可能是最后一场。一点一滴的积累,就是我的生活。’‘’
区分两种形式:
-
char myString[] = "Original";
创建了一个包含字符串副本的字符数组,长度是字符串长度 + 1。 -
const char *myString = "Original";
创建了一个指向字符串常量的指针,长度由字符串本身的长度决定,但无法直接获取。
在实际使用中,选择哪种方式取决于你的需求。如果需要修改字符串,使用字符数组;如果只是需要一个指向字符串的指针,可以使用指针。
c语言传参的理解
在C语言中,参数传递是按值传递的,包括指针也是传递指针的值。在函数中,参数 char *str
接收的是传递进来的指针的副本,而不是原始指针本身。因此,通过 str
修改指针的值(比如让它指向不同的内存区域)是不会影响到函数外部的原始指针的。
然而,通过传递指针,你可以修改指针所指向的内存中的内容。在 delchar
函数中,通过 str
指针可以修改传入的字符串。这就是为什么在函数内部可以删除字符,并且函数外部会受到影响。
例如:void delchar(char *str, char c)
此处的str与main函数中的str其实是两个不同的指针,只不过指向同一个字符串。,是main函数中指针的副本。
因此,在一道简单的删除字符串中的特定字符的题中,
这个代码,通过构造新的字符串是不可以的。
void delchar( char *str, char c ){
int i=0,j=0;
char* rstr;
while(str[i]!='\0'){
if(str[i]!=c){
rstr[j]=str[i];
j++;
}
i++;
}
printf("%s",rstr);
//此处只是把函数内的与原函数指向同一字符串副本指针,指向另一个字符串,对原函数中的指针和字符串没有影响。
str=rstr;
}
可以使用二维指针解决这个问题,也可以直接修改。
//直接对原字符串修改,
void delchar(char *str, char c){
int i=0,j=0;
while(str[i]!='\0'){
if(str[i]!=c){
str[j] = str[i];
j++;
}
i++;
}
str[j]='\0';
}
二维指针。如果你想要在函数外部修改原始字符串,你需要传递指向指针的指针(double pointer),或者返回一个新的字符串。例如:
Copy code
void modifyString(char **str)
{ *str = "Modified";
}
int main() {
char *myString = "Original";
printf("Before: %s\n", myString);
modifyString(&myString);
printf("After: %s\n", myString);
return 0;
}
这个程序将输出:
makefileCopy code
Before: Original
After: Modified