C复习-指针

参考: 里科《C和指针》


指针存储的是一个地址,实际就是一个值。

如果像下面一样对未初始化的指针进行赋值,如果a的初始值是非法地址,那么会报错。UNIX会提示段错误segmentation violation,或内存错误memory fault,指程序试图访问一个未分配给程序的内存位置;如果windows的话一般是保护性异常General Protection Exception。如果a的初始值是合法地址,那可能更麻烦了,因此在对指针进行间接访问之前,必须确保已经初始化(或者是NULL)。

int *a;
...
*a = 12;

向函数传递指针前也要先检查是否为NULL。因为按标准,在函数里不检查,检查交给用户(创建时检查)。

指针的指针

int a = 12;
int *b = &a;
int **c = &b;
char ch = 'a';
char *cp = &ch;
表达式说明重要性
*cp + 1‘b’*的优先级高于+
*(cp + 1)这是非法的,ch后面的值未知
++cp非法,是找ch后面的值
*++cp右值是ch后面的值,左值是ch后面那个位置
*cp++右值是ch的值,左值是ch的地址。但是cp移到下一个位置了。后缀++的优先级高于*,这里是1)++产生了cp的拷贝;2)++操作cp;3)在cp的拷贝上实现间接访问
++*cp‘b’++和*都是从右向左结合的,所以先间接访问。不能作为左值
(*cp)++‘a’因为先间接访问,所以计算的值就是’a’,随后ch的值+1变’b’
++*++cp先后移指针,然后取值,再+1很少见
++*cp++因为后缀++的优先级高,所以先移动cp,然后间接访问到ch,+1后ch=’b’,此时cp还是指向ch后一个位置很少见

实例

size_t
strlen(char* string) {
    int length = 0;
    /*
    * 如果string=null会报错,因为++自动移动,但是访问冲突
    * 这里不检查是否为null,是希望用户检查
    */
    while ( *string++ != '\0')
    {
        length += 1;
    }
    return length;
}

指针算术加减

指针+1是移动到下一个位置,而非下一个字节。比如int要4个字节,那么int *ptr, ptr+1时实际移动了4个字节,并不是在指针内部移动。

指针减指针

只有在数组内有意义,得到的结果是ptrdiff_t类型,是一种有符号整数类型。这个结果除以数组类型的长度(比如float是4)就是坐标差。如果两个指针指向的元素不在同一数组,这个结果就是未定义的。大部分编译器也不会检查是不是在一个数组。

指针的关系运算

同样在数组中有意义,指< ≤ > ≥。虽然标准允许指向数组元素的指针,与数组最后一个元素后面的内存位置的指针比较,但是不允许它与指向index=0前一个位置的指针比较。不能保证移植性。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值