- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一些代码可以创建一个动态分配的数组
int *Array = new int[size];
据我理解,Array应该是内存中Array第一项的指针。使用 gdb 时,我可以调用 x Array 检查第一个内存位置的值,x Array+1 检查第二个位置,等等。我希望在我之前使用内存中这些位置的任何应用程序都留下垃圾值.但是,使用 x 数组会为所有这些点返回 0x00000000。我究竟做错了什么?我的代码是否将数组的所有值初始化为零?
编辑:为了记录,我问是因为我的程序试图实现这个:http://eli.thegreenplace.net/2008/08/23/initializing-an-array-in-constant-time/ .我想确保我的算法不会递增数组以将每个元素初始化为 0。
最佳答案
在大多数现代操作系统中,操作系统为应用程序提供清零页面,而不是让信息在不相关的进程之间渗透。例如,出于安全原因,这很重要。在旧的 DOS 时代,事情要随意一些。今天,有了内存保护的操作系统,操作系统通常会给你零开始。
因此,如果这个new
发生在您的程序的早期,您可能会得到零。不过,你会疯狂地依赖它;如果你这样做,这是未定义的行为。
如果您不断分配、填充和释放内存,new
最终将返回未归零的内存。相反,它将包含您的过程自己的早期涂鸦的残余。
并且不能保证对new
的任何特定调用,即使是在您程序的开头,也会返回充满零的内存。您只是可能在程序的早期调用 new
时看到了这一点。 不要让它误导您。
关于c++ - 为什么我的动态分配数组被初始化为 0?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20458372/
出于好奇,我尝试了一些原型(prototype)制作,但似乎只允许在第一个位置使用子例程的原型(prototype) &。 当我写作时 sub test (&$$) { do_somethin
我需要开发一个类似于 Android Play 商店应用程序或类似 this app 的应用程序.我阅读了很多教程,发现几乎每个教程都有与 this one 类似的例子。 . 我已经开始使用我的应用程
考虑一个表示“事件之间的时间”的列: (5, 40, 3, 6, 0, 9, 0, 4, 5, 18, 2, 4, 3, 2) 我想将这些分组到 30 个桶中,但桶会重置。期望的结果: (0, 1,
我是一名优秀的程序员,十分优秀!