C++学习(十七)(C语言部分)之 指针
復習 數組
定義格式 類型 數組名[數組大小]
數組名+下標
int arr[2][3]={{1,2,3},{4,5,6}};
int arr[][3]={1,2,3,4,5,6};//二維數組定義的時候賦值 不能省略列 但可以省略行
?
內存地址 內存(字節) 每個字節編號(地址)
指針--->存放地址的類型 & 取地址 *取值(解引用)
指針定義
類型 *指針的名字 定義指針的格式 (類型 指針保存變量類型的地址)
(point 指針)
指針 可以通過地址修改/訪問其他變量值
一般用在 內存申請+函數傳參
指針 一般涉及到指針變量一個指向的方向
指針的類型
指針指向的數據的類型
指針--->內存 一條大街 每個字節--->門牌號(地址)
指針就是存放地址的變量
int *p
int 表明p指向一個int類型的變量
int* 表明指針是int*類型
使用過程中 p 表示指針變量 地址
*p 表示指針指向的內容 int
地址不一樣 操作不一樣
指針存的是什么東西 (地址)
指針如何賦值 如何使用(p *p)
p表示地址 *p是值
指針賦值 賦值變量的地址 &x 得到當前變量的地址
(每次運行的時候 變量地址未必一致)
NULL (特殊規定 指針沒有指向任何變量 賦值)
指針 先復制 然后使用
變量沒有賦值不能使用 指針沒有賦值頁不能使用
int x;
printf("%d",x);亂碼
規定 如果指針沒有指向內容 讓指針賦值為NULL (相當于指針的默認值 需要手動賦值)
指針賦值后使用 *p
操作 *p操作指向變量的值
*解引用 只能用于指針
一級指針 int *p/double *p/float *p/char *p
內存的分配 一次程序運行的時候變量分配的地址是不變的
指針很麻煩 并且不實用
指針 1.能不能存值--->
int x;
int *p;
p=1;//操作是錯誤的 賦值時地址
int*p=x;//x int類型 賦值指針 錯誤的
p=&x;
指針 2.麻煩
指針去修改變量的值
變量可以通過變量名去修改
有一種情況 不能通過變量名去修改 必須用到指針 函數傳參
指針 3.必須使用指針
內存四區 --->定義一個變量 (在內存中分配一塊地址)
棧區 (定義變量 定義在棧區) 內存不需要管理 自動分配內存 自動釋放 (缺點 棧溢出 大概只有4M空間 再大就管理不了) 例如arr[1000000000000];
堆區 (手動申請 手動釋放 必須用指針操作) 手動確定數組大小(動態數組) 堆區
全局靜態常量區 存放全局變量 靜態變量 常量 (比棧區大)
代碼區 (存放代碼二進制)
函數里面定義的變量 在棧區
堆區 用函數申請釋放
全局變量 放在main函數外面 在函數外部定義的變量
靜態 static 修飾的變量
字符串常量---->存放在常量區 常量 數據不能修改
?
?
?
?
1 #include<stdio.h> 2 #include<stdlib.h>//srand rand sysytem malloc free 3 int main() 4 { 5 #if 0 6 7 int x = 0;//定義變量 賦值 8 //取到x的地址 9 int *p;//定義 定義變量 10 p= &x;//賦值 給指針賦值 11 printf("%p\n",p);//打印p的值(地址) 12 *p = 20;//修改的x 操作*p和操作x 用指針去修改另外一個變量的值 13 if (p == NULL) 14 { 15 //說明指針沒有指向任何內容 不能使用 *p 16 } 17 printf("%p\n",p);//打印p的值(地址) 18 printf("%p\n",&x);//打印地址 格式占位符%p 19 //假設需要申請一塊空間 存放int malloc(sizeof(int)*1);//申請內存 返回一個地址 必須用指針保存 ()里面是申請的內存的大小 一般搭配sizeof 返回一個地址 括號里面的數字 表明大小 單位是字節 20 //malloc 內存申請 分配多少空間 21 22 //使用時和數組一樣 23 int*q = (int*)malloc(sizeof(int)* 100); 24 *q=2;//操作第一個int *(q+n) 操作第n+1個int *(q+0)~*(q+99) 25 q[0] = 2;//q[n]相當于 *(q+n) 26 for (int i = 0; i < 100; ++i) 27 { 28 *(q + i) = i;//通過指針 使用堆內存 29 //或者 q[i]=i; 30 printf("%d",*(q+i)); 31 } 32 //q[100];//越界 33 //*(q+100);//越界 34 int*myPoint = (int*)malloc(sizeof(int)*x);//內存申請 數組在堆區 大小 是由變量來決定的 動態數組 35 //int arr[100];//數組大小必須是常量 靜態數組 36 37 free(q);//堆區內存必須要手動釋放 38 free(myPoint); 39 while (1) 40 { 41 malloc(sizeof(int)*1000); 42 } 43 #endif 44 45 #if 1 46 char mystr[] = "hello world";//mystr 數組 棧區 47 char *pstr = "hello world";//pstr定義的是指針 保存的是地址 保存的是字符串的地址 48 //char*pstr="hello world";//常量區 內容不能修改 49 //pstr = "hello world";//字符串的地址賦值給了pstr 50 mystr[0] = '1'; 51 //pstr[0] = '1';//用指針修改了常量區的內容 所以會報錯 52 //*(pstr+0)='1'; 53 54 #endif 55 56 getchar(); 57 return 0; 58 }?
?
?
1.指針 定義格式 int*p int表示p要指向的內容(p保存的變量的地址) *表示這是指針 p表示指針的名字
使用方式 賦值 用地址給指針賦值(需要一個額外的變量)
使用 *p 代表p指向的內容
2.內存四區
棧區
堆區
全局靜態常量區(全局區)
代碼區
3.特殊指針用法
堆區的內存申請釋放 malloc free 頭文件 stdlib.h
char*p="hello"和char arr[]="hello"的區別
注意事項 1.指針使用的時候必須向賦值然后使用
2.指針只能賦值地址
3.內存申請必須釋放 不釋放會占內存 直到重啟
4.定義指針int*p
p相當于地址 *p相當于指向的內容
5.不同類型指針不能互相賦值 (類型不一樣 操作也不一樣)
//除了malloc 不考慮任何強轉
?
?
?
2018-07-20 ??10:29:29
?
轉載于:https://www.cnblogs.com/Yuuki-/p/9340110.html
總結
以上是生活随笔為你收集整理的C++学习(十七)(C语言部分)之 指针的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 各位,问下乐迈石晶地板产品好吗?
- 下一篇: [源码和文档分享]基于C++实现的运动会