1,未初始化和非法的指针
int * a;
* a = 12;
a 未被初始化,不知道指向哪里有,可能指向一个合法地址,把12存储到a所指的内存位置,可能就篡改一个合法的值。
2,NULL指针
它是一个特殊的指针,表示不指向任何东西。
使一个指针变量为NULL,可以赋一个零值。
但是需要注意的是,对一个NULL指针解引用是非法的,所以在对指针解引用之前要确定它非一个NULL指针。
3,左值和右值的区别
a = b+25;
a 是一个左值,它可以标示一个可以存储结果值的地点,
b+25是个右值,它指定了一个值。
b+25 = a;
b+25 不能作为左值,无法预测该结果会存储在什么地方,未标示一个特定的位置。字面值常量不能作为左值
4,破坏指针数组的讨论
在看到c与指针关于在一组字符串中查找一个字符的两个版本的讨论,实验室几个人叽叽喳喳争论了半天,晚上查阅了一些资料,整理了一下,给大家做个参考。
//版本一
#include <stdio.h>
#define TRUE 1;
#define FALSE 0;
int find_char( char **strings,char value)
{
char * string;
while((string = *strings++) != NULL)
{
while(*string != '\0')
{
if(*string++ == value)
return TRUE;
}
}
return FALSE;
}
//版本二
#include <stdio.h>
#include <assert.h>
#define TRUE 1;
#define FALSE 0;
int find_char( char **strings,char value)
{
assert(strings != NULL);
while( *strings != NULL)
{
while(**strings != '\0')
{
if( *(*strings)++ == value)
return TRUE;
}
}
}
char ** 是指向指针的指针,这这里看做是指针数组,数组中的元素是指向char的指针,而且都是指向各个字符串的首地址。
版本一中,通过中间指针string++来访问每个字符串的元素,只是将每个字符串的指针做一份拷贝,而strings中每个指针依然指向每个字符串的首地址,可以查找多次。
版本二中,(*strings)++改变了strings数组的指针的地址,不再指向每个字符串的首地址,相当于破坏了指针数组,只能查找一次。