入门

认识指针

#include<iostream>
using namespace std;

int main(void)
{
// 1定义指针
int a=10;

//指针定义语法:数据内型*指针变量名;
int*p;

//让指针记录变量a的地址
p = &a;
cout<<"a的地址"<<&a<<endl<<endl;
cout<<"指针p:"<<p<<endl<<endl;

//2使用指针
//可以通过解引用找到指针指向的内存
//指针前加*代表解引用,找到指针指向的内存数据
*p = 1000;   //找到a并修改他    
cout<<"a ="<<a<<endl;
cout<<"*p ="<<*p<<endl;
    return 0;
}

指针的大小

用sizeof计算出指针的大小

#include<iostream>
using namespace std;

int main(void)
{
//指针所占内存空间
int a=10;
//int * p;
//p = &a;
 int*p =&a;
 //32位(x86)4字节
 //64位(x64)8字节
 //所有
 cout<<"int * = "<<sizeof(int*)<<endl;
 cout<<"float * = "<<sizeof(float*)<<endl;
 cout<<"double * = "<<sizeof(double*)<<endl;
 cout<<"char * = "<<sizeof(char*)<<endl;

return 0;
}   

不同的编译方式就会出现不同的大小

注意事项

空指针(错误的)

#include<iostream>
using namespace std;

int main(void)
{
   //空指针
   //空指针用于给指针变量初始化
   int*p =NULL;

   //空指针不可访问
   //因为0~255是系统占用的不可访问
   


    return 0;
}

野指针(错误的)

#include<iostream>
using namespace std;

int main(void)
{
   //野指针
   //程序中,避免野指针
   int*p =(int *)0x1100;
   cout<<*p<<endl;

    return 0;
}

进阶

const修饰指针

#include <iostream>
using namespace std;
int a = 10;
int b = 10;

int main(void)
{
    // 1 const 修饰指针
    // 常量指针
    const int *p = &a; // 不可改值
    //******错误********
    //    *p = 20
    //******错误********
    p = &b; // 可该指向

    //************************************************* */

    // 2 const修饰常量
    // 指针常量
    int *const p2 = &a; // 不可该指向
    //******错误********
    //    p2 = &b
    //******错误********
    *p2 = 100; // 可改值

/******************************************************* */

    // 3 const修饰指针和常量
    const int* const p3 =&a; //都不可改


    return 0;
}

指针和数组结合

#include <iostream>
using namespace std;

int main(void)
{
    //****** 指针和数组 ***** */
    // 利用指针访问数组的元素
    int arr[10] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
    cout << "第一个元素 " << arr[0] << endl;
    int *p = arr; // arr就是数组的首地址
    cout << "指针访问第一个元素 " << *p << endl;
     
    cout<<endl<<endl<<endl;          //全是空行不用理


     cout<<"利用指针访问所有"<<endl;
     int *p2 = arr;
     for(int i;i<10;i++)
     {
      cout<<"指针访问第"<<i<<"个元素:"<<*p2<<endl;
      p2++;

     }


    return 0;
}

运行结果

第一个元素 1
指针访问第一个元素 1


利用指针访问所有
指针访问第0个元素:1
指针访问第1个元素:2
指针访问第2个元素:3
指针访问第3个元素:4
指针访问第4个元素:5
指针访问第5个元素:6
指针访问第6个元素:7
指针访问第7个元素:8
指针访问第8个元素:9
指针访问第9个元素:10

指针、函数、数组(冒泡排序)

#include <iostream>
using namespace std;

// 冒泡排序函数  参数1:首地址  参数2:函数长度
void maopao(int *arr, int len)  //不用指针数组传不到自定义函数这
{
    for (int i = 0; i < len - 1; i++)
    {
        for (int j = 0; j < len - i - 1; j++)
        {
            // j大于j+1就交换
            if (arr[j] > arr[j + 1])
            {
                int temp = arr[j];
                arr[j] = arr[j + 1];
                arr[j + 1] = temp;
            }
        }
    }
}

// 打印数组
void sb(int *arr,int len)
{
    for (int i = 0; i < len; i++)
    {
        cout << arr[i] << endl;
    }
}

int main(void)
{
    // 1、先创建数组
    int arr[10] = {4, 3, 6, 9, 1, 2, 10, 8, 7, 5};

    // 数组长度
    int len = sizeof(arr) / sizeof(arr[0]);
    // 2 创建函数 实现冒泡排序
    maopao(arr, len);

    // 3 打印排序后的数组
    sb(arr, len);

    return 0;
}

运行结果

1
2
3
4
5
6
7
8
9
10

[我的]((https://github.com/ababll5/blog_cpp))