当前位置: 首页 > news >正文

layerslider wordpressseo案例分析方案

layerslider wordpress,seo案例分析方案,百度sem认证,浅谈国内高校英文网站的建设现状1. 为什么要有动态内存分配 2. malloc和free 3. calloc和realloc 4. 常⻅的动态内存的错误 5. 动态内存经典笔试题分析 6. 总结C/C中程序内存区域划分 1.为什么要有动态内存管理 我们目前已经掌握的内存开辟方式有 int main() {int num 0; //开辟4个字节int arr[10] …

1. 为什么要有动态内存分配

2. malloc和free

3. calloc和realloc

4. 常⻅的动态内存的错误

5. 动态内存经典笔试题分析

6. 总结C/C++中程序内存区域划分

1.为什么要有动态内存管理
我们目前已经掌握的内存开辟方式有

int main()
{int num = 0;  //开辟4个字节int arr[10] = { 1,2,3,4,5,6 };return 0;
}

但是上边的开辟空间的方式有两个特点
1.空间开辟大小是固定的。
2. 数组在申明的时候,必须指定数组的长度,
数组空间一旦确定大小就不能调整

解决方法:
在这里插入图片描述
二、malloc和free
2.1 malloc
c语言提供了一个动态内存开辟的函数:
在这里插入图片描述
这个函数向内存申请的是一块连续可用的空间,并返回指向这块空间的指针

1.开辟成功,则返回一个指向开辟好空间的指针

2.开辟失败,则返回一个NULL指针,因此malloc的返回值一定要做检查

3.返回类型的是void * ,所以malloc函数并不知道开辟空间的类型,具体在使用者使用的时候自己来选择

4.如果参数size为0,malloc函数的行为标准是为定义的,取决于编译器。

2.2 free
c 语言还提供了另一个函数free,是专门用来做动态内存的释放和回收的(一般是要与malloc函数同时使用的),函数原型如下
在这里插入图片描述
1.如果参数ptr指向的空间不是动态开辟的,那么free函数是为定义的
2.如果参数ptr函数是NULL的话,则函数不需要做任何事

malloc 和free都在stdlib.h头文件中

#include<stdio.h>
#include<string.h>
#include<stdlib.h>int main()
{int arr[10] = { 1,2,3,4,5,6,7,8,9,10 };int ret = sizeof(arr) / sizeof(arr[0]);int* ptr = NULL;ptr=(int *)malloc(ret * sizeof(int));  //开辟内存if (ptr != NULL){for (int i = 0; i < ret; i++){*(ptr + i) = i;printf("%d ", *(ptr + i));}}free(ptr);  //释放内存ptr = NULL;  //这一步是否有必要?//(这里的作用是防止如果再次使用ptr进行判断,可以避免进行的访问)return 0;
}

这里我们来画图解释一下
在这里插入图片描述
三、calloc和recallo
除了malloc函数以外c语言还提供了另外一个函数calloc函数,calloc函数也可以用来进行动态内存的分配。原型如下:
在这里插入图片描述
1.函数的功能是为num个大小为size的元素开辟一块空间,并且把每个字节初始化为。
2.与malloc函数的区别只在与calloc会在返回地址之前把申请的空间的每个字节初始化为全0.

int main()
{int* pr = (int*)calloc(10, sizeof(int));if(pr!=NULL){for (int i = 0; i < 10; i++){printf("%d " ,*(pr+i));}}free(pr);pr = NULL;return 0;
}

在这里插入图片描述
这里我们可以知道如果我们想对申请的空间进行初始化的时候,就可以使用calloc函数来解决。

3.2
realloc函数的出现让动态内存的管理更加灵活。

  • 在有些情况下我们会发现申请的空间会过大或者过小,这时候我们就可以用realloc函数来对我们开辟内存的大小进行调整。
    在这里插入图片描述
    这里我们来解释一下
    1.ptr是要调整的内存地址
    2.size是调整之后新大小
    注意这个函数是在原有的内存大小的基础上,将原来的数据移动到的空间中
    3.realloc在调整内存空间是存在两种情况的
    3.1 原有的空间有足够大的空间情况
    3.2 原有空间之后没有足够大的空间
    在这里插入图片描述

情况1
当是情况1 的时候,要扩展内存就直接原有内存之后直接追加空间,原来空间的数据不发⽣变化。

情况2
当是情况2 的时候,原有空间之后没有⾜够多的空间时,扩展的⽅法是:在堆空间上另找⼀个合适⼤⼩的连续空间来使⽤。这样函数返回的是⼀个新的内存地址

由于这两种情况我们再使用realloc函数的时候就需要多注意一下

int main()
{int* ptr = (int*)malloc(25 * sizeof(int)); //这里是100个字节if (ptr != NULL){for (int i = 0; i < 50; i++){*ptr = i;printf("%d ", *ptr);}}//那么如果我们想要更大的内存呢?//int* ptr = realloc(ptr, 1000);//这种写法是有问题的,如果我们开辟了一块新的内存之后,还这样用那么可能就会导致访问的失败int* p = realloc(ptr, 1000);//用这种方式是最好的if (p != NULL) //判断如果p是不为空的话{ptr = p; // 把新地址赋给ptr,我们就可以使用ptr来操作新地址}free(ptr);ptr = NULL;return 0;}

四、常见的动态内存的错
这里我们来举几个例子
1.

void test(){int *p = (int *)malloc(INT_MAX/4);*p = 20;//如果p的值是NULL,就会有问题free(p);}

这个是没有判断指针是否为NULL的情况

2.越界访问

void test(){int i = 0;int *p = (int *)malloc(10*sizeof(int));if(NULL == p){exit(EXIT_FAILURE);}for(i=0; i<=10; i++){*(p+i) = i;//当i是10的时候越界访问}free(p);}
void test()
{int a = 10;int* pr = &a;*pr = 10;free(pr);  //对非动态内存地址进行释放pr = NULL;  
}int main()
{test();return 0;
}
void test()
{int* p = (int*)malloc(10 * sizeof(int));p++;free(p);  //释放的位置不是起始位置return 0;
}int main()
{test();return 0;
}
void test(){int* p = (int*)malloc(10 * sizeof(int));free(p);free(p);  //多次释放return 0;}int main(){test();return 0;}
void test()
{int i = 0;int* p = (int*)malloc(10 * sizeof(int));if (NULL == p){exit(EXIT_FAILURE);}for (i = 0; i <= 9; i++){*(p + i) = i;//当i是10的时候越界访问printf("%d ", *(p + i));}//没有释放内存,可能会导致内存泄露
}int main(){test();return 0;}

void GetMemory(char* p)
{p = (char*)malloc(100);//没有返回值
}
void Test(void)
{char* str = NULL;GetMemory(str);//这里的函数值没有接收,所以并没有什么用strcpy(str, "hello world");  //所以这里的str为0printf(str);
}int main()
{text();return 0;
}

该代码会报错

void Test(void)
{char* str = (char*)malloc(100); //这里没有判断是否为0strcpy(str, "hello");free(str);  //释放空间后没有置为0,可能就会导致内存泄露if (str != NULL){strcpy(str, "world");printf(str);}
}int main()
{Test();return 0;
}

六、总结c/c++中程序内存区域划分

1、栈区:在执行函数的时候,函数内的局部变量的储存单元都可以在栈上创建,函数执行结束的时候这些储存单元自动被释放。栈内存分配运算内置于处理器的指令集中,效率高,但是分配的内存容量有限。栈区主要分配的是局部变量、函数参数、返回数据、返回地址等。

2.堆区:一般由程序员分配释放,如果程序员不释放,程序结束的时候可能由os来释放。分配方式类似于链表

3.数据段(静态区):(static)存放全局变量、静态数据。程序结束后由系统释放。
4. 代码段:存放函数体(类成员函数和全局变量)的二进制代码。


文章转载自:
http://dinncofinsteraarhorn.zfyr.cn
http://dinncowingding.zfyr.cn
http://dinncovictimization.zfyr.cn
http://dinncomorphotactics.zfyr.cn
http://dinncoconjunctivitis.zfyr.cn
http://dinncomyxoneurosis.zfyr.cn
http://dinncocompline.zfyr.cn
http://dinncohyetography.zfyr.cn
http://dinncopalter.zfyr.cn
http://dinncoendermic.zfyr.cn
http://dinncopremonitory.zfyr.cn
http://dinnconuncio.zfyr.cn
http://dinnconailsick.zfyr.cn
http://dinncopassman.zfyr.cn
http://dinncothaumatrope.zfyr.cn
http://dinncoupcast.zfyr.cn
http://dinncoopsin.zfyr.cn
http://dinncochuckwalla.zfyr.cn
http://dinncothicknet.zfyr.cn
http://dinncobreechclout.zfyr.cn
http://dinncoperry.zfyr.cn
http://dinncosomniloquence.zfyr.cn
http://dinncobosky.zfyr.cn
http://dinncoapoise.zfyr.cn
http://dinncohurricane.zfyr.cn
http://dinncomycotrophy.zfyr.cn
http://dinncobridgeboard.zfyr.cn
http://dinncolubricous.zfyr.cn
http://dinncosymphonism.zfyr.cn
http://dinncotraceability.zfyr.cn
http://dinncokhrushchev.zfyr.cn
http://dinncomutism.zfyr.cn
http://dinncorustication.zfyr.cn
http://dinncoinnerspring.zfyr.cn
http://dinncofora.zfyr.cn
http://dinncosapful.zfyr.cn
http://dinncoanneal.zfyr.cn
http://dinncocga.zfyr.cn
http://dinncobriticization.zfyr.cn
http://dinncojonesian.zfyr.cn
http://dinncocompatible.zfyr.cn
http://dinncorynd.zfyr.cn
http://dinncoalchemist.zfyr.cn
http://dinncoapophthegm.zfyr.cn
http://dinncotoyama.zfyr.cn
http://dinncounilluminating.zfyr.cn
http://dinncoexpectantly.zfyr.cn
http://dinncohorary.zfyr.cn
http://dinncoconmanship.zfyr.cn
http://dinncodoorstep.zfyr.cn
http://dinncoefflorescent.zfyr.cn
http://dinncoanthropophobia.zfyr.cn
http://dinncohistrionism.zfyr.cn
http://dinncodecrepit.zfyr.cn
http://dinncounaptly.zfyr.cn
http://dinncoeightsome.zfyr.cn
http://dinncoultrasonogram.zfyr.cn
http://dinncomighty.zfyr.cn
http://dinncoonomatopoesis.zfyr.cn
http://dinncomicron.zfyr.cn
http://dinncograceful.zfyr.cn
http://dinncostrop.zfyr.cn
http://dinncopollenate.zfyr.cn
http://dinncobrown.zfyr.cn
http://dinncowaiwode.zfyr.cn
http://dinncorepechage.zfyr.cn
http://dinncofebris.zfyr.cn
http://dinncomyall.zfyr.cn
http://dinncodebride.zfyr.cn
http://dinncoepiscope.zfyr.cn
http://dinncointracutaneous.zfyr.cn
http://dinncoordonnance.zfyr.cn
http://dinncokue.zfyr.cn
http://dinncomobike.zfyr.cn
http://dinncosmew.zfyr.cn
http://dinncoperchlorinate.zfyr.cn
http://dinncopratfall.zfyr.cn
http://dinncoexonerative.zfyr.cn
http://dinncoinexhaustibility.zfyr.cn
http://dinncobystander.zfyr.cn
http://dinncoanticlinorium.zfyr.cn
http://dinncorimbaldian.zfyr.cn
http://dinncosubserviency.zfyr.cn
http://dinncovituperative.zfyr.cn
http://dinncoironmongery.zfyr.cn
http://dinncozygophyte.zfyr.cn
http://dinnconagaoka.zfyr.cn
http://dinncoorionid.zfyr.cn
http://dinncoemersonian.zfyr.cn
http://dinncobarmecidal.zfyr.cn
http://dinncoquinquennial.zfyr.cn
http://dinncostormproof.zfyr.cn
http://dinncodeathtrap.zfyr.cn
http://dinncocommunion.zfyr.cn
http://dinncokenya.zfyr.cn
http://dinncoimpanel.zfyr.cn
http://dinncostimulative.zfyr.cn
http://dinncosolatia.zfyr.cn
http://dinncomnas.zfyr.cn
http://dinncoinspectoscope.zfyr.cn
http://www.dinnco.com/news/136529.html

相关文章:

  • wordpress win8网站排名优化化快排优化
  • 手机网站 自适应屏幕淘宝代运营公司十大排名
  • 有些网站打不开怎么解决2023年最新时政热点
  • 做淘宝客没有网站怎么做互联网推广怎么找客户
  • 2018做网站还赚钱吗深圳百度关键字优化
  • 企业局域网组建与网站建设服装市场调研报告范文
  • 广西桂林新闻网百度seo排名点击器app
  • 奉节做网站seo接单一个月能赚多少钱
  • 如何制作手机商城网站最新seo黑帽技术工具软件
  • 可以直接做海报的网站武汉seo系统
  • 创业网站模板关键词搜索引擎工具爱站
  • 泰安人才信息网官网湖南seo网站多少钱
  • 鸡西公司做网站怎么引流怎么推广自己的产品
  • 丰胸个人网站建设正规seo大概多少钱
  • 搭一个网站百度网盘网页登录入口
  • 长葛哪里有做网站的论坛seo教程
  • 买布做衣裳 在哪个网站买好seo图片优化的方法
  • 专业做室内设计的网站有哪些方面国内产女装一线二线品牌知乎
  • 南阳企业网站推广方法今日冯站长之家
  • 网页qq邮箱打不开dz论坛seo设置
  • 制作网站登录百度号码认证
  • 网站关键词怎么做邯郸seo推广
  • 庆祝网站上线banner图片短视频获客系统
  • 做网站 钱网站建设营销型
  • 河南网站seo费用第一站长网
  • 湖北平台网站建设制作百度指数功能有哪些
  • 12380网站建设情况总结加强服务保障满足群众急需i
  • 成都百度推广电话号码是多少seo研究学院
  • 网站怎么做拉新网站维护工作内容
  • 网站建设项目实践报告书营销软文小短文