- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
越界访问数组有多危险(在 C 语言中)?有时会发生我从数组外部读取的情况(我现在明白我然后访问我程序的其他部分甚至超出该部分使用的内存)或者我试图将一个值设置为数组外部的索引。该程序有时会崩溃,但有时会运行,只会给出意想不到的结果。
现在我想知道的是,这到底有多危险?如果它损坏了我的程序,那还不错。另一方面,如果它破坏了我程序之外的某些东西,因为我以某种方式设法访问了一些完全不相关的内存,那么我想那是非常糟糕的。我读了很多“任何事情都可能发生”,'segmentation might be the least bad problem' ,“你的硬盘可能会变成粉红色, unicorn 可能会在你的窗下唱歌”,这很好,但真正的危险是什么?
我的问题:
我使用 OSX 10.7、Xcode 4.6。
最佳答案
就 ISO C 标准(该语言的官方定义)而言,访问超出其范围的数组具有“未定义的行为”。字面意思是:
behavior, upon use of a nonportable or erroneous program construct or of erroneous data, for which this International Standard imposes no requirements
非规范性注释对此进行了扩展:
Possible undefined behavior ranges from ignoring the situation completely with unpredictable results, to behaving during translation or program execution in a documented manner characteristic of the environment (with or without the issuance of a diagnostic message), to terminating a translation or execution (with the issuance of a diagnostic message).
这就是理论。现实情况如何?
在“最佳”情况下,您将访问一些由您当前运行的程序拥有的内存(这可能会导致您的程序运行异常),或者不您当前拥有的内存正在运行的程序(这可能会导致您的程序因段错误等问题而崩溃)。或者您可能会尝试写入您的程序拥有的内存,但它被标记为只读;这也可能会导致您的程序崩溃。
这是假设您的程序在尝试保护并发运行的进程彼此之间的操作系统下运行。如果您的代码在“裸机”上运行,比如说它是操作系统内核或嵌入式系统的一部分,那么就没有这种保护;您的行为不当代码应该提供这种保护。在这种情况下,损坏的可能性要大得多,包括在某些情况下对硬件(或附近的事物或人)造成物理损坏。
即使在 protected 操作系统环境中,保护也不总是 100%。例如,存在允许非特权程序获得根(管理)访问权限的操作系统错误。即使具有普通用户权限,一个出现故障的程序也会消耗过多的资源(CPU、内存、磁盘),甚至可能导致整个系统瘫痪。许多恶意软件(病毒等)利用缓冲区溢出来获得对系统的未授权访问。
(一个历史示例:我听说在一些带有 core memory 的旧系统上,在紧密循环中重复访问单个内存位置可能会导致该内存块融化。其他可能性包括破坏 CRT 显示器,并以驱动器机柜的谐波频率移动磁盘驱动器的读/写头,导致它走过 table 并掉到地板上。)
而且总是有 Skynet担心。
底线是这样的:如果你可以编写一个程序来故意做一些不好的事情,那么至少在理论上,一个有缺陷的程序可能意外地做同样的事情.
实际上,非常您在 MacOS X 系统上运行的错误程序不太可能做出比崩溃更严重的事情。但是不可能完全防止错误代码做坏事。
关于c - 越界访问数组有多危险?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53978745/
我最近才开始学习 Clojure,所以很抱歉,如果这有点初级: 有人可以向我解释一下两者之间的区别吗: => (def a (lazy-cat [0]
我有一些看起来像这样的数据: X = [[1,2,3,4],[01010],[-1.6]] y = [[4,2]] 我正在尝试使用 tflearn 在这些数据上训练神经网络。我使用的是 TFlearn
我的代码有问题。 我正在尝试从 .txt 文件中提取 channel 名称。我不明白为什么方法 line.split() 给我返回一个长度为 0 的数组: 有人可以帮助我吗? 这是文件.txt: --
def sigmoid(z): # complete the code z = np.asarray(z) if z.ndim == 0: return(1/(1+np.exp(-z))) e
我在访问 3d 数组内的值时遇到问题。有时它给出正确的值,但有时它给出随机的数值。数组内不存在。 import java.util.*; public class Main { public
我有一段代码,执行时会出现此错误。而且我比较新,我似乎无法解决问题。 错误:2011-09-06 12:31:06.094 ForceGauge[266:707] CoreAnimation:忽略异常
我正在尝试限制 http://www.liftdesignphoto.com/test/ 中的滚动因为它让电梯超出了界限。 有没有办法重新计算位置,使其不越界? (也许使用 %)。 谢谢 最佳答案 假
我正在尝试遍历 6 个“国际象棋”棋子的列表。每轮他们移动一个随机数量,如果他们落在另一个上,他们就会“杀死”它。 问题是,当我的 vector 中的最后一 block 杀死另一 block 时,我收
NumberPicker serviceWheel = (NumberPicker) findViewById(R.id.serviceSelector); serviceWheel.setMaxVa
我正在尝试使用 GridLayout 重现此计算器布局 但这就是我用我尝试过的代码得到的结果。 事实上,在设备上情况会变得更糟,它会削减更多必须跨越两行的最后一个相等按钮。
运行测试脚本时出现“标签越界”错误。将注释值与类数进行比较时,confusion_matrix 函数会抛出错误。在我的例子中,注释值是一个图像(560x560)和 number_of_classes
什么是 OOL(越界)代码?我在 ION 编译器中找到了它,但无法理解发生了什么。 bool CodeGeneratorShared::generateOutOfLineCode() { for
这是我正在研究的有趣的事情。 varray.c: static GLint vertices[] = {25, 25, 100, 325,
我的程序将文件读取到字节数组中,然后尝试从该文件中提取 bmp 图像。问题是我遇到了越界错误。 { public static void main( String[] args ) {
我有一个 UITableView,它由从 XML 提要解析的数据数组填充。我正在努力寻找此错误的原因,并想知道是否有人可以帮助我。该错误不会经常发生。它仅在数组数量很大时发生,例如 10-15 个对象
public class GameEntry { private String name; private int score; public GameEntry(String
我遇到了 Storyboard的问题(至少有点惊讶)。 我有一个 ViewController,它包含一个容器 View 以及各种 ImageView 。自然地,选择的 ImageView 决定了容器
我正在尝试为一些 textfield 设置动画。即在屏幕外开始动画并移动到屏幕中央。但就我而言,动画从中心开始并超出 bounds。当我在 viewWillAppear/viewDidAppear 中
closeTs在struct tic给我一个错误 - tsP=0x66 .我尝试从 oracle 条目中填充它,如果没有,我尝试分配一个值。但我在 fillFields 中访问错误.有人可以给我提示
public class Registration { public static void main(String[] args) { final String MY
我是一名优秀的程序员,十分优秀!