<c和指针>学习笔记5动态内存分配和预处理器
1 动态内存
比如声明数组得时候,我们需要提前预估数组长度,分配大了浪费,少了就更不好操作了。从而引入动态分配,需要的时候再分配。
(1)malloc和free
void *malloc(size_t size)
void free(void *pointer)
注意需要对每个malloc返回的指针进行检查,确保不是NULL。
(2)calloc和realloc
malloc和callo得区别是后者在返回指向内存的指针之前把它初始化位0
void *calloc(size_t num_elements,size_t element_size)
realloc用于修改一个原先已经分配好的内存块大小
void realloc(void *ptr,size_t new_size)
(3)动态内存分配得用法
比如想足够存储25个整数的内存
pi=malloc(25*sizeof(int))
(4)小技巧之malloc宏定义
#include <stdlib.h>
//如果程序偶尔调用malloc 程序由于错误无法编译
#define malloc 不要直接使用malloc
//接受元素得数目以及每种元素得类型 计算总共需要的内存字节数。alloc调用malloc并检查,确保返回的指针不是NULL
#define MALLOC(num,type) (type *)alloc((num)+sizeof(type))
#include "alloc.h"
#undef malloc
void* alloc(size_t size)
{
void * new_mem;
new_mem=malloc(size);
if(new_mem==NULL)
{
printf("out of memory!\n");
exit(1);
}
return new_mem;
}
2 预处理器
(1)预定义符号
__FILE__:文件的文件名
__LINE__:文件当前行的行号
__DATA__:文件被编译的日期
__TIME__:文件被编译得时间
这几个常用于debug输出
#define DEBUG_PRINT printf("FILE %s line %d:"\
"x=%d,y=%d,z=%d",\
__FILE__,__LINE__,\
X,Y,Z)
(2)#define
#define name stuff
每当符号name出现在这条指令后面时,预处理器就会把它替换成stuff,当然,替换文本不仅限于数值字面值chagnl,也可以如下
#define reg register
#define do_forever for(;;)
#define CASE break;case;
常见错误
#define SOUARE(X) X*X
a=5
printf("%d\n",SOUARE(a+1))//11 不是36哦,实际上是a+1*a+1
(2)#和##
#:可以将宏参数转换为一个字符串
#define PRINT(FORMAT,VALUE) \
printf("the value of" #VALUE \
" is " FORMAT "\n",VALUE)
PRINT("%d",x+3)
##它是位于它两边的符号链接成一个符号
(3)#undef
这条预处理指令用于移除一个宏定义
(4)条件编译
可以选择代码的一部分被正常编译还是完全忽略
#if statement #if DEBUG
staement printf("x=%d,y=%d\n",x+y)
#endif #endif
如果要使用 就应该使用#defnie DEBUG 1
(5)文件包含
本地包含:使用“ ” 例如#include “a.h”
函数库文件:使用<> 例如#include <stdio.h>在linux中通常去/usr/include查找
注意:
为了避免头文件重复包含
#ifndef __a__h
#define __a__h 1
#endif
<c和指针>学习笔记5动态内存分配和预处理器的更多相关文章
- C++学习笔记(十一):void*指针、类型转换和动态内存分配
void*指针 void关键字表示“空类型”的概念.但是,这里的“空类型”不表示“任意类型”,而是表示不存在的意思,也就是说C/C++不允许你写语句void a,不存在类型为void的东西. void ...
- C和指针 第十一章 动态内存分配
声明数组时,必须指定数组长度,才可以编译,但是如果需要在运行时,指定数组的长度的话,那么就需要动态的分配内存. C函数库stdlib.h提供了两个函数,malloc和free,分别用于执行动态内存分配 ...
- C和C指针小记(十六)-动态内存分配
动态内存分配 1.1 为什么使用动态内存分配 直接声明数组的方式的缺点: 1) 声明数组必须指定长度限制.无法处理超过声明长度的数组. 2) 如果声明更大的常量来弥补第一个缺点,会造成更多的内存浪费. ...
- 深入理解C指针----学习笔记
深入理解C指针 第1章 认识指针 理解指针的关键在于理解C程序如何管理内存,指针包含的就是内存地址. 1.1 指针和内存 C程序在编译后,以三种方式使用内存: 1. 静态. ...
- C++的智能指针学习笔记(初)
C++ primer plus 16.2节介绍了auto_ptr,该模板类在C++11中已弃用,目前已被shared_ptr代替. auto_ptr又叫做智能指针,用于管理动态内存分配的用法. 为什么 ...
- C++学习 之 指针及动态内存分配(笔记)
1. 指针 1.1 指针的含义: 简单来说,指针是存储内存地址的变量.当我们声明了一个指针变量后,使用该指针时系统会根据指针内的地址索引内存块,读取内存内的值.指针因为是用来存地址的,所以一般固定长度 ...
- [C++学习笔记14]动态创建对象(定义静态方法实现在map查找具体类名对应的创建函数,并返回函数指针,map真是一个万能类)good
[C++学习笔记14]动态创建对象 C#/Java中的反射机制 动态获取类型信息(方法与属性) 动态创建对象 动态调用对象的方法 动态操作对象的属性 前提:需要给每个类添加元数据 动态创建对象 实 ...
- 《C和指针》 读书笔记 -- 第11章 动态内存分配
1.C函数库提供了两个函数,malloc和free,分别用于执行动态内存分配和释放,这些函数维护一个可用内存池. void *malloc(size_t size);//返回指向分配的内存块起始位置的 ...
- C语言学习笔记--动态内存分配
1. 动态内存分配的意义 (1)C 语言中的一切操作都是基于内存的. (2)变量和数组都是内存的别名. ①内存分配由编译器在编译期间决定 ②定义数组的时候必须指定数组长度 ③数组长度是在编译期就必须确 ...
随机推荐
- jquery获取表单元素与回显
一.获取哦表单元素 dcoument表单文本对象的集合 all[] 对所有html元素的访问 forms 返回对文档中所有form对象的引用 forms[1] 对所有form对象引用 <scri ...
- delphi通过Idhttp和php交互
最近需要做delphi和php交互的方法: 就把这2个方法写了下 一,Get方法 const Url = 'http://www.cnblogs.com'; procedure TForm1.Butt ...
- 什么是shell【TLCL】
常用命令 date cal df——report file system disk space usage free——display amount of free and used memory i ...
- J2EE 领域的一些技术框架结构图
J2EE 领域的一些技术框架结构图 阿里百川,开启移动应用开发的新篇章 1.Spring 架构图 Spring 是一个开源 框架,是为了解决企业应用程序开发复杂性而创建的.框架的主要优势之 ...
- ML二(决策树学习)
决策树学习 Decision Tree Learning 1 基本概念 属性(attribute):树上的每个结点说明了对实例的某个属性的测试,该结点的每一个后继分支对应该属性的一个可能值. 熵(en ...
- JQUERY Uploadify 3.1 C#使用案例
近来因为要做一个上传功能,而firefox又不能直接使用file这样的标签,所以试着用js来写了一个,结果发现代码太多,验证太复杂,而且效果也不理想. 相对的,jquery提供的这一套uploadif ...
- Java_异常_04_ OutOfMemoryError系列
二.参考资料 1.铁猫 OutOfMemoryError系列(1): Java heap space OutOfMemoryError系列(2): GC overhead limit exceeded ...
- Bootstrap-other内置组件
1.缩略图 缩略图在网站中最常用的地方就是产品列表页面,一行显示几张图片,有的在图片底下(左侧或右侧)带有标题.描述等信息.Bootstrap框架将这一部独立成一个模块组件.并通过“thumbnail ...
- Agc016_D XOR Replace
传送门 题目大意 给定两个长为$n$的序列$A,B$你可以进行若干组操作,每次操作选定一各位置$x$,令$A_x$等于$A$的异或和. 问能否通过一定操作使得$A$成为$B$,如果能,求最小操作书数. ...
- 股神小D
题目大意: 给定一棵树,每一条边有$L,R$两种权值,求有多少条路径满足$\max(L)\leq\min(R)$. 解法$1-$点分治$+$二维数点 统计树上的路径应首先想到点分治,我们很显然可以搜出 ...