作为使用 MS Visual Studio 的 C++ 开发人员,我已经工作了几年 作为工作平台。由于我私下更喜欢使用linux,所以我最近采取了 也有机会将我的工作环境转移到 Linux。 由于我多年来一直在优化我的Windows环境, 当然,事实证明有几件事丢失了或没有按预期工作。 因此,我有一些问题,我还没有得到有用的答案。
让我们开始下面的问题,稍后可能会出现不同的问题。 问题是我已经多次偶然发现的问题, 每当我被迫在非 Windows 平台上调试特定于平台的错误时。
简单来说:如何在linux调试时显示Unicode(UCS2编码)字符串?
现在我想出了一些更多的细节。我们的库内部使用基于 Unicode 的
String 类,它将每个字符编码为 16 位 Unicode 值(但我们不
支持多字编码,因此我们基本上只能使用 UCS2 可编码子集
UTF16,但这包括几乎所有使用过的脚本)。
这已经造成了一个问题,因为大多数平台(即 linux/unix)都考虑
wchar_t 类型由 4 个字节组成,而在 Windows 上它只有 2 个字节,因此
我不能简单地将内部字符串缓冲区转换为 (wchar_t *),所以我不确定,
如果这真的对任何调试器有帮助的话。
对于 gdb 我想,我可以从调试代码中调用函数,以 打印调试信息。因此我在我们的库中插入了一个特殊的函数, 可以任意转换字符串数据并将其写入新缓冲区。 目前我将我们的内部缓冲区转码为 utf8,因为我希望这样 最有可能工作。
但到目前为止,这只解决了部分问题:如果字符串是拉丁字符串, 然后我现在得到一个可读的输出(而不能直接打印拉丁语 数据,如果它是 16 位编码),但我还必须处理其他脚本 (f.e. CJK (a.k.a. Hansi/Kanji), cyrillic, greek ...) 我的意思是交易 我必须使用此类脚本专门调试数据,因为直接使用的脚本 影响控制流。 当然,在这些情况下,我只看到与多个对应的 ISO 字符 组成 utf8 字符的字节,这使得调试 CJK 数据更加困难 然后正确显示的字符串将是神秘的。
通常 gdb 允许设置多个主机和目标编码,因此它应该 可以将正确编码的 utf8 数据流发送到控制台。
但我当然更愿意使用 IDE 进行调试。目前我正在尝试 与eclipse和CDT交 friend ,但为了调试我也测试了kdgb。 在这两个应用程序中,到目前为止我只能获得错误解码的 utf8 数据。 另一方面,我曾经在 windows 平台上的 eclipse 中调试过一个 java 项目 并且所有内部字符串都正确显示(但这个应用程序不是 使用我们的库和相应的字符串),因此至少在某些情况下 eclipse 可以正确显示 unicode 字符。
对我来说最烦人的一点是,到目前为止我什至想不出 任何证明显示真正的 unicode 数据(即非 ISO 字符)有效的证据 在 linux 上的任何设置中(即我发现的 QString 的 gdb 脚本,似乎 只显示拉丁字符并跳过其余部分),当然 几乎每个 linux 应用程序似乎都支持 unicode 数据,因此有 一定是周围的人,在 linux 平台上调试真正的 unicode 数据 我真的无法想象,他们都在阅读十六进制代码而不是 直接显示unicode字符串。
因此,任何指向允许调试 unicode 字符串的设置的指针,基于 在任何其他字符串类(例如 QString)和/或 IDE 上也将不胜感激。
最佳答案
上面 Charles Salvia 提到的简单脚本“wchar.gdb”对我有帮助,但几年后很难找到(文章中的链接已损坏),因此我将其粘贴在这里。该脚本还演示了 gdb 中内置的一些鲜为人知的宏功能。
define wchar_print
echo "
set $i = 0
while (1 == 1)
set $c = (char)(($arg0)[$i++])
if ($c == '\0')
loop_break
end
printf "%c", $c
end
echo "\n
end
document wchar_print
wchar_print <wstr>
Print ASCII part of <wstr>, which is a wide character string of type wchar_t*.
end
关于c++ - 在 linux 上调试时如何显示 Unicode 字符串?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1721545/
我正在学习如何使用Nokogiri,根据这段代码我遇到了一些问题:require'rubygems'require'mechanize'post_agent=WWW::Mechanize.newpost_page=post_agent.get('http://www.vbulletin.org/forum/showthread.php?t=230708')puts"\nabsolutepathwithtbodygivesnil"putspost_page.parser.xpath('/html/body/div/div/div/div/div/table/tbody/tr/td/div
总的来说,我对ruby还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用
我有一个字符串input="maybe(thisis|thatwas)some((nice|ugly)(day|night)|(strange(weather|time)))"Ruby中解析该字符串的最佳方法是什么?我的意思是脚本应该能够像这样构建句子:maybethisissomeuglynightmaybethatwassomenicenightmaybethiswassomestrangetime等等,你明白了......我应该一个字符一个字符地读取字符串并构建一个带有堆栈的状态机来存储括号值以供以后计算,还是有更好的方法?也许为此目的准备了一个开箱即用的库?
我的目标是转换表单输入,例如“100兆字节”或“1GB”,并将其转换为我可以存储在数据库中的文件大小(以千字节为单位)。目前,我有这个:defquota_convert@regex=/([0-9]+)(.*)s/@sizes=%w{kilobytemegabytegigabyte}m=self.quota.match(@regex)if@sizes.include?m[2]eval("self.quota=#{m[1]}.#{m[2]}")endend这有效,但前提是输入是倍数(“gigabytes”,而不是“gigabyte”)并且由于使用了eval看起来疯狂不安全。所以,功能正常,
在我的Rails(2.3,Ruby1.8.7)应用程序中,我需要将字符串截断到一定长度。该字符串是unicode,在控制台中运行测试时,例如'א'.length,我意识到返回了双倍长度。我想要一个与编码无关的长度,以便对unicode字符串或latin1编码字符串进行相同的截断。我已经了解了Ruby的大部分unicode资料,但仍然有些一头雾水。应该如何解决这个问题? 最佳答案 Rails有一个返回多字节字符的mb_chars方法。试试unicode_string.mb_chars.slice(0,50)
关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。
给定这段代码defcreate@upgrades=User.update_all(["role=?","upgraded"],:id=>params[:upgrade])redirect_toadmin_upgrades_path,:notice=>"Successfullyupgradeduser."end我如何在该操作中实际验证它们是否已保存或未重定向到适当的页面和消息? 最佳答案 在Rails3中,update_all不返回任何有意义的信息,除了已更新的记录数(这可能取决于您的DBMS是否返回该信息)。http://ar.ru
我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t
对于具有离线功能的智能手机应用程序,我正在为Xml文件创建单向文本同步。我希望我的服务器将增量/差异(例如GNU差异补丁)发送到目标设备。这是计划:Time=0Server:hasversion_1ofXmlfile(~800kiB)Client:hasversion_1ofXmlfile(~800kiB)Time=1Server:hasversion_1andversion_2ofXmlfile(each~800kiB)computesdeltaoftheseversions(=patch)(~10kiB)sendspatchtoClient(~10kiBtransferred)Cl
我得到了一个包含嵌套链接的表单。编辑时链接字段为空的问题。这是我的表格:Editingkategori{:action=>'update',:id=>@konkurrancer.id})do|f|%>'Trackingurl',:style=>'width:500;'%>'Editkonkurrence'%>|我的konkurrencer模型:has_one:link我的链接模型:classLink我的konkurrancer编辑操作:defedit@konkurrancer=Konkurrancer.find(params[:id])@konkurrancer.link_attrib