- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
让 x
是基本源字符集的任何成员。 'x'
和 L'x'
分别是基本执行字符集和基本执行宽字符集的成员。
'x'
的整数值是真的吗?和 L'x'
必须相等?看起来标准不需要这样做,这是有道理的。可以想象将 EBCDIC 用作窄字符集,将 Unicode 用作宽字符集。
std::use_facet<std::ctype<wchar_t>>(std::locale()).widen('x')
是真的吗?应该等于 L'x'
在某些(或任何)语言环境中?在这种情况下,要求这样做是有道理的,但我在标准中也找不到这样的要求。同样,是 std::use_facet<std::ctype<wchar_t>>(std::locale()).narrow(L'x')
与 'x'
相同?
如果以上不正确,那么是哪一个
std::wcout << L'x';
std::wcout << ct.widen('x');
应该输出x
? ct
是适当的语言环境方面。
最佳答案
在实践中几乎不能保证宽字符集,因为 C 和 C++ 标准要求所有宽字符都可以用单个编码值表示,而 Windows 编程的标准是 UTF-16 编码的宽文本.最初的 Windows 宽文本只是最初的 16 位 Unicode,现在称为 UCS-2,它仍在 Windows 控制台窗口中使用,并且符合 C 和 C++ 要求。 UTF-16 是 UCS-2 的扩展,它使用两个编码值,称为代理对,用于原始 Unicode 基本多语言平面(也称为 BMP)之外的字符。
回复
” Is it true that integral values of
'x'
andL'x'
must be equal? [When x is a member of the C++ basic source character set]
基本源字符集是 ASCII 的子集,几乎所有现存的通用字符编码,尤其是 Unicode 编码,都是 ASCII 的扩展。有一个异常(exception),即 IBM 的 EBCDIC 字符编码(有多种变体)。但是,如果它仍然在使用,那就是在 IBM 大型机上。
因此在实践中你有这个保证,但在正式的时候你没有。不过,更重要的是,它无关。例如,基本源字符集缺少 $ 符号,你几乎不能指望没有它,即限制自己使用基本源字符集不是一个实际的提议。
回复
” Is it true that
std::use_facet<std::ctype<wchar_t>>(std::locale()).widen('x')
should be equal toL'x'
in some (or any) locale [When x is a member of the C++ basic source character set]
出于与文字相同的原因,在实践中是,在形式上不是(因为支持像 EBCDIC 这样的编码),而且这与从业者无关。
特别是在实践中,一个更相关的考虑是微软的 Visual C++ 有(未记录的)Windows ANSI 作为其执行字符集,而 UTF-16 作为宽字符编码。例如。在我的机器上,执行字符集是 Windows 1252,也就是 Windows ANSI Western。有些字符,尤其是 €,具有完全不同的 Unicode 字符代码。更糟糕的是,可能只有一些窄字符集可用作执行字符集,其中某些字符的 UTF-16 编码将使用一对代理编码值。在那种情况下widen
甚至不能代表结果;没有空间了。
关于c++ - 'x' 和 L'x' 之间的关系并加宽 ('x' ),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31959761/
话说,尾部的++在这里没有实际作用? 最佳答案 l+l++ 未定义。您的表达式中没有序列点来分隔对 l 的访问和后增量。它可以做任何事情,包括具有与 l+l 相同的效果。 编辑:问题和答案在 Why
我正在研究成员资格算法,我正在研究这个特定问题,该问题说明如下: 展示一种算法,给定任何常规语言 L,确定 L 是否 = L* 所以,我的第一个想法是,我们有 L*,它是 L 的 Kleene 星并确
我试图弄清楚如何使用 Javascript 生成一个随机 11 个字符串,该字符串需要特定的字母/数字序列,以及位置。 ----------------------------------------
我一直在 LinqPad 中试验查询。我们有一个表 Lot,其中有一列 Side char(1)。当我编写 linq to sql 查询 Lots.Where(l => l.Side == 'A')
这个问题在这里已经有了答案: Iterate over all pairs of consecutive items in a list [duplicate] (7 个答案) 关闭 7 年前。 假
列表 ['a','a #2','a(Old)'] 应变为 {'a'} 因为 '# ' 和 '(Old)' 将被删除,并且不需要重复项列表。我努力用生成器开发列表理解,并决定这样做,因为我知道它会起作用
我正在为蛇和梯子制作一 block 板,到目前为止,我已经按降序打印了板。但是,我需要以正确的方式打印电路板。 编辑“螺旋下降”意味着 100...91 81...90 80...71 ...
字符串“Hello\n”等于 {'H','e','l','l','o','\','n','\0'} 或 {'H','e','l','l','o','\n','\0'}? 是否在字符串定义中添加转义序列
这个问题在这里已经有了答案: Different behaviour for list.__iadd__ and list.__add__ (3 个答案) 关闭 8 年前。 ls = [1,2,3]
当我在编写一个程序时,我在我的代码中看到了一个奇怪的行为。这是我所看到的。 >>> l = [1,2,3,4,5,6,7,8] >>> g = [] >>> for i in l: ... g
我明白了what a Y Combinator is , 但我不明白这个来自 Wikipedia page 的“新颖”组合子的例子: Yk = (L L L L L L L L L L L L L
Exception ParseException is not compatible with throws clause in Comparator.compare(L, L). 我在java 6上
期望的输出 我想要一个函数返回一个列表,这样,给定一个“困惑的”列表 l,每个元素都是 l 对应元素的索引,如果 l 已排序。 (抱歉,我想不出更简单的说法。) 示例 f([3,1,2]) = [2,
你好,我正在查看“假设一个排序数组在你事先不知道的某个枢轴旋转。(即 0 1 2 4 5 6 7 可能变成 4 5 6 7 0 1 2)”这个问题的 C++ 解决方案。你如何有效地在旋转数组中找到一个
让我们考虑这个简单的例子: import numpy as np a=np.arange(90) a=a.reshape(6,3,5) 我想得到一个数组 b形状 (6*5,3+1=4) 与 b[0:6
我正在编写一个 q 脚本,它在特定路径中加载一个数据库并对其进行一些处理。 db 的位置目前在脚本中是硬编码的,但我想将 db 路径作为参数传递并让它从变量中的路径加载。 目前它看起来像这样: q)
为什么我收到错误 Device: (3:9741) (0,l.useLinkBuilder) is not a function。 (在 '(0,l.useLinkBuilder)()' 中,'(0,
我有 ADT 版本 23.0.4 并安装了 Android 5.0 的 SDK 平台。 我读到 Android 5.0 Lolipop 的 API 级别为 21。但是在 Eclipse 的“新建应用程
我在 Google Play Store 中实现了一个抽屉导航,我想在 DrawerLayout 中设置列 TableView 的选定项目。但是后来发现在touch模式下无法选中item,有一个i
作为 C++ 的新手,我基本上有一个关于 g++ 编译器的问题,尤其是库的包含。考虑以下生成文件: CPPFLAGS= -I libraries/boost_1_43_0-bin/include/ -
我是一名优秀的程序员,十分优秀!