草庐IT

指令序列

全部标签

c++ - 代码综合——C++/Tree子节点序列化

我正在使用这个很棒的工具(http://www.codesynthesis.com/products/xsd/c++/tree/)将xsd转换为C++代码。我试图从子节点获取xml字符串,但我唯一能得到的是所有xml,如下所示:所有的xml:John.......我可以让所有的xml做这样的事情:people_t&p=...xml_schema::namespace_infomapmap;map[""].schema="people.xsd";//Serializetoastring.//std::ostringstreamoss;people(oss,p,map);std::stri

c++ - vector (反)序列化与 Boost.serialization 的向后兼容性

抱歉交叉发布。在发布到邮件列表boost-users并且一周没有任何回复后,我倾向于在stackoverflow上发布问题。原始帖子,稍作重新编辑:嗨名单,我正在从Boostv1.35迁移到新版本。然而,我有一些我希望新版本可读的遗留序列化字符串。经过一些测试,我发现显然是较新的版本(在这个案例1.40以及更高版本)无法从1.35正确反序列化std::vector实例生成的字符串。谁能给我一个关于可能是什么的指针问题在这里?非常感谢!埃瓦尔德==详情==我使用文本存档和gcc版本4.4.1(Ubuntu4.4.1-4ubuntu9)测试vector是一个包含2项的结构,长整数1和2。各

c++ - 序列化和反序列化位域

我收到了一份文档,其中定义了一组通过串行通信channel传输和接收的消息。我想获取传入消息并将它们反序列化为对象,并序列化我的出站消息。线路上的编码已确定且不可更改,并且由header中的各种位域和不同的有效负载组成,例如,classMessage{intmsg_num:7intdest_addr:4boolSRR:1boolIDE:1intsource_addr:6//...andsoon...}我看了一下使用protobufs,但似乎他们的varint编码方法已经建立。我也看过boost-serialization,但根据我到目前为止所读的内容,那里的编码方式并不完全清楚。那么,

c++ - 获取 `rsqrtss` 包装器的最少指令

我认为是时候使用快速平方根倒数了。因此,我尝试编写一个函数(在生产中将被标记为inline):floatsqrt_recip(floatx){return_mm_cvtss_f32(_mm_rsqrt_ss(_mm_set_ps1(x)));//sameas_mm_set1_ps}TL;DR:我的问题是“如何让GCC和ICC为上述功能输出最少的汇编(两条指令),最好不求助于原始汇编(坚持使用内在函数)?”正如所写,在ICC13.0.1、GCC5.2.0和Clang3.7上,输出是:shufpsxmm0,xmm0,0rsqrtssxmm0,xmm0ret这是有道理的,因为我使用_mm_s

c++ - OpenMP 原子和非原子读/写在 x86_64 上产生相同的指令

根据OpenMP规范(v4.0),由于i的不同步读/写,以下程序包含可能的数据竞争:inti{0};//std::atomici{0};voidwrite(){//#pragmaompatomicwrite//seq_csti=1;}intread(){intj;//#pragmaompatomicread//seq_cstj=i;returnj;}intmain(){#pragmaompparallel{/*codethatcallsbothwrite()andread()*/}}我想到的可能的解决方案在代码中显示为注释:保护i的读写与#pragmaompatomicwrite/re

c++ - 为什么 linear_congruential_engine::seed(Sseq) 会丢弃种子序列生成的三个数字?

C++标准(从C++11一直到当前的C++17草案)在[rand.eng.lcong]中说明如下:templateexplicitlinear_congruential_engine(Sseq&q);Effects:Constructsalinear_congruential_engineobject.Withk=⌈log2(m)÷32⌉andaanarray32(orequivalent)oflengthk+3,invokesq.generate(a+0,a+k+3)andthencomputesS=(∑j=0k−1aj+3·232​j)modm.Ifcmodmis0andSis0,

c++ - 如何在多个排序列表上创建迭代器?

好的,这是我得到的一道面试题,当时我的表现很一般。我想知道最佳解决方案是什么以及如何最好地实现。给定多个排序列表,构建东西,使我们能够从最小元素到最大元素遍历所有这些列表。例子:{-2,5,10}{2,9,11}{-5,9}->-5,-2,2,5,9,9,10,11更新:在SO聊天#c-questions-and-answers和特别是@Nican的帮助下,我已经让这艘船以某种方式飞起来了。我已经发布了我的工作代码作为答案,以允许其他解决方案。我在下面发布的答案仍然很乱,特别是我没有正确实现==和!=。我在这些方面仍然需要帮助。这个问题的理由在网上找到简洁的自定义迭代器实现并不常见。我

c++ - Google Assistant SDK (C++) - 广播指令

我正在使用示例应用程序并使用--text_input选项向Google智能助理发送广播命令,一切正常。现在,在最新版本中,Google智能助理会回复:“出了点问题。出了点问题”,但我没有收到错误,即使打开了verbose。我需要做一些与以前不同的事情吗?其他命令,例如“几点了?”正常工作。这是广播请求的输出:$./run_assistant--text_input"BroadcastDinner"--credentials_file./credentials.jsonUsinglocaleen-USassistant_sdkrobots_pem:assistant_sdkCreateC

c++ - Boost C++ 跨平台 (Windows & Mac) std::wstring 序列化

我正在为Windows(使用VisualStudio2008)和Mac(使用GCC)构建的程序中使用BoostC++库实现序列化。该程序在大约30个类中使用宽字符串(std::wstring)。根据平台的不同,当我保存到文件时(通过boost::archive::text_woarchive),宽字符串在输出文件中的表示方式不同。在Windows下保存:H*e*l*l*o**W*o*r*l*d*!*...在MacOSX下保存:H***e***l***l***o******W***o***r***l***d***!***...其中*是NULL字符。当我尝试使用Mac构建读取在Window

c++ - 使用指针和非默认构造函数 boost 序列化

您将如何使用boost::serialization序列化/反序列化此类?#includestructFoo{structBar{std::vector*data;//MustpointtoFoo::dataBar(std::vector*d):data(d){}};std::vectordata;std::vectorelements;Foo(){//doverytimeconsumingcalculationtopopulate"data"and"elements"}};当从序列化数据加载对象时,不得执行Foo中的构造函数,但如果对象是默认构造的,则必须评估构造函数。给Bar添加默