博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
C++day05 学习笔记
阅读量:5809 次
发布时间:2019-06-18

本文共 2327 字,大约阅读时间需要 7 分钟。

1、变量的存储

   (1)内存是一块空间,把其中的每个字节做了编号,为了以后计算机能通过编号找到数据
   (2)编址方式:绝对编址(在整个程序中使用),相对编址(字节相对于逻辑0偏移量,在进程中使用)

2、取变量地址

   (1)"&"  &i 表示取内存中i的地址
        地址的编址用十六进制表示
   (2)逻辑0在代码区
        全局变量在数据区,地址的编址是大于0的
        局部变量在栈区,地址的编址是小于0的
   
3、数组、结构的地址
   (1)数组中的数据在内存中是连续存储的。 数组中每个元素的地址相差的值应为数组元素类型的大小。
   (2)结构的地址:
        结构的空间是连续的。
        结构的起始地址与第一个成员变量的地址是一样的。

4、存储地址—

   指针:存储变量的地址
   指针的类型由将要保存的地址的变量类型决定
   int*只能保存int变量的地址
   指针赋值一定要是同类型的指针才能相互赋值!
  
5、指针的运算
   (1)指针和指针之间的运算
      “+”,“*”,“/” 指针与指针间是不能做这些运算,没有意义!
      “-” 可以做减法运算,以“sizeof(指针类型)”作为计算单位的!    注意:要同类型的指针才能做此运算,不同的话,会对运算单位产生歧义。
  (2)指针和数字之间的运算(加、减都可以)
      int i = 100;
      int * p = &i;
      打印 p+1  -> 相当于在地址上加4,因为存储的变量是int类型的
           p+2  -> 相当于在地址上加8

6、通过指针访问所指向的变量

   *p 代表指针p所指向的变量  *p <=> i
  
   指针在声明的时候,即初始化
   int * p = NULL;  表示没有明确指向,不能 *p ,会出现 “段错误”的异常  -->空指针
  
   段错误原因 (1)空指针
              (2)数组越界
              (3)递归的条件不正确
             
7、课堂练习
    用指针打印出数组中个元素的值

#include 
using namespace std; int main(){ int ai[6]={
34,4,12,67,34,2}; int *p = &ai[0]; for(int i = 0 ; i < 6 ; i++){ cout <<"a[" << i << "]=" <<*(p+i) << endl; } return 0; }

 

int *p = ai ; 数组的本质就是用指针实现的,数组的名字就代表数组的首地址(起始地址)                 数组的名字是指向数组首地址(a[0])的指针                     ai 数组名,就是指向数组首地址的指针,可以用下标取元素,也可以把数组名当指针来访问元素   *(ai+n)    p  指针名,也是指向首地址的指针,也可以通过下标(像数组名一样)访问数组元素        p[n] <=>  *(p+n)

8、结构指针

struct person{        int id;        int age;   }      int main(){        person per = {
1,20}; person* p = &per; cout << "per.id ="<
<
id=" << p->id <
age=" << p->age <

9、指针的地址

   指针变量在内存中占4个字节(与类型无关,因为保存地址的指针只保存地址)
   保存int型指针(int* p = &i)的地址用int**保存(int** pp = &p)

#include 
using namespace std; int main(){ int i = 0 ; int * p = &i ; int ** pp = & p ; cout<<"&i = " << &i << endl; cout<<"p = " << p << endl; cout<<"&p = " << &p << endl; cout<<"pp = " << pp << endl; cout<<"&pp = " << &pp << endl; cout<<"i = " <
<< endl; cout<<"*p = " << *p << endl; cout<<"*pp = " << *pp << endl; cout<<"**pp = " << **pp << endl; return 0 ; }

执行结果:

&i = 0xffbffbecp = 0xffbffbec&p = 0xffbfbe8pp = 0xffbfbe8&pp = 0xffbffbe4i = 0*p = 0*pp = 0xffbffbec**pp = 0

     pp  ->  p  ->  i   指向关系

      pp=&p     p=&i
      *pp=p     *p=i       **pp=*p=i

转载于:https://www.cnblogs.com/tangzhengyue/archive/2012/08/04/2622584.html

你可能感兴趣的文章
网络直播被严查,机器如何帮助鉴别小黄图?
查看>>
用小米手环装逼,你不可不知的五个姿势
查看>>
海妖音乐魏清晨:科技读心术
查看>>
手机只需发条消息即可开始大规模SQL注入攻击
查看>>
数据中心基础架构标准化能否彻底改变超大规模IT部署?
查看>>
存储技术复杂性的代价
查看>>
读懂三大技术特征,再看物联网制式之争
查看>>
网络安全创企Synack获2100万美元C轮融资,微软领投
查看>>
逻辑备份和物理备份简单理解
查看>>
《测试驱动的嵌入式C语言开发》——2.3节CppUTest:一个用C++实现的自动化单元测试框架...
查看>>
C919开启中国民航新时代 安防也应打造中国“芯”
查看>>
ACL论文分享:修改生成对抗网络,训练半监督问答模型|分享总结
查看>>
欧盟网络安全法案对英国产业意味着什么?
查看>>
LinkedIn终于进军视频领域 不过貌似有点晚
查看>>
RabbitMQ:四种ExChange用法
查看>>
半监督组稀疏表示:模型、算法与应用(ECAI 2016论文精选)| AI科技评论
查看>>
从德国能源转型中学什么?
查看>>
《Android的设计与实现:卷I》——第1章 1.2Android体系结构
查看>>
《程序员度量:改善软件团队的分析学》一峰值和谷值
查看>>
《Linux高性能服务器编程》——3.10 拥塞控制
查看>>