如何将固定尺寸的枚举Val设置为最大值的值?
这可能很简单,但我没有正确。我有一个“ bitmask”枚举,该枚举具有一个值所有
,该表明所有位均已设置。但是,我无法使用〜0来翻转所有位。出现以下错误:
<source>:11:16: error: enumerator value '-1' is outside the range of underlying type 'uint_fast8_t' {aka 'unsigned char'}
11 | all = ~0x0,
|
这很奇怪,因为它实际上应该适合uint8_t否?这是我的代码( godbolt ):
#include <iostream>
int main()
{
enum mask_t : uint_fast8_t {
first = 0x1,
second = 0x2,
all = ~0x0,
} mask;
mask = all;
}
This is probably simple but I'm not getting it right. I have a "bitmask" enum which has a value all
that indicates that all bits are set. However, I can't get it to flip all bits using ~0. The following error appears:
<source>:11:16: error: enumerator value '-1' is outside the range of underlying type 'uint_fast8_t' {aka 'unsigned char'}
11 | all = ~0x0,
|
Which is strange because it should actually fit into uint8_t no? Here is my code (godbolt):
#include <iostream>
int main()
{
enum mask_t : uint_fast8_t {
first = 0x1,
second = 0x2,
all = ~0x0,
} mask;
mask = all;
}
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
您可以借助一些元编程技巧
demo
You can get the maximum value with the help of some meta-programming tricks
Demo
默认情况下,
0x0
是类型int
。因此,如果您尝试翻转所有位,您将获得-1
无法分配给枚举的类型。即使您使用后缀作为字面值,例如
u
。表明字面价值是无符号类型的。如〜0x0u
中。您将获得unsigned int
类型的最大值。超过您使用的8位整数类型的范围。因此,这也行不通。因此,您需要告诉语言您希望首先需要的字面价值是所需的类型。这可以通过其他答案中所示的
static_cast
来实现:但是,如果您稍后决定更改枚举的类型,则使用硬编码的类型和值有时会陷入困境。因此,如果您有C ++ 14。您可以使用
std :: undlying_type
type-tait,并制作一个通用实用程序:然后使用类似:
现在您不必关心枚举的基本类型。
您甚至可以使用
std :: Numeric_Limits
如果需要正确的值而不是依靠翻转位:天空是极限。
By default,
0x0
is of typeint
. So if you try to flip all the bits you'll get-1
which can't be assigned to the type your enumeration was defined to.Even if you use a suffix for that literal value, like
u
for example. To indicate that the literal value is of unsigned type. As in~0x0u
. You'd get the maximum of theunsigned int
type. Which exceeds the range of the 8-bit integer type you're using. So this doesn't work either.So you need to tell the language that you want the literal value to be of the type you need first. That can be achieved with a
static_cast
as demonstrated in other answers:But using hardcoded types and values can get in the way sometimes if you decide to change the type of the enum later. So if you have c++14 available. You can use the
std::underlying_type
type-trait and make a generic utility like:And then used like:
Now you don't have to care about the underlying type of the enumeration.
You can even use
std::numeric_limits
if you want the right values instead of relying on flipping bits:Sky is the limit.
您需要将Expression
〜0x0
转换为具有类型int
的类型的uint_fast8_t
last键入
int
?因为整数字面0x0
具有类型int
,并且操作员〜不会更改表达式的类型。从C ++标准
类型
int
的对象可以代表文字0x0
。这是一个演示程序。
程序输出是
另一种方法是写
You need to convert the expression
~0x0
having the typeint
and a negative value to the typeuint_fast8_t
like for exampleWhy does the expression have the type
int
? Because the integer literal0x0
has the typeint
and the operator ~ does not change the type of the expression.From the C++ Standard
And an object of the type
int
can represent the literal0x0
.Here is a demonstration program.
The program output is
Another way is just to write