2012年C++专家进阶之一

简介: 2012年C++专家进阶之一一、C中的malloc与C++中的new的8大区别:序号比较项mallocnew说明1应用范围CC++仅仅是C++语言New是C++语言新引进的操作符,C++兼容C语言,或者说对C语言进行扩充2操作符不是New以及 d...

2012C++专家进阶之一

一、C中的mallocC++中的new8大区别

序号

比较项

malloc

new

说明

1

应用范围

C

C++

仅仅是C++语言

NewC++语言新引进的操作符,C++兼容C语言,或者说对C语言进行扩充

2

操作符

不是

New以及 delete

 

3

重载

C++语言可以

 

重载是面向对象语言的特性

4

构造函数

malloc仅仅申请内存,不能调用构造函数

new的时候可以调用对象的构造函数

构造函数是面向对象的概念

5

析构函数

free仅仅释放内存,

不能调用析构函数

delete的时候调用对象的析构函数

析构函数是面向对象的概念

6

返回值

malloc返回的是void型指针

new返回的是某种数据类型的指针

 

7

释放

malloc申请的空间必须由free释放

new申请的空间必须由delete来释放

两者的实现机理不同

8

理解

函数

操作符

 

二、sizeofstrlen5大区别

序号

比较项

sizeof

strlen

说明

1

理解

操作符

库函数

 

2

输入参数

1.可以是数据类型;

2.也可以是变量;

举例:如sizeof(float)或者
float  a;
sizeof(a)

只能是以’\0’结尾的字符串;

简言之:仅仅是字符串,并且是带’\0’结尾的字符串;

 

3

数组

不退化

传递给strlen就退化为指针

 

4

返回值

计算的数据类型占用的内存空间大的大小

计算的字符串的实际长度,也就是不含’\0’的长度

 

5

时间

编译器在编译时,就计算出sizeof的结果

Strlen函数必须在运行时才能计算出来

 

相关文章
|
1月前
|
存储 C++ 容器
C++进阶--mep和set的模拟实现
C++进阶--mep和set的模拟实现
|
1月前
|
测试技术 C++
C++进阶--红黑树
C++进阶--红黑树
|
2天前
|
设计模式 C语言 C++
【C++进阶(六)】STL大法--栈和队列深度剖析&优先级队列&适配器原理
【C++进阶(六)】STL大法--栈和队列深度剖析&优先级队列&适配器原理
|
2天前
|
存储 缓存 编译器
【C++进阶(五)】STL大法--list模拟实现以及list和vector的对比
【C++进阶(五)】STL大法--list模拟实现以及list和vector的对比
|
2天前
|
算法 C++ 容器
【C++进阶(四)】STL大法--list深度剖析&list迭代器问题探讨
【C++进阶(四)】STL大法--list深度剖析&list迭代器问题探讨
|
2天前
|
编译器 C++
【C++进阶(三)】STL大法--vector迭代器失效&深浅拷贝问题剖析
【C++进阶(三)】STL大法--vector迭代器失效&深浅拷贝问题剖析
|
1月前
|
算法 安全 编译器
C++:模版进阶 | Priority_queue的模拟实现
C++:模版进阶 | Priority_queue的模拟实现
|
1月前
|
存储 算法 数据管理
【C++入门到精通】C++入门 ——搜索二叉树(二叉树进阶)
在C++中,本文介绍了搜索二叉树(二叉搜索树,BST)的概念和基本操作,包括搜索、插入和删除。搜索操作从根节点开始,按值大小决定左右查找;插入操作找到合适位置新建节点;删除操作需考虑无子节点、单子节点和双子节点的情况。文中还提供了非递归和递归实现的C++代码示例。此外,讨论了搜索二叉树在K模型和KV模型中的应用以及性能分析,强调了保持树平衡的重要性。
15 0
|
1月前
|
存储 安全 程序员
【C++ 包装器类 智能指针】完全教程:std::unique_ptr、std::shared_ptr、std::weak_ptr的用法解析与优化 — 初学者至进阶指南
【C++ 包装器类 智能指针】完全教程:std::unique_ptr、std::shared_ptr、std::weak_ptr的用法解析与优化 — 初学者至进阶指南
69 0
|
1月前
|
存储 C++
C++进阶--AVL树
C++进阶--AVL树

热门文章

最新文章