草庐IT

const_set

全部标签

c++ - 通过 const 引用传递 Qt 类

众所周知,Qt类使用copy-on-wite按值传递时。因此,直到需要时才进行复制。当只需要对对象进行只读访问时,我已经看到很多次通过const引用传递Qt类。为什么人们传递constQString&而不是简单的QString如果在这两种情况下都没有完成复制? 最佳答案 这是因为魔法是有代价的。QString不会复制整个字符串,但会计算引用。QString的多次复制会减慢程序的速度。如果constQString&足以满足您的需求,为什么不使用它呢?它仍然更快。 关于c++-通过const

C++ 错误 : deduced conflicting types for parameter 'T' string vs const char *

因此,我正在为双端队列容器编写一个简单的模板化搜索函数。这是代码:templatevoidsearchInDequeFor(std::dequeDeque,TsearchValue){for(constauto&element:Deque){if(Deque.empty()){std::cout下面是我在main中调用函数的方式:dequemyDeque={"apple","banana","pear","blueberry"};searchInDequeFor(myDeque,"pear");这是我遇到的错误:candidatetemplateignored:deducedconfl

c++ - 如何检查成员函数是否有 const 重载?

假设我有structfoo{voidham(){}voidham()const{}};structbar{voidham(){}};假设我有一个模板化函数,我能否判断给定类型是否具有ham的const重载? 最佳答案 与#defineDEFINE_HAS_SIGNATURE(traitsName,funcName,signature)\template\classtraitsName\{\private:\templatestructhelper;\template\staticstd::uint8_tcheck(helper*);

c++ - 在 C++ 中获取 const char * 长度的最佳方法

我知道两种获取constchar长度的方法*constchar*str="HelloWorld!";intSize=0;while(str[Size]!='\0')Size++;其他方式很简单constchar*str="HelloWorld!";size_tSize=strlen(str);但我不想使用像strlen这样的strlib函数,我认为这个函数也使用了我的第一种方式行为。因为在PC世界中,当我们想要计算某些东西时,我们需要计算每个block的数量,并且没有魔法可以通过一次移动获得长度,所以我认为第一种方法是获得constchar*。其他方式我认为第一种方式对于重弦来说可能太

c++ - `void f1(const Class &c)` 和 `void f2(Class const &c)` 有什么区别?

下面这些函数有什么区别(看关键字const)?voidf1(constClass&c)和voidf2(Classconst&c) 最佳答案 没有区别。这两个版本可以互换。 关于c++-`voidf1(constClass&c)`和`voidf2(Classconst&c)`有什么区别?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/7576223/

C++ 构造函数——通过引用传递仅适用于 const。为什么?

所以今天早些时候,我正在catch很好的旧C++,当我编译我的代码时它不工作。像一些程序员一样,我开始四处寻找,最终发现添加键盘const可以解决问题。但是,我不太喜欢黑客攻击,想知道为什么代码在添加const后运行良好。这是我在将const添加到构造函数之前的代码:#include#includeusingnamespacestd;classNames{private:string_name;string_surname;public:Names(string&name,string&surname):_name(name),_surname(surname){}stringgetN

c++ - 为什么 const char* 强制转换为 std::string 有效?

这个Actor令我困惑:#include#include#includeusingnamespacestd;intmain(){stringstr1=(string)"Icastthisthing"+"--thenaddthis";cout有人可以解释为什么这种c风格的字符串转换有效(或被允许)吗?我将生成的优化程序集与来自:stringstr1=string("Iconstructthisthing")+"--thenaddthis";而且它们看起来是相同的,所以我觉得我忘记了一些实际上允许互换这种转换/构造的C++语义。std::stringstr2=std::string("Ic

c++ - 为什么 const int 比 const int& 快?

有一天我无意中注意到了这一点,现在决定对其进行广泛测试。所以,当我调用函数时:#defineTypeint#definePrmconstType&Typetestfunc1(Prmv1,Prmv2,Prmv3,Prmv4,Prmv5,Prmv6,Prmv7,Prmv8,Prmv9,Prmv10){return(v1|v2|v3|v4|v5|v6|v7|v8|v9|v10);}1亿次:for(Typey=0;y对于int、constint和constint&类型,我注意到constint比常量整数&。(注意:我使用返回值来确保函数不会被优化)。为什么会这样?我一直认为添加&实际上会使它更

FPGA设计时序约束三、设置时钟组set_clock_groups

目录一、背景二、时钟间关系2.1时钟关系分类2.2时钟关系查看三、异步时钟组3.1优先级3.2使用格式3.3 asynchronous和exclusive3.4 结果示例四、参考资料一、背景    Vivado中时序分析工具默认会分析设计中所有时钟相关的时序路径,除非时序约束中设置了时钟组或false路径。使用set_clock_groups命令可以使时序分析工具不分析时钟组中时钟的时序路径,使用set_false_path约束则会双向忽略时钟间的时序路径    使用-group参数可以将一个时钟设置到多个时钟组中,如果时钟组中没有时钟,则时钟组为空组。只有至少两个组都是非空组,为有效组时se

c++ - 尝试将 std::pair 插入 std::set

我不明白这段代码中的错误是什么:#include#include#includeusingnamespacestd;classA{public:A(unsignedinta):_a(a){}A():_a(0){}unsignedinta()const{return_a;}private:unsignedint_a;};classB{public:B(unsignedintb):_b(b){}B():_b(0){}unsignedintb()const{return_b;}private:unsignedint_b;};voiddisplay(constPoint&point){//co