社区
C++ 语言
帖子详情
s=new linknode s=(link)malloc(sizeof(linknode)) 区别
十方魔
2016-12-26 11:09:42
s=new linknode new是C++中的运算符,以delete方式释放空间
s=(link)malloc(sizeof(linknode)) 是C的函数,以free方式释放
这么理解对吗?求教诸位,这两种新建结点的方式有何不同?开辟空间和释放上有什么区别?使用中有什么需要注意的地方呢
...全文
696
5
打赏
收藏
s=new linknode s=(link)malloc(sizeof(linknode)) 区别
s=new linknode new是C++中的运算符,以delete方式释放空间 s=(link)malloc(sizeof(linknode)) 是C的函数,以free方式释放 这么理解对吗?求教诸位,这两种新建结点的方式有何不同?开辟空间和释放上有什么区别?使用中有什么需要注意的地方呢
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
5 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
ri_aje
2016-12-26
打赏
举报
回复
c++ 老老实实用 new/new[] 就行了。malloc 不会调用构造函数的。
ipqtjmqj
2016-12-26
打赏
举报
回复
效果一样,最好分开用,用malloc申请的,用free释放; 用new申请的,用delete释放
paschen
版主
2016-12-26
打赏
举报
回复
malloc与free不会调用对象的构造函数与析构函数 但是new/delete会!
yshuise
2016-12-26
打赏
举报
回复
malloc和new不一样,new要调用构造函数,而malloc不会调用,要程序员自己调用定位new
小灸舞
2016-12-26
打赏
举报
回复
1) malloc与free是C++/C语言的标准库函数,new/delete是C++的运算符。它们都可用于申请动态内存和释放内存。 2) 对于非内部数据类型的对象而言,光用maloc/free无法满足动态对象的要求。对象在创建的同时要自动执行构造函数,对象在消亡之前要自动执行析构函数。由于malloc/free是库函数而不是运算符,不在编译器控制权限之内,不能够把执行构造函数和析构函数的任务强加于malloc/free。 因此C++语言需要一个能完成动态内存分配和初始化工作的运算符new,以及一个能完成清理与释放内存工作的运算符delete。注意new/delete不是库函数。 我们不要企图用malloc/free来完成动态对象的内存管理,应该用new/delete。由于内部数据类型的“对象”没有构造与析构的过程,对它们而言malloc/free和new/delete是等价的。 3) 既然new/delete的功能完全覆盖了malloc/free,为什么C++不把malloc/free淘汰出局呢?这是因为C++程序经常要调用C函数,而C程序只能用malloc/free管理动态内存。 如果用free释放“new创建的动态对象”,那么该对象因无法执行析构函数而可能导致程序出错。如果用delete释放“malloc申请的动态内存”,结果也会导致程序出错,但是该程序的可读性很差。所以new/delete必须配对使用,malloc/free也一样。
单链表的创建之头插法和尾插法
头插法: /使用头插法建立单链表 void CreastLsitF(
Link
Node
* L, ElemType a[], int n) {
Link
Node
* s; L = (
Link
Node
*)
malloc
(
sizeof
(
Link
Node
));... s = (
Link
Node
*)
malloc
(
sizeof
(
Link
Node
)); s->da
c语言的链表操作
L = (
Link
Node
*)
malloc
(
sizeof
(
Link
Node
)); if (!L) { printf("申请失败!即将退出"); return 0; } L->next = NULL; p = L; printf("表头已经申请完成"); printf("是否继续申请空间:(1:是/0:不是)...
单链表算法
单链表 1.单链表结构 typedef struct L
Node
{ Elemtype data; struct L
Node
*next; }
Link
Node
; 2.头插法 void CreateListF(
Link
Node
* &...
Link
Node
*s;... L=(
Link
Node
*)
malloc
(
sizeof
(Li...
数据算法与结构
L=(S
Link
List *)
malloc
(
sizeof
(S
Link
Node
)); L->next=NULL;//NULL 不能小写,否则不能识别 for(i=0;idata=a[i]; S->Next=L->next L->next=S; } } //尾插法 void CreatListF(S
Link
Node
*&L,ElemType a[],int n){ ...
数据结构-线性表(链表)(c++版)
//链表太短,即i太大,p指向表尾
Link
Node
*
new
Node
= (
Link
Node
*)
malloc
(
sizeof
(
Link
Node
));
new
Node
->data = x;
new
Node
->next = p->next;//插入到p节点后面 p->next =
new
Node
; } return true; } 3.4 ...
C++ 语言
64,654
社区成员
250,484
社区内容
发帖
与我相关
我的任务
C++ 语言
C++ 语言相关问题讨论,技术干货分享,前沿动态等
复制链接
扫一扫
分享
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++
技术论坛(原bbs)
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
请不要发布与C++技术无关的贴子
请不要发布与技术无关的招聘、广告的帖子
请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下
试试用AI创作助手写篇文章吧
+ 用AI写文章