存儲其他變量地址的變量,稱為指針;
站在用戶的角度思考問題,與客戶深入溝通,找到鄄城網站設計與鄄城網站推廣的解決方案,憑借多年的經驗,讓設計與互聯(lián)網技術結合,創(chuàng)造個性化、用戶體驗好的作品,建站類型包括:成都做網站、成都網站建設、成都外貿網站建設、企業(yè)官網、英文網站、手機端網站、網站推廣、域名申請、虛擬空間、企業(yè)郵箱。業(yè)務覆蓋鄄城地區(qū)。int a = 25;
int *b = &a; // 此時會報錯,“int類型的值不能用于初始化int類型的實體”
// &a表示指向a的內存地址;
存儲內存地址的叫指針,不能使用0以外的整型對指針賦值,因此不能指向a,只能指向a的地址
也就是&a(表示a的內存地址)
//例如
#include#include#includeusing namespace std;
int main()
{int a = 5;
int *b = &a;
cout<< b<< "\n"; // b得到的是a的內存地址
cout<< *b<< "\n"; // *b得到的是內存地址存儲的值
a = 10; //修改a
cout<< b<< "\n"; // b獲取的內存地址不變
cout<< *b<< "\n"; // 但是內存地址對應的值變了
*b = 8; // 通過修改內存地址對應的數據
cout<< a<< "\n"; // 也就是直接修改a
}
//顯示
0113FACC
5
0113FACC
10
8
指針指向數組指針指向數組不需要加&來指向他的地址
int a[5] = {1, 2, 3, 4, 5};
int *b = a;
直接指向內存中首地址,也就是索引為0的地址
//例如
#include#include#includeusing namespace std;
int main()
{ int c[5] = {1, 2, 3, 4, 5 };
int* d = c; // 直接指向數組開始的內存
cout<< c[1]<< " "<< *(d + 1);
// *(d + 1)是指針偏移,表示向右移動一位,原來在開始的位置,也就是索引為0的位置,偏移之后就到了索引為1的位置,所以能輸出2
}
//顯示
2 2
*(d + 1)表示是往右偏移一個單位的長度
指針不允許越界訪問,就是不能超出索引
//例如
#include#include#includeusing namespace std;
int main()
{int c[5] = {1, 2, 3, 4, 5 };
int* d = c;
c[1] = 5; //修改之后,兩個都發(fā)生變化
cout<< c[1]<< " "<< *(d + 1);
}
//顯示
5 5
空指針int *a = nullptr;
空指針不指向任何地址,也不能指向任何地址,不能修改,只是一個空指針
空指針nullptr在if語句中會被當成False
NULL 或 0 也會被認為是空指針
二維及多維數組的指針需要在數組前面加強制類型轉換(int *)
//例如
#include#include#includeusing namespace std;
int main()
{int c[3][3] = {{1, 2, 3},
{4, 5, 6},
{7, 8, 9}
};
int* d = (int *)c; // 強制類型轉換
cout<< *(d + 2)<< " "<< *(d + 3)<< "\n"; // (d + 2)是3,(d + 3)是4
cout<< *c[1]<< " "<< *c[1]+1; // c是二維數組,因此一開始指針默認在數組的開始,也就是c[0][0]處,*c[1]意味著指針懸停到了第一行的開始,也就是c[1][0]處,也就是4,因此*c[1]+1表示在此基礎上右偏移一個,也就是5;
}
//顯示
3 4
4 5
二維數組在內存中是以行來保存的
//例如
#include#include#includeusing namespace std;
int main()
{int a[5] = {1, 2, 3, 4, 5 };
// int* b = a;
int* b = &a[0]; // 與上式寫法等效,也就是指針指向數組最開始的內存地址
cout<< *(b + 3);
}
//顯示
4
指針可以要求指向第幾個地址;
//例如
#include#include#includeusing namespace std;
int main()
{int a[5] = {1, 2, 3, 4, 5 };
int* b = &a[2]; // 此時指針指向索引為2的元素
cout<< *(b + 1); // 再次右偏
}
//顯示
4 // 索引2右偏1,得到索引3
//例如
#include#include#includeusing namespace std;
int main()
{int a[5] = {1, 2, 3, 4, 5 };
int* b = &a[2];
*(b - 1) = 999;
for (int i = 0; i< 5; i++)
{cout<< a[i]<< " ";
}
}
//顯示
1 999 3 4 5 //(b - 1)是索引1,左移
引用引用的數據成為引用變量,b就是引用變量,引用支持多個引用變量引用一個數據,以及連續(xù)引用,
修改其中哪一個,其他都將發(fā)生變化
//例如
#include#include#includeusing namespace std;
int main()
{int a = 33;
int &b = a;
cout<< b<< "\n";
b = 55;
cout<
函數函數要先聲明再使用,函數的聲明需要在函數主體int main前面;
type name (argument1, argument2...) statement
type 是返回類型
name 是定義的函數名
argument是上傳的參數
statement是語句
加法函數
//例如
#include#include#includeusing namespace std;
int func(int a, int b)
{int c = a + b;
return c;
}
int main()
{int d = func(1, 3); // 調用函數
cout<< d;
}
//顯示
4
入口參數入口參數的隱式轉換
入口參數做值拷貝,就是只有值一樣,函數內部會對拷貝得到的數據進行執(zhí)行運算,不會對原數據有任何影響
//例如
#include#include#includeusing namespace std;
int func(int a)
{a = 10; // 對a進行復制,此時a是值拷貝得到的a,
return 0;
}
int main()
{int a = 3;
int d = func(a); // 將a= 3 傳進去,會對a做值拷貝,
cout<< d<< "\n"; // d是返回值,是return的值
cout<< a;//調用完函數之后應該是a = 10,但那是函數內部,在函數外部的a沒有改變,還是3
}
//顯示
0
3
函數返回兩個數函數只能有一個數值,如果要返回兩個數值,可以返回引用,或者內存地址
用引用//例如
#include#include#includeusing namespace std;
float func(float r, float &D) //此處引用D
{float S = 3.14 * r * r;
D = 2 * 3.14 * r;
return S;
}
int main()
{int a = 10;
float d1;
float d = func(a,d1); // 相當于有一個&D = d1,此時D和d1是引用和被引用關系,一方被修改,則兩方都被修改,而函數體中的D = 2 * 3.14 * r;就是修改D,那么d1也會被修改,那么就可以從函數體中得到另一個參數了
cout<< d<< "\n";
cout<< d1;
指針指向內存地址//例如
#include#include#includeusing namespace std;
float func(float r, float *D)
{float S = 3.14 * r * r;
*D = 2 * 3.14 * r;
return S;
}
int main()
{int a = 10;
float d1;
float d = func(a, &d1); 相當于有一個*D = &d1,此時D直接指向d1的內存地址,一方被修改,則兩方都被修改,而函數體中的D = 2 * 3.14 * r;就是修改D,那么d1也會被修改,那么就可以從函數體中得到另一個參數了
cout<< d<< "\n";
cout<< d1;
}
a和b交換值一、利用引用
//例如
#include#include#includeusing namespace std;
void func(float &a, float &b)
{float temp = a;
a = b;
b = temp;
}
int main()
{float a = 2;
float b = 3;
func(a, b);
cout<< a<< "\n";
cout<< b;
}
二、利用指針指向地址
//例如
#include#include#includeusing namespace std;
void func(float *a, float *b)
{float temp = *a;
*a = *b;
*b = temp;
}
int main()
{float a = 2;
float b = 3;
func(&a, &b);
cout<< a<< "\n";
cout<< b;
}
空函數int func () // 不上傳參數的函數是可以存在的,一般用功能性參數
{return 1.0;
}
運算符的重載可以存在函數名相同的函數,但是上傳參數的類型或上傳參數的個數不能一樣
在c++中,輸入1.5其實是double類型,1.5f才是float類型
double雙精度浮點數
//例如
#include#include#includeusing namespace std;
void func(int a)
{cout<< "運行了整型func";
}
void func(float a) //兩個函數名一樣,但是上傳參數的類型不一樣
{cout<< "運行了浮點型func";
}
int main()
{float a = 2;
int b = 3;
func(a); //a是浮點型,調用浮點型func
func(b); //b是整型,調用整型func
double c = 4;
func(4); // 會報錯,因為沒有定義雙精度浮點型的func,不知道選哪一個,但是如果去掉一個func,只留一個func,就會隱式轉換**
}
//顯示
運行了浮點型func運行了整型func //沒有加換行
如果有兩個func,不知道選哪一個,就會報錯,但是如果去掉一個func,只留一個func,就會隱式轉換
函數可以在int main前面聲明,然后在int main后面寫函數,也不會報錯
函數里面可以有默認參數
//例如
#include#include#includeusing namespace std;
int func(int a,int b=5)
{int c = a + b;
cout<< c<< "\n";
return c;
}
int main()
{float a = 2;
int b = 3;
func(a); //默認b=5
func(a,b); // 上傳參數的時候優(yōu)先使用上傳的參數
}
//顯示
7
5
遞歸遞歸深度是跟程序內存占據大小有關
遞歸實現(xiàn)n的階乘
//例如
#include#include#includeusing namespace std;
int func(int n)
{if (n<= 1)
{return 1;
}
return n * func(n-1);
}
int main()
{int res = func(3);
cout<< res;
}
//顯示
6
遞歸實現(xiàn)x*x+sin(x)-2求解
//例如
#include#include#includeusing namespace std;
// x*x+sin(x)-2
float func(float left, float right)
{if ((abs(left - right))< 0.00001)
{return left;
}
float r_left = left * left + sin(left) - 2;
float r_right = right * right + sin(right) - 2;
float mid = (left + right) / 2;
float r_mid = mid * mid + sin(mid) - 2;
if (r_left * r_mid< 0)
{return func(left, mid);
}
else
{return func(mid, right);
}
}
int main()
{float res = func(0, 10);
cout<< res;
}
//顯示
1.06154
void函數無返回值的函數定義為void
靜態(tài)函數static,靜態(tài)函數,在函數內部存在的變量,函數內部共享
//例如
#include#include#includeusing namespace std;
void func()
{static int a = 0; //靜態(tài)函數的初始化只會執(zhí)行一次
a++;
cout<< a<< "\n";
}
int main()
{func();
func();
func();
func();
func();
}
//顯示
1
2
3
4
5
兩個函數之間的靜態(tài)變量互不關聯(lián),沒有影響
//例如
#include#include#includeusing namespace std;
void F2()
{static int b = 0;
b++;
cout<< "F2的靜態(tài)函數"<< b<< "\n";
}
void F1()
{static int a = 0;
a++;
cout<< "F1的靜態(tài)函數"<< a<< "\n";
F2();
}
int main()
{F1();
F1();
F2();
}
//顯示
F1的靜態(tài)函數1 // F1和F2的靜態(tài)函數的計數互不影響,沒有關聯(lián)
F2的靜態(tài)函數1
F1的靜態(tài)函數2
F2的靜態(tài)函數2
F2的靜態(tài)函數3
你是否還在尋找穩(wěn)定的海外服務器提供商?創(chuàng)新互聯(lián)www.cdcxhl.cn海外機房具備T級流量清洗系統(tǒng)配攻擊溯源,準確流量調度確保服務器高可用性,企業(yè)級服務器適合批量采購,新人活動首月15元起,快前往官網查看詳情吧