热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

C语言入门篇(二)指针的介绍和运用

一.内存1.内存的含义:内存是沟通CPU和硬盘的桥梁:(1)暂存CPU中的运算数据(2)暂存与

 一.内存

  1.内存的含义:

    内存是沟通CPU和硬盘的桥梁: 

      (1)暂存CPU中的运算数据

      (2)暂存与外部存储器交换的数据

    物理存储器:实际存在的具体存储器芯片

               主板上装插的内存条

            显示卡上的显示RAM芯片

          各种适配卡上的RAM芯片和ROM芯片

     存址空间:对存储器编码的范围。我们在软件上常说的内存是指这一层含义

      (1)编码:对每个物理存储单元(一个字节)分配一个号码

      (2)寻址:可以根据分配的号码找到相应的存储单元,完成数据的读写

         理解:可以将内存 抽象理解为一个超大的一维字符数组,通过下标(对每个字节分配的号码-与操作系统有关,例如 操作系统为32位,号码就是32位的编号)

         拓展:现在可以理解为什么系统会影响内存的性能,32位操作系统寻址范围 就是 2的32次方也就是4G 所以最大内存为4G

  指针和指针变量:

      (1)内存中每一个字节都有自己的编号,这就是“地址”

      (2)如果程序中定义了一个变量,程序运行或者编译时,系统就会给这个变量分配内存单元,并确定他的地址(编号)

      (3)指针实质就是内存“地址”。指针就是地址,地址就是指针

      (4) 指针是内存单元的编号,指针变量是存放地址的变量

  

  关于野指针,空指针,万能指针大家可以去找些资料,这里只贴代码,不做解释

  此处强调一下 ,将NULL赋给指针,此指针就被称为空指针,因为NULL是一个值为0的宏常量

  什么是宏?

    (百度百科)宏是一种规则或模式,或称语法替换 ,用于说明某一特定输入(通常是字符串)如何根据预定义的规则转换成对应的输出(通常也是字符串)。这种替换在预编译时进行,称作宏展开。

  二:const修饰指针变量

    const 限定一个变量不允许被改变,产生静态作用

    用const修饰变量是不安全的 (可以通过高一级指针修改)

    const int * i  = &a    等价于 int const * i = &a    此时const修饰的是 int *  ,所以 *i 是不允许赋值 ,也就是不能间接修改a的值,但是指向地址可以 修改 如 i = &b 

    int * const i = &a     此时const修饰的是 变量 i ,所以i 指向的地址不能修改,但是 *i = 200 可以通过,也就修改了a 的值

    const int *  const i = &a  值和地址都不能修改   

  三:指针和数组

    int [] i = {1,2,3,4,5};

    i 为数组第一个元素的地址,但他是一个常量

    i = 10 ;   // 发生错误,因为虽然 i 指向元素地址,但是i是一个常量

    sizeof() 方法 ,判断占用多少字节

  四:指针加减运算

    指针的加减运算不像我们所想到加减

    如果一个 int * ,+1的结果就是增加了一个int 类型大小   -----int * i = 20; i = i+1;  就是原地址移动4位

    如果是一个char *,+1的结果是增加一个char大小 --------  ...

    什么类型 * + 1 就移动原地址一个类型位 (指针乘除没有意义)

  五:多级指针

    C语言允许有多级指针存在,在实际的程序中一级指针最常用,其次是二级指针。

    二级指针就是指向一个一级指针变量地址的指针,三级......

    int a = 1;

    int * b = &a;  //一级指针,指向a的地址

    int **c = &b; // 二级指针,指向b的地址 ,*c 就是 b , *cc 就是 a

    int ***d = &c; //三级指针,指向c的地址,*d就是c,**d就是b,***d就是a

 

  

 

    

      

 

 


转载于:https://www.cnblogs.com/Mr-Hai/p/10245181.html


推荐阅读
  • 深入解析Java虚拟机(JVM)架构与原理
    本文旨在为读者提供对Java虚拟机(JVM)的全面理解,涵盖其主要组成部分、工作原理及其在不同平台上的实现。通过详细探讨JVM的结构和内部机制,帮助开发者更好地掌握Java编程的核心技术。 ... [详细]
  • 本文探讨了如何使用自增和自减运算符遍历二维数组中的元素。通过实例详细解释了指针与二维数组结合使用的正确方法,并解答了常见的错误用法。 ... [详细]
  • 在高并发需求的C++项目中,我们最初选择了JsonCpp进行JSON解析和序列化。然而,在处理大数据量时,JsonCpp频繁抛出异常,尤其是在多线程环境下问题更为突出。通过分析发现,旧版本的JsonCpp存在多线程安全性和性能瓶颈。经过评估,我们最终选择了RapidJSON作为替代方案,并实现了显著的性能提升。 ... [详细]
  • 主调|大侠_重温C++ ... [详细]
  • 深入解析Redis内存对象模型
    本文详细介绍了Redis内存对象模型的关键知识点,包括内存统计、内存分配、数据存储细节及优化策略。通过实际案例和专业分析,帮助读者全面理解Redis内存管理机制。 ... [详细]
  • 本文详细介绍了C语言的起源、发展及其标准化过程,涵盖了从早期的BCPL和B语言到现代C语言的演变,并探讨了其在操作系统和跨平台编程中的重要地位。 ... [详细]
  • JavaScript 基础语法指南
    本文详细介绍了 JavaScript 的基础语法,包括变量、数据类型、运算符、语句和函数等内容,旨在为初学者提供全面的入门指导。 ... [详细]
  • JSOI2010 蔬菜庆典:树结构中的无限大权值问题
    本文探讨了 JSOI2010 的蔬菜庆典问题,主要关注如何处理非根非叶子节点的无限大权值情况。通过分析根节点及其子树的特性,提出了有效的解决方案,并详细解释了算法的实现过程。 ... [详细]
  • 深入解析Java枚举及其高级特性
    本文详细介绍了Java枚举的概念、语法、使用规则和应用场景,并探讨了其在实际编程中的高级应用。所有相关内容已收录于GitHub仓库[JavaLearningmanual](https://github.com/Ziphtracks/JavaLearningmanual),欢迎Star并持续关注。 ... [详细]
  • 本题来自WC2014,题目编号为BZOJ3435、洛谷P3920和UOJ55。该问题描述了一棵不断生长的带权树及其节点上小精灵之间的友谊关系,要求实时计算每次新增节点后树上所有可能的朋友对数。 ... [详细]
  • 本文介绍如何从字符串中移除大写、小写、特殊、数字和非数字字符,并提供了多种编程语言的实现示例。 ... [详细]
  • 本文介绍了一种基于选择排序思想的高效排序方法——堆排序。通过使用堆数据结构,堆排序能够在每次查找最大元素时显著提高效率。文章详细描述了堆排序的工作原理,并提供了完整的C语言代码实现。 ... [详细]
  • 本文深入探讨了MySQL中常见的面试问题,包括事务隔离级别、存储引擎选择、索引结构及优化等关键知识点。通过详细解析,帮助读者在面对BAT等大厂面试时更加从容。 ... [详细]
  • 本题要求在一个长度为n的数组中找出任意一个重复的数字。数组中的所有数字都在0到n-1之间,但具体哪些数字重复以及重复次数未知。 ... [详细]
  • 本文详细介绍了8051系列微控制器的中断系统,特别是C51编译器中interrupt和using关键字的作用及其使用方法。通过深入分析这两个关键字的功能,帮助开发者更好地理解和优化中断程序的设计。 ... [详细]
author-avatar
actthank90909
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有