最近在看C語言代碼時碰到了這個問題,結合查找的資料對這C的知識點做了一下小結。寫了一份測試它們的代碼。test1函數穿了一個char* const的指針,如果對它增加,會報錯,它是只讀的。但是可以對指針所指位置的內容進行更改。test2函數測試的是const char類型的參數,test3函數測試的 ...
最近在看C語言代碼時碰到了這個問題,結合查找的資料對這C的知識點做了一下小結。寫了一份測試它們的代碼。test1函數穿了一個char* const的指針,如果對它增加,會報錯,它是只讀的。但是可以對指針所指位置的內容進行更改。test2函數測試的是const char類型的參數,test3函數測試的是char const 的參數。註釋部分是一些錯誤寫法和提示信息,也就是一些反面教材。
#include <stdio.h>
//TEST1
void test1(char* const p){
// p++;
//compile error:
// increment of read-only parameter ‘p’
*(p+3) = 'D';
*(p+4) = 'E';
}
//TEST2
void test2(const char* p){
p++;
// *(p) = 'B';
//error:
// assignment of read-only location ‘*p’
p++;
printf("test2 func string:%s\n", p);
}
//TEST3
void test3(char const* p){
p++;
// *(p) = 'B';
//error:
// assignment of read-only location ‘*p’
printf("test3 func string:%s\n", p);
}
int main()
{
char str[27];
for(int i = 0;i < 26;i++ ) str[i] = 'a'+i;
str[26] = '\0';
printf("original string: %s\n", str);
test1(str);
printf("after test1 string: %s\n", str);
test2(str);
test3(str);
return 0;
}
小結一下,const放在*的前面都是表示不能通過指針修改參數所指位置的內容,const放在*後面則是表示不能夠修改參數的值。