我有以下C#代码:
byte rule = 0; ... rule = rule | 0x80;
产生错误:
无法将类型'int'隐式转换为'byte'.存在显式转换(您是否错过了演员?)
[更新:问题的第一个版本错了......我误读了编译器输出]
添加强制转换并不能解决问题:
rule = rule | (byte) 0x80;
我需要把它写成:
rule |= 0x80;
这看起来很奇怪.为什么|=
操作员与操作员有什么不同|
?
有没有其他方法告诉编译器将常量视为一个字节?
@ Giovanni Galbo:是的,不是.该代码处理外部设备中闪存的编程,逻辑上代表单个字节的存储器.我可以稍后施展,但这似乎更明显.我想我的C传承太多了!
@ Jonathon Holland:'as'语法看起来更整洁但不幸的是看起来不起作用......它产生:
as运算符必须与引用类型或可空类型一起使用('byte'是不可为空的值类型)
Eric Z Beard.. 34
C#没有字节的文字后缀.u = uint,l = long,ul = ulong,f = float,m =十进制,但没有字节.你必须施展它.
C#没有字节的文字后缀.u = uint,l = long,ul = ulong,f = float,m =十进制,但没有字节.你必须施展它.
这有效:
rule = (byte)(rule | 0x80);
显然是表达'规则| 即使将0x80定义为'const byte 0x80',0x80'也会返回一个int.
您正在寻找的术语是"Literal",不幸的是C#没有字节文字.
这是所有C#文字的列表.
int rule = 0; rule |= 0x80;
http://msdn.microsoft.com/en-us/library/kxszd0kx.aspx的| operator是为所有值类型定义的.我认为这会产生预期的结果."| ="运算符是一个或那么赋值运算符,它只是rule = rule |的简写 0x80的.
关于C#的最重要的事情之一就是它可以让你根据它们的大小做滥用价值类型等疯狂的事情.'int'与字节完全相同,但如果您尝试将它们同时用作两者,编译器将抛出警告.简单地坚持使用一个(在这种情况下,int)效果很好.如果你担心64位准备就绪,你可以指定int32,但所有的int都是int32s,甚至在x64模式下运行.