new和malloc都是用于动态分配内存的函数,但它们有以下几点区别:
1. 返回值类型:new返回的是对象指针,而malloc返回的是void指针。
2. 内存大小:new在分配内存时会自动计算对象的大小,并分配足够的内存空间;而malloc需要手动指定要分配的内存大小。
3. 对象构造和析构:new会调用对象的构造函数来初始化对象,而malloc只是分配了一段内存空间,需要手动调用构造函数初始化对象。同样地,new会自动调用对象的析构函数来释放资源,而malloc需要手动调用析构函数来释放资源并调用free函数释放内存。
4. 类型安全:new是类型安全的,它会自动进行类型检查,并在类型不匹配时报错。而malloc没有类型检查,容易出现类型不匹配的问题。
5. 内存池:new和delete可以使用内存池技术,从而提高内存分配和释放的效率。malloc和free不支持内存池技术。
综上所述,如果需要动态分配对象,建议使用new和delete;如果只需要分配一段内存空间,则可以使用malloc和free。但是需要注意,在使用new和delete时,要确保对象的构造和析构函数正确实现;在使用malloc和free时,要确保手动调用构造和析构函数,并在释放内存时调用free函数。
new、malloc、delete、free的底层实现原理如下:
1. new和delete的底层实现原理
new的底层实现主要分为两个步骤:首先调用operator new函数分配内存空间,然后调用对象的构造函数初始化对象。
operator new函数是一个静态函数,它的作用是从堆中分配一段内存空间,并返回指向该内存空间的指针。operator new函数的函数原型如下:
void* operator new(size_t size);
new操作符会根据对象的类型自动计算所需的内存大小,并调用operator new函数分配内存空间。然后,new操作符会调用对象的构造函数来初始化对象。
delete的底层实现主要分为两个步骤:首先调用对象的析构函数释放资源,然后调用operator delete函数释放内存空间。
operator delete函数是一个静态函数,它的作用是释放从堆中分配的内存空间。operator delete函数的函数原型如下:
void operator delete(void* ptr);
delete操作符会先调用对象的析构函数来释放资源,然后调用operator delete函数释放内存空间。
2. malloc和free的底层实现原理
malloc的底层实现原理是通过调用系统函数brk或mmap来从操作系统中获取一段内存空间,然后将这段内存空间分配给用户使用。malloc函数的函数原型如下:
void* malloc(size_t size);
malloc函数会根据参数size指定的内存大小来分配一段内存空间。如果分配成功,返回指向该内存空间的指针;否则返回NULL。
free的底层实现原理是将分配的内存空间标记为“未使用”,并将其返回给操作系统。free函数的函数原型如下:
void free(void* ptr);
free函数会将参数ptr指向的内存空间标记为“未使用”,并将其返回给操作系统。如果参数ptr为NULL,则不进行任何操作。
综上所述,new和delete的底层实现原理与malloc和free的底层实现原理有所不同,主要体现在对象构造和析构函数的调用上。