首页 > 其他分享 >指针的初步认识

指针的初步认识

时间:2024-07-17 16:58:24浏览次数:6  
标签:变量 认识 初步 int 地址 数组 printf 指针

1.什么是指针?

        1.1什么是数据/变量的地址

                地址就是数据在内存中的存储位置。指针就是数据在内存中的存储地址,或者叫数据在内存中的编码位置。

        1.2指针变量

                用来存储指针/地址的变量叫做指针变量。

        1.3 如何定义一个指针变量

                类型说明符 *变量名

                类型说明符指的是本指针变量所指向变量的数据类型

int *p//表示P是一个指针变量,他的值是某个整型变量的地址。
p中存放的是地址,使用*p会指向p中的地址

a = 10;
int *p=&a;
*p=20//这里的*是解引用
此时a=20

        1.4什么是空指针和野指针?

                空指针:值为零的指针。表示不指向任何地址

                野指针:未初始化的指针或指向不明的指针;

2.什么时候用到指针?

        2.1函数传参

                使用指针作函数的形参,可以直接操作实参

        2.2数组指针

        2.2.1 数组作为指针使用

                一个变量有一个地址,数组中有多个元素,每一个都在内存中占用存储单元,它们都有其地址。数组的指针是指数组的起始地址。数组元素的指针是数组元素的地址。

                数组里的内存是连续的。数组名是其首地址。每个数组元素按其类型不同占有几个连续的内存单元。一个数组元素的首地址也是指它占有的几个内存单元的首地址

int a[10];
int *p;//定义p为指向整型变量的指针

p = &a[0];//p指向a数组的第0号元素

C语言规定数组名代表数组首地址
则p=&a[0] <==> p=a

定义指针变量时可以赋给初值
int *p=&a[0] <==> int *p=a

        2.2.2数组指针的运算

指针加减法与直接地址加减不同

int arr[5] = {1,3,7};
int *p1 = &arr[0];
int *p2 =&arr[1];
int *p3 =&arr[2];
printf("%p\n",p1);//000000000062FDF0
printf("%p\n",p2);//000000000062FDF4
printf("%d\n",p2-p1);//1
printf("%d\n",p3-p1);//2

//指针运算是自动根据数据类型大小计算的

        2.2.3字符数组指针

                

	char string[]="hello world";
	char string1[]= "china";
	char *p = &string[6];
	
	printf("string=%s\n",string);
	printf("p=%s\n",p);
	
	for(int i=0;i<5;i++)
	*p++=*(string1+i);
	
	printf("string=%s\n",string);

        2.2.4 字符串指针

                

标签:变量,认识,初步,int,地址,数组,printf,指针
From: https://blog.csdn.net/weixin_65395913/article/details/140475093

相关文章

  • 避免函数形参为空指针
    展示一个函数形参为空指针的隐患:执行第32行代码时,相当于执行double*pdPoint=pdTemp;,由于pdTemp=NULL,所以pdPoint=NULL。在然后 voidPointer(double*pdPoint,intiDim)函数中对pdPoint赋了一块动态内存,此时 pdPoint!=NULL,但是 pdPoint和pdTemp只是赋值......
  • day1 二分查找(及其进阶)和移除元素的双指针法
    基础概念算法的单调性:问题的规模随着算法的推进不断缩减(如704中开始的查找区间是[lo,hi),随着循环的进行,问题规模确实在不断的缩小)算法的不变性:在初始状态下自然满足,当问题的有效规模缩减为0时,不变性应该随即等于正确性。(如704中开始的查找区间是[lo,hi),最终要么直接命中,要么......
  • C++ 智能指针动态内存简单测试
    代码示例,主要来自《C++Primer》,动态内存相关那章内容。#include<iostream>#include<memory>#include<string>namespace{//未初始化的智能指针,默认保存的空指针voiddef_null_sp_test();//不是唯一用户,复制一份新的考拷贝。voidsp_unique_copy_te......
  • 计算机只认识0和1但是怎么表示图像和影视等等众多应用的?
    原文:计算机只认识0和1但是怎么表示图像和影视等等众多应用的?-知乎(zhihu.com)0和1是两种状态,看上去没法表示诸如图像这样的复杂信息。但是,题主还记不记得以前那个发明国际象棋的数学家给国王出的难题?在第一格放一粒米,第二格放两粒米,以后每一格都要放比前一格多一倍的米,直到......
  • C语言中的指针:掌握内存的钥匙
    C语言中的指针:掌握内存的钥匙引言       C语言是一种结构化编程语言,它提供了对硬件底层的直接访问,其中最强大的特性之一就是指针。指针允许程序员直接操作内存地址,这对于理解程序的内部工作原理以及优化代码性能至关重要。本文将深入探讨C语言中指针的概念、使用方......
  • C语言指针详解(初级)
    1.指针是什么?指针理解的2个要点:        1.指针是内存中一个最小单元的编号,也就是地址(&)        2.平时口语中说的指针,通常指的是指针变量,是用来存放内存地址的变量总结:指针就是地址,口语中说的指针通常指的是指针变量。那我......
  • C++(函数参数为数组与指针算术)
    目录1.函数参数为数组2.指针算术2.1arr是指向第一个元素的地址2.2arr[i]表示什么?#include<iostream>voidprintArray(intarr[],intsize){for(inti=0;i<size;++i){std::cout<<arr[i]<<"";}}intmain(){intarr[5]......
  • 排列和组合的认识
    目录定义PermutationCombination总结定义Permutation排列的定义:排列是从一个集合中按照一定顺序选取部分元素的方式。比如密码,就是一个排列,1122和2211是不同的密码口令。Combination组合的定义:组合是从一个集合中选取部分元素的方式,但与排列不同,组合不考虑元素的顺序......
  • C++ 用智能指针这样包装 this 指针是否可行
    #include<iostream>#include<memory>usingnamespacestd;classA;classB{public:B(shared_ptr<A>a){pa=a;cout<<"B构造..."<<endl;}~B(){cout<<&quo......
  • 虚函数表 和 虚函数指针
     虚函数指针vptr大小x86平台下为4个字节,x64平台下为8个字节例题:涉及内存对齐 答案:32位miaoage=264位miaoage=1核心在这句话上p【1】=q【1】;由于两个子类都继承自有虚函数的基类因此都带有虚表指针首先基类中只有一个int432位下,虚表指针也是4......