gpt4 book ai didi

c++ - C++ 中使用什么类型来定义数组大小?

转载 作者:可可西里 更新时间:2023-11-01 17:03:24 25 4
gpt4 key购买 nike

avr-gcc 中为 8 位微 Controller 编译一些测试代码,行

const uint32_t N = 65537;
uint8_t values[N];

我收到以下编译警告(默认情况下应该是一个错误,真的)

warning: conversion from 'long unsigned int' to 'unsigned int' changes value from '65537' to '1' [-Woverflow]
uint8_t values[N];

请注意,为此目标编译时,sizeof(int) 为 2。

看来,数组的大小不能超过 unsigned int 的大小。

我说的对吗?这是特定于 GCC 的还是某些 C 或 C++ 标准的一部分?

在有人评论说 8 位微 Controller 通常没有足够的内存来容纳如此大的阵列之前,我只想说这不是重点。

最佳答案

size_t 被认为是要使用的类型,尽管未被 C 或 C++ 标准正式批准。

这样做的基本原理是 sizeof(values) 将是该类型( 由 C 和 C++ 标准规定),并且元素的数量将不一定大于此值,因为对象的 sizeof 至少为 1。

关于c++ - C++ 中使用什么类型来定义数组大小?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54202670/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com