malloc,colloc,realloc内存分配,动态库,静态库的生成与调用



1.在main方法里面直接定义一个非常大的数组的时候,可能会出现栈溢出:错误代码演示:

#include<stdio.h>

#include<stdlib.h>

void
main()

{

int
a[1024 * 1024];

int
num = 100;

system("pause");

}

错误截图:

2.在定义数组的时候要定义数组的长度,否则会出现错误。(特例:在GCC编译器下,不会出现错误(因为标准不一样))。

3.打印并且赋值的是:

for (int
i = 0;
i <
length;i++)

{

printf("%d\n",a[i]
= i); 
//初始数组并打印

}

4.内存分配可以通过三个函数实现

A.void *malloc(size_t size):malloc只管分配,不初始化内容(size:Bytes
to allocate:分配的字节数)。

B.void *calloc(size_t,size_t size):分配内存,并且初始化内存信息为0,其有两个参数(num:Number
of elements;size:Length in bytes of each element),第一个参数是,开辟的数量,第二个参数是每个参数的大小。

C.void *realloc(void *memblock,size_t size);Reallocatememory blocks;用于分配内存.

memblock:Pointer to previously alloctedmemory block;

size:New size in bytes

例如:

int *p1 = (int*)malloc(sizeof(int)*10);//只管分配,不初始化

int *p2 = (int*)calloc(10,sizeof(int));//calloc会进行内存清零

例子:

#include<stdio.h>

#include
<stdlib.h>

int
main(int
argc,
char *argv[])

{

//只管分配

int *p1
= (int *)malloc(sizeof(int)*
10);

//calloc会进行内存清零

int *p2
= (int *)calloc(10,
sizeof(int));

printf("%p,%p",
p1,
p2);

for (int
i = 0;
i < 10;
i++)

{

p1[i]
= i;

p2[i]
= i;

}

getchar();

return 0;

}

5.realloc分配内存

#include
<stdio.h>

#include<stdlib.h>

void
main()

{

//分配内存

int *p
= (int *)calloc(10,sizeof(int));

printf("%p\n",
p);//输出地址

int
i;

for (i
= 0; i < 10;i++)

{

//*(p + i)等价于p[i]

*(p +
i) =
i;

}

//变长,第一个参数是指针地址,第二个参数表示的是数组的个数

int *pnew
= (int *)realloc(p,100000);

//realloc.第一种情况,后面的内存没有用,就直接扩展变长

//第二种情况,后面的内存有人用,先分配新的长度,拷贝原来原来的内存,释放原来的内存

printf("%p",pnew);

for (int
i = 10;
i < 25000;i++)

{

*(pnew +
i) =
i;

}

system("pause");

return 0;

}

6.新建项目dlllib

编写代码:

#include<stdio.h>

#include<stdlib.h>

void
go()

{

printf("Hello
World\n");

}

7.制作dll,右击项目à属性à配置属性à常规à分别修改配置类型(动态库.dll)和目标文件名。

8.制作lib,右击项目à属性à配置属性à常规à分别修改配置类型(动态库.lib)和目标文件名。

9.引入lib.lib的方式有

A:将.lib拷贝到源代码所在的目录下。à通过代码引入.lib。代码是:

#pragma comment(lib,”test.lib”);  //其中test.lib就是要引入的.lib静态库(注意,也要将静态库对应的.h放到源文件所在的位置)。

B:将.lib拷贝到源代码所在的目录下。à通过配置的方式引入静态库。方式是:

右击项目à属性à配置属性à输入à附加依赖项(如现有依赖项添加的方式添加.lib静态库)。

malloc,colloc,realloc内存分配,动态库,静态库的生成与调用,布布扣,bubuko.com

时间: 2024-08-10 02:10:08

malloc,colloc,realloc内存分配,动态库,静态库的生成与调用的相关文章

Linux 动态库 静态库

什么是库 本质上来说库是一种可执行代码的二进制形式,可以被操作系统载入内存执行.由于windows和Linux的本质不同,因此二者库的二进制是不兼容的.Linux操作系统支持的库函数分为静态库和动态库,动态库又称共享库.Linux系统有几个重要的目录存放相应的库函数,如/lib,/usr/lib;头文件放在/usr/include. 什么是静态库 静态库的名字一般是libxxx.a;利用静态函数库编译成的文件比较大,因为整个函数库的所有数据都被整合进目标代码中,他的优点就显而易见了,即编译后的执

C++基础知识之动态库静态库

一. 静态库与动态库 库(library),一般是一种可执行的二进制格式,被操作系统载入内存执行. 我们通常把一些公用函数制作成函数库,供其它程序使用.函数库分为静态库和动态库 静态库和动态库区别: 静态库在程序编译时会被连接到目标代码中,程序运行时将不再需要该静态库.因此,使用了静态库的可执行程序存储在磁盘上的空间就比较大. 动态库在程序编译时并不会被连接到目标代码中,而是在程序运行是才被载入,因此在程序运行时还需要动态库存在. 静态库和动态库命名规范: linux: 静态库文件名的命名规范是

Linux 下动态库 / 静态库(依赖)

一. 依赖动态库的动态库 libfun.so依赖动态库libtest.so(libfun.so动态库里的函数intnothing()调用了libtest.so里的intmytest()函数),而main.exe又调用了libfun.so的函数int nothing(). 下面两种方式都能工作: 1> 常用的方式 g++ -shared -fPIC -o libtest.so test.cpp g++ -shared -fPIC -o libfun.so function.cpp  -L./ -I

动态库静态库差异对比

最近在做一个项目需要http接口,由此将框架中依赖libcurl的http单独拿来用 libcurl提供两种库:静态库跟动态库,首先curl目下只提供了libcurl.a,并没有生成libcurl.so,由此开始编译依赖静态的http.sog++ -shared -fPIC -o lib/libhttp.so http_handle.cpp -I./ -I./curl-7.34.0/include -L./ -lcurl ./lib/libhttp.so: undefined reference

c/c++:动态库 静态库 linux/windows 例子 (转)

作者:吴秦出处:http://www.cnblogs.com/skynet/本文基于署名 2.5 中国大陆许可协议发布,欢迎转载,演绎或用于商业目的,但是必须保留本文的署名吴秦(包含链接). C++静态库与动态库 这次分享的宗旨是——让大家学会创建与使用静态库.动态库,知道静态库与动态库的区别,知道使用的时候如何选择.这里不深入介绍静态库.动态库的底层格式,内存布局等,有兴趣的同学,推荐一本书<程序员的自我修养——链接.装载与库>. 什么是库 库是写好的现有的,成熟的,可以复用的代码.现实中每

Python、编译解释、动态库静态库、编译过程、头文件了解一下

学习Python这门语言首先要了解 什么是编译与解释,什么是连接,什么是动态库与静态库, 什么是编译: 编译就是先把高级语言设计的程序翻译成二进制的机器语言,然后CPU直接执行机器码就可以了.一把翻译再执行 编译型语言在于速度快. 什么是解释: 解释就是在程序运行时,才把高级程序语言一条一条地翻译成二进制的机器语言.边运行边翻译成二进制机器语言.所以速度没有编译来得快.边执行边翻译 解释型语言的优点在于可以跨平台. Python语言的优点: 可移植性.可扩展性.可嵌入性 简单.优雅.明确 开发效

g++动态库静态库混合链接

今天编译一个程序时报错: g++ -static -o echo.fcgi echo_adaptor.o echo.o -L/usr/local/lib/ -lfastcgipp -L/usr/lib/ -lboost_thread -pthread -lboost_system -lboost_date_time -L/home/chu/lib/ -lwebframework -L/usr/local/lib/ -lctemplate_nothreads -L/usr/lib64/mysql/

(转)linux centos 编译luabind-0.9.1 动态库 静态库

编译时:virtual memory exhausted: Cannot allocate memory 一.问题 当安装虚拟机时系统时没有设置swap大小或设置内存太小,编译程序会出现virtual memory exhausted: Cannot allocate memory的问题,可以用swap扩展内存的方法. 二.解决方法 在执行free -m的是时候提示Cannot allocate memory: (swap文件可以放在自己喜欢的位置如/var/swap) [html] view

【C/C++学院】0801-重定向以及文件扫描/二进制加密解密/简单加密/按照密码加密/动态库与静态库

重定向以及文件扫描 #define _CRT_SECURE_NO_WARNINGS//关闭安全检查 #include<stdio.h> #include<stdlib.h> void main1() { char str[100] = { 0 }; scanf("%s", str); printf("str=%s\n", str); system(str); } void main2() { char str[100] = { 0 }; fs