NULL:
对所有指针变量进行显式的初始化是种好事:(1)如果你知道指针将被初始化为什么地址,就直接初始化该地址,
(2)否则把它初始化位NULL.
注意:假定变量a存储于位置100.
×100 =25
看上去像是把25赋值给a,因为a是位置100所存储的变量。但这是错误的,这条语句是非法的。因为字面值100的类型是整形,而间接访问操作只能作用于指针类型表达式。
正确:
×(int ×)100 =25
强制类型转换把值100从“整形”转换为“指向整形的指针”
这种技巧运行之处:你偶尔需要通过地址访问内存中某个特定的位置。
前缀++:先增加它的操作数的值再返回这个结果。
后缀++:先返回cp值的一份copy,然后再增加cp的值。
易错点:
char ch = 'a' char *cp = &ch;
此时的×cp++代表什么????
结果是:它的右值和左值分别是变量ch的值和ch的内存位置,也就是cp原先所指。
定人误解的地方:后缀++操作符的优先级高于*操作符。但表达式结果看上去是像先执行间接访问操作。
实际:这里有三个步骤
(1)++操作符产生cp的一份拷贝
(2)然后++操作符增加cp的值
(3)最后在cp的拷贝上执行间接访问操作。
*cp++:这个表达式常常在循环中出现,首先用一个数组的地址初始化指针,然后使用这种表达式就可以依次访问该数组的内容了。
#include <stdio.h> #include <stdlib.h> size_t strlen_test(char *string) { int length = 0; while(*string++ != '