草庐IT

c++ - 振奋 spirit : What type names should be used for the built in terminals?

我正在重构一个类型系统(类型模型),它使用spirit进行字符串序列化。我正在使用类型特征的编译时建模构造。templatetype_traits{typedefboost::spirit::qi::int_parserstring_parser;}templatetype_traits{typedefboost::spirit::ascii::stringstring_parser;}在这个例子中,我展示了原始解析器,但我希望也加入规则。int4类型有效,但这是因为(home/qi/numeric/int.hpp+27):namespacetag{templatestructint_

c++ - HDF5 :Create a Dataset with string

我正在使用HDF5API,我正在尝试创建一个具有可变长度字符串的数据集。结构是structdataX{std::stringdata;};我使用的是具有静态硬编码大小的char[256]。但我希望它是动态的,所以在阅读HDF5文档后,我找到了H5T_VARIABLE并按如下方式使用它,但它仍然失败。H5Dcreate返回负值(表示错误)。hid_tmem_type;mem_type=H5Tcopy(H5T_C_S1);H5Tset_size(mem_type,H5T_VARIABLE);/*Createthememorydatatype.*/if((mem_type_id=H5Tcre

c++ - 在Boost Phoenix中获取局部变量的类型

我如何获取作用域BoostPhoenix语句中使用的局部变量的类型?使用Phoenix和Proto,我可以提取Phoenix表达式的多个方面。例如,以下代码公开了元数(3);标签类型(lambda_actor);和Phoenixlambda表达式的child-2标签类型(shift_left):#include#includenamespaceproto=boost::proto;namespacephoenix=boost::phoenix;usingnamespacephoenix::local_names;structFoo{constcharstr[6]="Ok.\n";};i

c++ - clang 不编译我的代码,但 g++ 可以

谁能帮我处理这段代码:#include#includestructnonsense{};templatetypenamestd::enable_if::value,int>::typefo(void*const){return0;}templatetypenamestd::enable_if::value,int>::typefo(void*const){return1;}typedefint(*func_type)(void*);templatevoidrun_me(){staticstructnonsensedata;typedefstd::pairpair_type;std::v

c++ - C : x86 Intel Intrinsics usage of _mm_log2_ps() -> error: incompatible type 'int' ?

我正在尝试将log2应用于__m128变量。像这样:#includeintmain(void){__m128two_v={2.0,2.0,2.0,2.0};__m128log2_v=_mm_log2_ps(two_v);//log_2:=log(2)return0;}尝试编译会返回此错误:error:initializing'__m128'withanexpressionofincompatibletype'int'__m128log2_v=_mm_log2_ps(two_v);//log_2:=log(2)^~~~~~~~~~~~~~~~~~~我该如何解决?

python - c++中python "type(<name>, <bases>, <dict>)"的等价物是什么?

好吧,我正在将python3.3嵌入到C++应用程序中。我希望在C++端动态创建一个Python类,就像我在Python中执行以下操作一样:my_type=type("MyType",(object,),dict())我知道我总是可以导入“builtins”模块,但我一般会尽量避免在C++端导入。谢谢! 最佳答案 以下似乎工作得很好:PyObject*type(constchar*name,boost::python::tuplebases,boost::python::dictdict){returnPyType_Type.tp_

c++ - 我怎样才能*有效地*从嵌套表达式生成所有类型的元组?

假设我有一些包含类型排列的模板表达式,在本例中它们来自AbstractSyntaxTree:templatestructBranch{};templatestructLeaf{};输入表达式可以是Branch的任意嵌套组合和Leaf类型,但为了简单起见,我将创建一个包含单个Leaf的线性AST包裹N层层深入Branch类型:usingExpression=Branch>;//N=2为了这个问题,我创建了一个函数来动态生成这些表达式,这样我就可以演示我在绘图方面遇到的问题。所以这里是我将用来生成我的表达式的函数://wrapLeafinBranchNnumberoftimes:templ

c++ - 如何从对象实例中获取成员 typedef

在MSVC2010中给出如下代码:错误C2039:“my_type”:不是“全局命名空间”的成员templateclassC{public:typedefTmy_type;};Cc;autof=[&c](){decltype(c)::my_typev2;//ERRORC2039};我找到了一个蹩脚的方法来解决它,但我想知道当你只有一个对象实例时获取typedef的正确方法是什么。 最佳答案 从一堆非常有用的评论中,我得到了一个可行的解决方案。感谢大家。remove_reference作为身份对象具有双重用途。templateclas

C++ 类型比较 : typeid vs double dispatch dynamic_cast

是否有任何性能或稳健性原因使您更喜欢其中一个?#include#includestructB{virtualboolIsType(Bconst*b)const{returnIsType2nd(b)&&b->IsType2nd(this);}virtualboolIsType2nd(Bconst*b)const{returndynamic_cast(b)!=nullptr;}};structD0:B{virtualboolIsType(Bconst*b)const{returnIsType2nd(b)&&b->IsType2nd(this);}virtualboolIsType2nd(B

浅谈区块链DAPP学习·续

前言昨天发布了关于自己学习区块链和DAPP的学习小结式的文章,朋友对我提了几点意见说:合约没有身份,一个人可以很多次的投票只要舍得花gas这是个刷票漏洞。仔细想来是有点偷懒了,所以今天补一篇。就两点:1,补上身份认证避免反复投票;2,对web3.0以及他的部署和调用再做一些介绍,其实功能和昨天是一样的但是方法会有所不同。solidity的合约优化pragmasolidity^0.4.0;contractVoting{//投票列表bytes32[]publiccandidateList;//对应的票数mapping(bytes32=>uint8)publicvotesReceived;//投票人