一、听课标准

1、选择法排序

2、会简单封装函数

3、数组做函数参数会退化为一级指针

  a、数组做函数参数时,应该吧数组元素个数也传递给函数

  b、形参中的数组,编译器把它仿作指针处理,c语言特色

  c、实参中的数组,和形参中数组本质不一样

void   fun(int a[]);//4字节
main(){
    , ,  };//12字节
    fun(a);
}

二、数据类型

1、类型的本质:固定内存大小的别名

2、数据类型的作用:编译器预算对象(变量)分配的内存空间大小

  int a;//告诉c编译器分配4个字节的内存

3、数据类型可以通过typedef起别名

4、可以通过sizeof()测类型大小

5、void ,无类型

1)、函数参数为空,定义函数时,可以使用void修饰:int fun(void)
2)、函数返回值没有返回值,使用void修饰
3)、不能定义void类型的普通变量:void a;//error,无法确定类型,不同类型分配空间不一样
4)、可以定义void*变量:void *p;//ok,32永远是4字节,64位永远是8字节
5)、数据类型本质:固定内存块大小别名
6)、void *p万能指针,函数返回值,函数参数

malloc(配置内存空间)

相关函数 calloc, free, realloc, brk

表头文件 #include<stdlib.h>

定义函数 void * malloc(size_t  size);

函数说明 malloc() 用来配置内存空间,其大小由指定的size决定

返回值  若配置成功则返回一指针,失败则返回NULL

范例 void  p = malloc(1024);/*  配置1k的内存 */

三、扩展知识

1)分文件时,头文件防止头文件重复包含

#pragma once

2)让c代码可以在c++编译器编译运行

// __cpluscplus 是编译器提供好的宏,不是自定义的

#ifdef __cpluscplus

extern "C"{

#endif //__cpluscplus

//函数的声明

#ifdef __cpluscplus

}

#endif //__cplusplus

四、变量

1、变量的本质;内存空间的别名

2、必须通过数据类型定义变量

3、变量相当于门牌号,内存相当于房间,通过门牌号找到房间,通过变量找到所对应的内存

4、变量的赋值:1)直接 2)间接

  

int a;
a=;
;
p=&a;//指针指向谁,就把谁的地址赋值给指针
*p=;//间接赋值

4、重点:没有变量,哪来内存,没有内存,拿来内存首地址

5、变量三要素(名称、大小、作用域),变量的生命周期

五、内存四区(栈区、堆区、全局区、代码区)

1、栈区:系统扥配空间,系统自动回收,函数内部定义的变量,函数参数,函数结束,其内部碧昂量声明周期结束

2、堆区:程序员动态分配空间,有程序员动手释放,没有手动释放,分配的空间一直可用

3、全局变量(全局变量和静态变量,里面有分为初始化区和为初始化区,文字常量区:字符常量):整个程序运行完毕,系统自动回收

4、内存四区模型图(c语言学好指针的关键)

5、a)栈区地址生长方向:地址有上往下递减

  b) 堆区地址生长方向:地址由下往上递增

  c) 数组buf,buf+1 地址永远递增

六、函数调用模型

1、程序各个函数运行流程(压栈弹栈、入栈出栈、先进后出)

七、指针也是一种数据类型

1、指针变量也是一种变量,也有空间,32位程序大小为4字节

int *p=0x1122;

2、*操作符,*相当于钥匙,通过*可以找到执政所指向的内存区域

;
int *p=NULL;
p=&a;//指针指向谁,就把谁的地址赋值给指针
*p=;//*放=左边,给内存赋值,写内存
int b=*p;//*放=右边,取内存的值,读内存

c语言提高篇 第一天的更多相关文章

  1. 嵌入式学习笔记(综合提高篇 第一章) -- 利用串口点亮/关闭LED灯

    1      前言 从踏入嵌入式行业到现在已经过去了4年多,参与开发过的产品不少,有交换机.光端机以及光纤收发器,停车场出入缴费系统,二维码扫码枪,智能指纹锁以及数字IC芯片开发等; 涉及产品中中既有 ...

  2. C语言提高 (1) 第一天 数据类型本质与内存四区

    (物联网的分层的概念 b/s c/s 结构 习惯: 在C语言 0 函数执行成功 <0是错误 >1做一些返回值处理 3 课前准备 工作经验,记录 4 数据类型的本质 数据类型的本质是固定大小 ...

  3. 明解C语言 入门篇 第一章答案

    练习1-1 #include <stdio.h> int main() { int a; a = 15; int b; b = 37; int c; c = a - b; printf(& ...

  4. 明解C语言 中级篇 第一章答案

    练习1-1 #include <stdio.h> #include<stdlib.h> int main() { srand(time()); ; printf("您 ...

  5. java提高篇(二)-----理解java的三大特性之继承

    在<Think in java>中有这样一句话:复用代码是Java众多引人注目的功能之一.但要想成为极具革命性的语言,仅仅能够复制代码并对加以改变是不够的,它还必须能够做更多的事情.在这句 ...

  6. java提高篇(二)-----理解java的三大特性之继承

    在<Think in java>中有这样一句话:复用代码是Java众多引人注目的功能之一.但要想成为极具革命性的语言,仅仅能够复制代码并对加以改变是不够的,它还必须能够做更多的事情.在这句 ...

  7. (转)java提高篇(二)-----理解java的三大特性之继承

    在<Think in java>中有这样一句话:复用代码是Java众多引人注目的功能之一.但要想成为极具革命性的语言,仅仅能够复制代码并对加以改变是不够的,它还必须能够做更多的事情.在这句 ...

  8. Java 学习笔记提高篇

    Java笔记(提高篇)整理   主要内容: 面向对象 异常 数组 常用类 集合 IO流 线程 反射 Socket编程 1.  面向对象 1.1包 用来管理Java中的类, 类似文件夹管理文件一样. 因 ...

  9. Java提高篇之理解java的三大特性——继承

    在<Think in java>中有这样一句话:复用代码是Java众多引人注目的功能之一.但要想成为极具革命性的语言,仅仅能够复制代码并对加以改变是不够的,它还必须能够做更多的事情.在这句 ...

随机推荐

  1. 01-css的引入方式

    [转]01-css的引入方式 引入css方式(重点掌握) 行内样式 内接样式 外接样式 3.1 链接式 3.1 导入式 css介绍 现在的互联网前端分三层: HTML:超文本标记语言.从语义的角度描述 ...

  2. 【代码笔记】Web-CSS-CSS Border(边框)

    一,效果图. 二,代码. <!DOCTYPE html> <html> <head> <meta charset="utf-8"> ...

  3. iOS----------对单元格取余

    if (indexPath.row % 2 == 0) { cell.backgroundColor = [UIColor magentaColor]; }else{ cell.backgroundC ...

  4. gitbook 入门教程之实用插件(新增3个插件)

    插件没有什么逻辑顺序,大家可以按照目录大纲直接定位到感兴趣的插件部分阅读即可. 更多插件正在陆续更新中,敬请期待... 最新更新插件 tbfed-pagefooter 版权页脚插件 gitalk 评论 ...

  5. 用canvas给视频图片添加特效

    Canvas制作视频图片特效 1. Canvas介绍 1.1Canvas是html5上的一个画布标签,功能有点类似java的swing.可以在canvas上画线条 弧线, 文字 就是画布的功能. 具体 ...

  6. MySQL下perror工具查看System Error Code信息

      在MySQL数据库的维护过程中,我们有时候会在MySQL的错误日志文件中看到一些关于Operating system error的错误信息,例如在MySQL的错误日志里面,有时候会看到关于 Inn ...

  7. kmalloc分配物理内存与高端内存映射--Linux内存管理(十八)

    1 前景回顾 1.1 内核映射区 尽管vmalloc函数族可用于从高端内存域向内核映射页帧(这些在内核空间中通常是无法直接看到的), 但这并不是这些函数的实际用途. 重要的是强调以下事实 : 内核提供 ...

  8. MySQL:1366 - Incorrect string value错误解决办法

    今天使用navicat向MySQL中插入中文时,报错: - Incorrect string value:... 在我自己数据库设计之初,没有设计好字符编码格式的问题. 使用如下语句解决: alter ...

  9. LeetCode算法题-Binary Tree Tilt(Java实现)

    这是悦乐书的第263次更新,第276篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第130题(顺位题号是563).给定二叉树,返回整棵树的倾斜度.树节点的倾斜被定义为所有 ...

  10. docker容器日志收集方案(方案N,其他中间件传输方案)

    由于docker虚拟化的特殊性导致日志收集方案的多样性和复杂性下面接收几个可能的方案 ​ 这个方案各大公司都在用只不过传输方式大同小异 中间件使用kafka是肯定的,kafka的积压与吞吐能力相当强悍 ...