一、函数的定义
函数在namespace std中有如下定义(C++98与C++11版本不一致):
Typedef void (*new_handler)(); new_handler set_new_handler(new_handler new_p) throw(); //C++98 new_handler set_new_handler (new_handler new_p) noexcept; //C++11
二、函数介绍
该函数的作用是:当new操作或new[]操作失败时调用参数所指的new_p函数
异常安全:
数据争用:
函数说明
1. set_new_handler函数的作用是设置new_p指向的函数为new操作或new[]操作失败时调用的处理函数。
2. 设置的处理函数可以尝试使更多空间变为可分配状态,这样新一次的new操作就可能成功。当且仅当该函数成功获得更多可用空间它才会返回;否则它将抛出bad_alloc异常(或者继承该异常的子类)或者终止程序(例如调用abort或exit)。
3. 如果设置的处理函数返回了(例如,该函数成功获得了更多的可用空间),它可能将被反复调用,直到内存分配成功,或者它不再返回,或者被其它函数所替代。
4. 在尚未用set_new_handler设置处理函数,或者设置的处理函数为空时,将调用默认的处理函数,该函数在内存分配失败时抛出bad_alloc异常。
三、函数的参数
new_p:
设置的处理函数可以尝试使更多空间变为可分配状态,这样新一次的new操作就可能成功。当且仅当该函数成功获得更多可用空间它才会返回;否则它将抛出bad_alloc异常(或者继承该异常的子类)或者终止程序(例如调用abort或exit)
如果设置的处理函数返回了(例如,该函数成功获得了更多的可用空间),它可能将被反复调用,直到内存分配成功,或者它不再返回,或者被其它函数所替代
如果未设置处理函数,或者设置的处理函数为空时,将调用默认的处理函数,该函数在内存分配失败时抛出bad_alloc异常
四、函数的返回值
五、演示案例
下面程序中new操作分配内存失败时将调用no_memory函数
// new_handler example #include <iostream> // std::cout #include <cstdlib> // std::exit #include <new> // std::set_new_handler void no_memory () { std::cout << "Failed to allocate memory!\n"; std::exit (1); } int main () { //绑定no_memory处理函数 std::set_new_handler(no_memory); std::cout << "Attempting to allocate 1 GiB..."; char* p = new char [1024*1024*1024]; std::cout << "Ok\n"; delete[] p; return 0; }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
4. 分配内存的函数 除了malloc之外,C标准库还提供了另外两个在堆空间分配内存的函数,它们分配的内存同样由free释放。 #include <stdlib.h> void *calloc(size_t nmemb, size_t size); void *realloc(void *ptr, size_t size); 返回值:成功返回所分配内存空间的首地址,出错返回NULL calloc
本文向大家介绍C#反射内存的处理分析,包括了C#反射内存的处理分析的使用技巧和注意事项,需要的朋友参考一下 本文实例分析了C#反射内存的处理。分享给大家供大家参考。具体分析如下: 这段时间由于公司的项目的要求,我利用c#的反射的机制做了一个客户端框架。客户端里的所有的模块都是以一定形式进行提供,例如:FORM,UserControl. 在做的过程中很简单与愉快。具体的过程如下: 1. 收集客户的需
我已经读了一些关于我的问题的帖子(比如这篇文章),但没有一篇能解决这个问题。在我的Flask应用程序中,我使用内置在多处理中的Python(在16个物理核心上)并行下载了32-64个图像,如下所示: 下载工作正常,除了内存使用外,速度显著提高。在下载过程中,Python分配了大约100GB的RAM,尽管实际只使用了大约2GB。每个进程分配超过6 gb的RAM,仅用于下载最多4个图像,每个图像的容量
来自标准::set_new_handler 每当内存分配尝试失败时,分配函数都会调用new-handler函数。它的预期目的有三个: 使更多内存可用 终止程序(例如,通过调用 std::terminate) 抛出类型 std::bad_alloc 或派生自 std::bad_alloc 的异常 以下超载保证会有什么影响吗?
我有一个func添加两个NO并返回(a+B)。然后我创建了一个指向func的func指针。希望为该函数指针的数组分配内存并访问它们。代码如下。 我的问题是使用malloc的下面一行: 编译时,sizeof(add_2nos*)和sizeof(add_2nos)没有任何区别。如果有什么区别??另外,如果类型转换是必要的,而我正在分配相同类型的内存…?
我用C++创建了一个简单的类Storer,用于内存分配。它包含六个字段变量,所有这些变量都在构造函数中赋值: 我对这些变量是如何存储的很感兴趣,所以我编写了以下代码: 我对输出非常感兴趣: