社区
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方式释放
这么理解对吗?求教诸位,这两种新建结点的方式有何不同?开辟空间和释放上有什么区别?使用中有什么需要注意的地方呢
...全文
716
5
打赏
收藏
s=new linknode s=(link)malloc(sizeof(linknode)) 区别
s=new linknode new是C++中的运算符,以delete方式释放空间 s=(link)malloc(sizeof(linknode)) 是C的函数,以free方式释放 这么理解对吗?求教诸位,这两种新建结点的方式有何不同?开辟空间和释放上有什么区别?使用中有什么需要注意的地方呢
复制链接
扫一扫
分享
转发到动态
举报
AI
作业
写回复
配置赞助广告
用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也一样。
第9讲习题链表迅速节点前面插入与后面插入.pdf
Link
Node
*
new
Node
= (
Link
Node
*)
malloc
(
sizeof
(
Link
Node
)); // 创建新节点
new
Node
->data =
new
Data; // 设置新节点的数据
new
Node
->next = head; // 新节点的下一个节点是原链表的首节点 head =
new
Node
; // ...
单链表的创建和插入
L = (
Link
Node
*)
malloc
(
sizeof
(
Link
Node
)); // 分配内存空间 L->next = NULL; // 头结点初始化 p = L; printf("the list is:"); // 提示用户输入 scanf("%d", &x); while (x != -1) { temp = (
Link
Node
*)...
关于冒泡排序的完整代码
h = (
Link
Node
*)
malloc
(
sizeof
(
Link
Node
)); h->next = NULL; return h; } ``` 这个函数用于创建一个空的链表头部节点。 2. **节点插入**: ```cpp
Link
Node
*Insert(DataType data,
Link
Node
* h) { ...
单链表的创建之头插法和尾插法
头插法: /使用头插法建立单链表 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:不是)...
C++ 语言
65,199
社区成员
250,520
社区内容
发帖
与我相关
我的任务
C++ 语言
C++ 语言相关问题讨论,技术干货分享,前沿动态等
复制链接
扫一扫
分享
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++
技术论坛(原bbs)
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
请不要发布与C++技术无关的贴子
请不要发布与技术无关的招聘、广告的帖子
请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下
试试用AI创作助手写篇文章吧
+ 用AI写文章