我在和我的一个朋友争论,如果我们定义了一个数组/指针:
sometype * p;
如果我们想知道类型的大小,他说应该使用:
sizeof(sometype)
我说也可以使用:
sizeof(p[0]),
它应该是一样的。他不同意,他的观点是如果p
没有初始化,那么这种用法p[0]
可能会导致问题。
但据我所知,只有当我们改变或依赖 的值时p[0]
,这才会有害。由于我们不改变p[0]
也不使用p[0]
's 的价值,这是完全明智的。
既然无法说服对方,谁能把这个概念说清楚。
我知道这个问题没有用,几乎所有的开发者都会使用 sizeof(sometype),包括我:)。但是这个问题很有趣,我真的很想知道 sizeof(p[0]) 是否会有害。
==================================
让我稍微扩展一下这个问题。如果我确实使用了一些不相关的值(或被认为是随机的或其他的)。我可以一直使用p[0]
来获得价值吗?
为了让问题更清楚,如果我不更改未初始化指针的值,只使用它指向的值,我是否可以始终获得一个值而不会造成问题?