- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我有一个文件,我已将其读入数据类型为 signed char
的数组。我无法改变这个事实。
我现在想这样做:!((c[i] & 0xc0) & 0x80)
其中 c[i]
是签名字符之一。
现在,我从 C99 standard 的第 6.5.10 节知道“[按位与] 的每个操作数都应具有整数类型。”
C99 规范的第 6.5 节告诉我:
Some operators (the unary operator ~ , and the binary operators << , >> , & , ^ , and | , collectively described as bitwise operators )shall have operands that have integral type. These operators return values that depend on the internal representations of integers, and thus have implementation-defined aspects for signed types.
我的问题有两个方面:
由于我想使用文件中的原始位模式,如何将我的 signed char
转换/转换为 unsigned char
以便位模式保持不变?
是否有这些“实现定义的方面”的列表(比如 MVSC 和 GCC)?
或者您可以采取不同的方式,并争辩说这对 c[i]
的任何值的有符号和无符号字符产生相同的结果。
自然地,我会奖励对相关标准或权威文本的引用,并阻止“知情”猜测。
最佳答案
正如其他人指出的那样,您的实现很可能是基于二进制补码的,并且会给出您期望的结果。
但是,如果您担心涉及有符号值的操作结果,并且您只关心位模式,只需直接转换为等效的无符号类型即可。结果在标准下定义:
...
否则,如果新类型是无符号的,则通过重复添加或转换值比新类型可以表示的最大值减一直到值在新类型的范围内。
这实质上是指定结果将是值的二进制补码表示。
其基本原理是,在二进制补码数学中,计算结果是对 2 的某个幂(即类型中的位数)取模,这又恰好等同于屏蔽掉相关位数。一个数的补数是从 2 的幂中减去的数。
因此,添加一个负值等同于添加任何与该值相差 2 的幂的倍数的值。
即:
(0 + signed_value) mod (2^N)
==
(2^N + signed_value) mod (2^N)
==
(7 * 2^N + signed_value) mod (2^N)
等(如果你知道模数,那应该是不言而喻的)
因此,如果您有一个负数,加上 2 的幂将使它成为正数 (-5 + 256 = 251),但底部的“N”位将完全相同 (0b11111011),并且不会影响数学运算的结果。由于值随后会被截断以适合类型,因此即使结果“溢出”,结果也正是您所期望的二进制值(即,如果数字以正开头,您可能会认为会发生什么 - 这种包装也是定义明确的行为).
所以在 8 位二进制补码中:
同样,如果您有:
unsigned int a;
int b;
a - b == a + (unsigned int) -b;
在幕后,这个转换不太可能用算术实现,并且肯定是从一个寄存器/值到另一个寄存器/值的直接赋值,或者只是完全优化掉,因为数学没有区分有符号和无符号(解释CPU 标志是另一回事,但这是一个实现细节)。该标准的存在是为了确保实现不会自己去做一些奇怪的事情,或者我想,对于一些不使用二进制补码的奇怪架构......
关于c - 按位与符号字符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14233716/
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求提供代码的问题必须表现出对所解决问题的最低限度理解。包括尝试过的解决方案、为什么它们不起作用,以及预
为什么在 C# 中添加两个 char 结果是 int 类型? 例如,当我这样做时: var pr = 'R' + 'G' + 'B' + 'Y' + 'P'; pr 变量变为 int 类型。我希望它是
下面的代码可以编译,但 char 类型的行为与 int 类型的行为不同。 特别是 cout ::ikIsX >() ::ikIsX >() ::ikIsX >() using names
我正在寻找一个正则表达式,它可以匹配长度为 1 个或多个字符但不匹配 500 的内容。这将在 Rails 路由文件中使用,特别是用于处理异常。 路线.rb match '/500', to: 'err
对于 C 编程作业,我正在尝试编写几个头文件来检查所谓的“X 编程语言”的语法。我最近才开始,正在编写第一个头文件。这是我编写的代码: #ifndef _DeclarationsChecker_h_
为什么扩展的 ascii 字符(â、é 等)被替换为 字符? 我附上了一张图片...但我正在使用 PHP 从 MySQL 中提取数据,其中一些位置有扩展字符...我使用的是 Arial 字体。 您可以
我有一个与 R 中的断线相关的简单问题。 我正在尝试粘贴,但在获取(字符/数字)之间的断线时遇到问题。请注意,这些值包含在向量中(V1=81,V2=55,V3=25)我已经尝试过这段代码: cat(p
如何将 ANSI 字符 (char) 转换为 Unicode 字符 (wchar_t),反之亦然? 是否有用于此目的的任何跨平台源代码? 最佳答案 是的,在 中你有mbstowcs()和 wcsto
函数 fromCharCode 不适用于国际 ANSI 字符。例如,对于 ID 为 192 到 223 的俄语 ANSI (cp-1251) 字符,它返回特殊字符。如何解决这个问题? 我认为,需要将A
如果不喜欢,我想隐藏 id,但不起作用 SELECT * FROM character, character_actor WHERE character.id NOT LIKE character_a
现在这个程序成功地反转了键盘输入的单词。但是我想在我反转它之前“保存”指针中的单词,所以我可以比较两者,反转的和“原始的”,并检查它们是否是回文。我还没有太多经验,可能会出现比我知道的更多的错误,但我
Memcpy 和 memcmp 函数可以接受指针变量吗? char *p; char* q; memcpy(p,q,10); //will this work? memcmp(p,q,10); //w
恐怕我对一个相当过饱和的主题的细节有疑问,我搜索了很多,但找不到一个明确的答案来解决这个特定的明显-imho-重要的问题: 使用UTF-8将byte[]转换为String时,每个字节(8bit)都变成
我有一个奇怪的问题。我需要从 stat 命令打印输出字符串。 我已经编写了获取一些信息的代码。 import glob import os for file in glob.glob('system1
我正在使用 Java 并具有其值如下所示的字符串, String data = "vale-cx"; data = data.replaceAll("\\-", "\\-\\"); 我正在替换其中的“
String urlParameters = "login=test&password=te&ff"; 我有一个String urlParams,& - 是密码的一部分,如何使其转义,从而不被识别为分
大家好,我只想从此字符串中提取第一个字母: String str = "使 徒 行 傳 16:31 ERV-ZH"; 我只想获取这些字符: 使 徒 行 傳 并且不包括 ERV-ZH 仅数
这个问题已经有答案了: Crash or "segmentation fault" when data is copied/scanned/read to an uninitialized point
所以, 我有一个字符**;它本质上是一个句子,带有指向该句子中每个单词的指针;即 'h''i''\0''w''o''r''l''d''\0''y''a''y''!''\0' 在这种情况下,我希望使用可
这个问题在这里已经有了答案: Using quotation marks inside quotation marks (12 个答案) 关闭 7 年前。 如何打印 " 字符? 我知道打印 % 符号
我是一名优秀的程序员,十分优秀!