12/13
(一) 常量指针
指针指向的对象不能通过这个指针来修改,仍然可以通过原来的声明修改,也就是说常量指针可以被赋值为变量的地址,常量指针是限制了通过这个指针修改变量的值。
const int a = 12;
const int b = 15;
const int *c = &a; // 为了简化代码,很多人习惯赋初始值
const int *d;
d = &a; // 这样当然是可以的
c = &b; // 虽然c已经被赋予初始值,可是仍然可以指向另一个变量
特点是,const的位置在指针声明运算符的左侧。只要const位于的左侧,无论它在类型名的左边或右边,都声明了一个指向常量的指针,叫做常量指针。可以这么想,*左侧是常量,指针指向的对象是常量。
(二) 指针常量
因为指针常量是一个常量,在声明的时候一定要给它赋初始值。一旦赋值,以后这个常量再也不能指向别的地址。虽然指针常量的值不能变,可是它指向的对象是可变的。指针常量的值是指针,这个值因为是常量,所以不能被赋值。
char *a = "abcde1234";
char *b = "bcde";
char *const c = &a;
下面的操作是可以的
a[0] = 'x'; // 我们并没有限制a为常量指针(指向常量的指针)
或者*c[0] = 'x' // 与上面的操作一致
(三)指向常量的指针常量
char *a = "abcde1234";
const char *b = "bcde"; // b是指向常量字符串的指针变量
char *const c = &a; // c是指向字符指针变量的常量
const char *const d = &b; // d是指向字符常量的指针常量
指向常量的指针常量就是一个常量,且它指向的对象也是一个常量。因为是一个指针常量,那么它指向的对象当然是一个指针对象,而它又指向常量,说明它指向的对象不能变化。
(四 )realloc malloc
realloc原型是extern void *realloc(void *mem_address, unsigned int newsize);
指针名=(数据类型*)realloc(要改变内存大小的指针名,新的大小)。
malloc原型是extern void *malloc(unsigned int num_bytes);
malloc的语法是:指针名=(数据类型* )malloc(长度),(数据类型*)表示指针.
(五) 二级指针
二级指针
A(即B的地址)是指向指针的指针,称为二级指针,用于存放二级指针的变量称为二级指针变量.根据B的不同情况,二级指针又分为指向指针变量的指针和指向数组的指针.
p1:指针变量名
*p1:访问p1指向的变量
p2:二级指针变量【指向一级指针,保存的是一级指针变量的内存地址】
*p2:获取一级指针的值【即一级指针指向的变量的内存地址】
**p2:获取一级指针指向的变量的值
输出p2得到的是一级指针变量的地址
输出*p2得到的是一级指针变量指向的普通变量的地址
输出**p2得到的是一级指针变量指向的普通变量的值
(六)课后习题
void is_prime()
{
int *a = (int*)malloc(sizeof(int));
int i, j,num = 1;
for (i = 2; i < 1000; i++)
{
for (j = 2; j <= i; j++)
{
if (i%j == 0)
{
break;
}
if (j == (i - 1))
{
num++;
a = (int*)realloc(a, num*sizeof(int));
*(a + num - 1) = i;
printf("%d ", *(a + num - 1));
}
}
}
printf("%d", num);
printf("----------------------------------------------------\n");
for (i = num; i > 1; i--)
{
num--;
printf("%d ", *(a+num));
}
}
int main()
{
is_prime();
getchar();
}