指针的特点

  • 他就是内存中的一个地址
  • 指针本身运算
  • 指针所指向的内容是可以操作的

操作系统是如何管理内存的

栈空间

  • 4M~8m的大小
  • 当进入函数的时候会进行压栈数据

堆空间

  • 4g的大小 1g是操作系统
  • 全局变量

内存映射

  • 可以对内存的内容修改修改硬盘的内容
  • 一般在数据库中经常使用

内存的分配与释放

  • c语言分配内存的方法

    1. // malloc(需要分配的大小); 这里的分配的大小需要对齐的2的指数
    2. void *mem = malloc(size);
  • 释放内存

    1. // 一般分配的内容都是在堆空间中的
    2. // 如果使用完不去释放会照成内存泄漏和野指针的出现
    3. free(men);
  • 什么是内存泄漏:

    • 不断的向系统申请内存
    • 申请的内存不用,也不去释放
    • 绝对不允许内存泄漏
  • 什么是野指针

    • 这个指针已经被释放掉了
    • 别人又创建了这个指针
    • 过去的自己又用到了这个指针

函数指针

返回值类型(*指针变量名)(参数列表);

  1. int func(int x); // 声明一个函数
  2. int (*f)(int x); // 声明一个函数指针
  3. f = func; // 将func函数的首地址赋值给指针f
  1. #include <stdio.h>
  2. int sum (int a, int b)
  3. {
  4. return (a+b);
  5. }
  6. int main(int argc, int *argv[])
  7. {
  8. // 定义一个函数指针
  9. int (*f) (int, int);
  10. // f 指向 sum函数
  11. f = sum;
  12. // 执行f函数,相当于执行sum函数
  13. int f_sum = f(2,3);
  14. printf("f_sum: %d\n", f_sum);
  15. return 0;
  16. }

指针就是内存地址: void*、 char*

数组就是:char c[2]、 int arr[10],指连续相同类型的空间

  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. int main(int argc, char *argv[])
  4. {
  5. // 定义两个int类型的指针
  6. int *a, *b;
  7. // 通过malloc在堆里面开辟了空间
  8. a = (int*)malloc(sizeof(int));
  9. b = (int*)malloc(sizeof(int));
  10. *a = 1;
  11. *b = 2;
  12. // 指针a的地址是&a, a是指向空间的地址,*a是指向空间的值
  13. printf("addr of a:%p, %p, %d\n", &a, a, *a);
  14. printf("addr of b:%p, %p, %d\n", &b, b, *b);
  15. return 0;
  16. }

  1. #include<stdio.h>
  2. #include<stdlib.h>
  3. int main(int argc, char *argv[])
  4. {
  5. // 创建一个数组c里面有3个数据,int类型的数组一个数组占4个字节,地址相关的空间相差是1个字节
  6. int c[3] = {1,2,3};
  7. printf("c的地址:%p\t%p\tc[0]:%p\tc[1]:%p\tc[2]:%p\t\n",c, &c, &c[0], &c[1], &c[2]);
  8. printf("%d, %d, %d\n", c[0], c[1], c[2]);
  9. }

C语言中的指针与数组的定义与使用的更多相关文章

  1. 深入理解C语言中的指针与数组之指针篇

    转载于http://blog.csdn.net/hinyunsin/article/details/6662851     前言 其实很早就想要写一篇关于指针和数组的文章,毕竟可以认为这是C语言的根本 ...

  2. 深入理解C语言中的指针与数组之指针篇(转载)

    前言 其实很早就想要写一篇关于指针和数组的文章,毕竟可以认为这是C语言的根本所在.相信,任意一家公司如果想要考察一个人对C语言的理解,指针和数组绝对是必考的一部分. 但是之前一方面之前一直在忙各种事情 ...

  3. C语言中的指针和数组

    下面的内容节选自由我所执笔的会议记录.对于本文的不足之处,各位可以提出自己的看法. Q1:指针和数组到底是怎么一回事? A:指针和数组有本质的不同.指针就是一个内存地址,在32位系统下,一个指针永远占 ...

  4. C语言中的指针数组

    C语言中的指针数组是什么,像 char *a[]={"ddd","dsidd","lll"}; 这里讲一下注意如果我们使用了a也就是首元素的 ...

  5. 转: 浅谈C/C++中的指针和数组(二)

    转自:http://www.cnblogs.com/dolphin0520/archive/2011/11/09/2242419.html 浅谈C/C++中的指针和数组(二) 前面已经讨论了指针和数组 ...

  6. C语言中的指针笔记

    C语言指针 得到变量的地址 可以使用&运算符找到变量保存在内存中的位置 int x = 1; printf("x的内存地址是"%p\n",&x) %p格式 ...

  7. C语言中的指针加减偏移量

    C语言指针偏移技巧(也是一个要注意的坑) - 陈杰柱的博客 - CSDN博客  https://blog.csdn.net/cjzjolly/article/details/82116772 C语言中 ...

  8. 转:浅谈C/C++中的指针和数组(一)

    再次读的时候实践了一下代码,结果和原文不一致 error C2372: 'p' : redefinition; different types of indirection 不同类型的间接寻址 /// ...

  9. 【ZZ】C 语言中的指针和内存泄漏 & 编写高效的C程序与C代码优化

    C 语言中的指针和内存泄漏 http://www.ibm.com/developerworks/cn/aix/library/au-toughgame/ 本文讨论了几种在使用动态内存分配时可以避免的陷 ...

随机推荐

  1. P1030 求先序排列 (一个非常棒的写法)

    理论正确就是真正的正确,误... 就是找嘛,找到每一个对应字符,然后对应的左右子树的区间,然后就可以了. #include <bits/stdc++.h> using namespace ...

  2. nginx解决WordPress 上传到服务器后页面404错误的方法

    人啊,要说你傻了吧,真是啥事都能碰到: 因为换了nginx,把新做的上传到服务器配置好后,就主页和后台能打开,其他的所有页面,全是404,果真404和502是我最讨厌的数字啊,这让我很怀疑人生啊,怀疑 ...

  3. html学习-第二集(CSS)

    head标签里面添加style标签,可以为标签添加样式 id选择器 类选择器 标签选择器 层级选择器 组合选择器 属性选择器 <!DOCTYPE html> <html lang=& ...

  4. 【Struts APP_PATH】StartSystemListener

    StartSystemListener package k.filter; import javax.servlet.ServletContext; import javax.servlet.Serv ...

  5. HashMap遍历,取出key和value

    HashMap的遍历有两种常用的方法,那就是使用keyset及entryset来进行遍历,在用keySet(key)取value时候,需要key 第一种: Map map = new HashMap( ...

  6. mysql学习笔记(二:中的auto_increment 理解

    1.auto_increment 理解1 auto_increment是用于主键自动增长的,从1开始增长,当你把第一条记录删除时,再插入第二跳数据时,主键值是2,不是1. 例如: create tab ...

  7. netty学习1

    1.IO java 自带IO流 1)同步处理方式,一个请求占用一个线程,高并发常见出现问题 2.java nio 实在jdk1.4版本上新添加的new IO / 非阻塞IO 可多路并发 3.Netty ...

  8. C语言:将3*4矩阵中找出行最大,列最小的那个元素。-将低于平均值的人数作为函数返回值,将低于平均分的分数放入below数组中。

    //将3*4矩阵中找出行最大,列最小的那个元素. #include <stdio.h> #define M 3 #define N 4 void fun(int (*a)[N]) { ,j ...

  9. 「luogu3380」【模板】二逼平衡树(树套树)

    「luogu3380」[模板]二逼平衡树(树套树) 传送门 我写的树套树--线段树套平衡树. 线段树上的每一个节点都是一棵 \(\text{FHQ Treap}\) ,然后我们就可以根据平衡树的基本操 ...

  10. ETCD实战

    一.建立集群 1.在每台机器上建立环境变量 TOKEN=token-01 CLUSTER_STATE=new NAME_1=machine-1 NAME_2=machine-2 NAME_3=mach ...