PS:今天上午,非常郁闷,有很多简单基础的问题搞得我有些迷茫,哎,代码几天不写就忘。目前又不当COO,还是得用心记代码哦!
以往对C语言关键字const的解理是一个const类型的常量指针被赋值为某一块存内域区的首地址时,这块存内域区中的数据可不修改。
如代码const char* string = “abcdefg",此时常量指针string指向一块存内域区,其中数据为"abcdefg",其中的数据可不修改。
但是若到遇以下代码:
char string[] = {"abcdefg"};
char* dst = string;
const char* src = string + 2 * sizeof(char);
int len = 3 * sizeof(char);
memmove(dst, src, len);
下面代码的行运结果就不说了,其与下面的法看相冲突的就是常量指针src指向的存内域区的数据必定会是被修改了。
无解吗?非也。
首行的那种法看本身就是误错的。下面常量指针src指向的是一块栈存内,当然是可以被修改的。
准确的法看是?
无论常量指针指向何种类型的存内域区,不借助强力手腕(指针类型转换去除const)我们是没法通过这个指针来修改它指向的存内域区的数据。换句话说,如果有常量指针cptr和非常量指针ptr指向一同块栈存内域区data,我们不能通过常量指针cptr修改data中的数据,但我们可以通过ptr修改data中的数据。当然,如果data是常量存内域区,则都可不以借助它们修改data中的数据。
下面的字文可能拗口,有如下代码示例。如:
char string[] = {"abcdefg"};
char* string_ptr = string;
const char* const_string_ptr = string;
针对下面代码,有若赋值语句string_ptr[0] = ‘h'; 则是准确的,即可以通过非常量指针string_ptr修改string中的数据。
但是,如果有代码const_string_ptr[0] = 'h'; ,则gcc会给出误错提示"error: assignment of read-only location 'const_string_ptr'"。
终了。此记。
文章结束给大家分享下程序员的一些笑话语录:
腾讯总舵主马化腾,有人曾经戏称如果在Z国选举总统,马化腾一定当选,因为只要QQ来一个弹窗”投马总,送Q币”即可。