草庐IT

copy-local

全部标签

c++ - "local variables at the outermost scope of the function may not use the same name as any parameter"是什么意思?

我一直在阅读C++入门第5版。在第6.1章功能参数列表的第三段中。它写道“此外,函数最外层范围内的局部变量不得使用与任何参数相同的名称”。什么意思?我不是以英语为母语的人。我不明白函数的“最外层范围”的实际含义。 最佳答案 函数的最外层是定义函数体的block。您可以将其他(内部)block放入其中,并在该block的本地变量中声明变量。内部block中的变量可以与外部block中的变量或函数参数具有相同的名称;他们将名称隐藏在外部范围内。外部block中的变量不能与函数参数同名。演示:voidf(inta)//functionha

c++ - TLS 变量上的 "illegal thread-local reference to regular symbol"错误

我在链接过程中出现了一个奇怪的问题。我有一个包含以下定义的头文件foo.hpp:structFoo{static__threadintx;}以及引用该变量plugin.cpp的源文件:#include"foo.hpp"voidbar(){inty=Foo::x;}它编译得很好:$CXX-stdlib=libc++-std=c++11-fvisibility=hidden-fPIC-oplugin.cpp.o-cplugin.cpp但是当我尝试链接为动态库时:$CXX-stdlib=libc++-std=c++11-fvisibility=hidden-dynamiclib-Wl,-un

c++ - std::locale/std::facet 关键部分

出于好奇。在过去,我曾看到像boost::to_lower这样的函数的性能下降,因为std::use_facet中使用了CriticalSection,当懒惰时分面已分配。据我所知,在语言环境中存在全局锁定错误,但根据StephanLavavej的说法,它已在VS2013中修复。瞧,我昨天看到这个锁在刻面杀死服务器性能上,所以我想我混淆了两个不同的问题。但是首先,为什么在惰性方面有一个CriticalSection?显然它会破坏性能。为什么他们没有解决某种可升级的锁或指针上的原子操作? 最佳答案 MSVC++的std::locale

Visual Studio 11 中的 c++11 thread_local 关键字支持

所以有一个listofc++11featuressupportedbyvisualstudio.thread_local支持被标记为部分。我无法在这里找到对部分支持的确切含义的解释。他们只是别名__declspec(thread)吗?我可以只使用boost::thread_specific_ptr,但似乎有一些报告boost::thread_specific_ptrisslow.这可能是真的,也可能不是。具体来说,我想要最新的linux+gcc和windows+msvc上的x86/x64上的快速TLS。快速意味着尽可能不进行系统调用(我认为这对于上述平台是可能的。)

C++ 静态工厂方法与构造函数 : how to avoid copying?

Thisquestion要求以简洁的方式在C++中实现静态工厂方法,thisanswer描述了一种明确的方法。返回值优化将使我们免于制作不必要的Object拷贝,从而使这种创建Object的方式与直接调用构造函数一样高效。在私有(private)构造函数中将i复制到id的开销可以忽略不计,因为它是一个小的int。但是,当Object包含作为类Foo实例的实例变量(需要复杂的初始化逻辑)时,问题和答案并未涵盖更复杂的情况)而不是一个小的原始类型。假设我想使用传递给Object的参数构造Foo。使用构造函数的解决方案如下所示:classObject{Foofoo;public:Object

TwoSampleMR:local clump(MR-Base exceeded 300 seconds) 包括Windows和Linux R解决办法

首先是Windows一个做孟德尔随机化的过程遇到的报错:bmi_exp_datPleaselookatvignettesforoptionsonrunningthislocallyifyouneedtorunmanyinstancesofthiscommand.ClumpingC5nTuK,5340156variants,usingEURpopulationreferenceErrorinapi_query("ld/clump",query=list(rsid=dat[["rsid"]],pval=dat[["pval"]], :  ThequerytoMR-Baseexceeded300se

java - JNI 错误 : Local reference table overflow 512 entries

我的函数如下所示。它被执行了很多次。在某些时候它在jobjectnvarObject=env->GetObjectField(var1,nvar1)崩溃,给出错误JNI错误:本地引用表溢出512个条目。任何人都可以研究这个问题并提出一些启示。 最佳答案 所有返回jobject或类似对象引用的JNI方法都在引用表中创建本地引用。当您将控制权交还给JVM时,这些引用会自动清理,但如果您要创建许多引用(例如,在循环中),则需要手动清理它们。您在cls引用上调用DeleteLocalRef是正确的,但请注意GetObjectField也返回

C++11:GCC 4.8 静态 thread_local std::unique_ptr 未定义引用

我需要为将通过宏访问的每个线程存储一个唯一指针。我想我应该用一个单例和静态thread_localstd::unique_ptr对象来解决这个问题。这是代码的简化版本:main.cpp#include#include#include#includeusingnamespacestd;#include"yay.hpp"mutexcoutMutex;voidyay(intid){int*yayPtr=getYay();//IknowthisisbadcoutMutex.lock();couthappy;for(inti=0;i耶.hpp#ifndefBE_HAPPY#defineBE_HA

c++ - C++ 中 std::is_trivially_copy_constructible 中的琐碎操作是什么

这是std::is_copy_constructible(1)和std::is_trivially_copy_constructible文档的摘录(2)关于cppreference.com:1)CheckswhetheratypeisCopyConstructible,i.e.hasanaccessibleexplicitorimplicitcopyconstructor.Iftherequirementismet,amemberconstantvalueequaltrueisprovided,otherwisevalueisfalse.2)Sameas(1),butthecopyco

c++ - GNU STL 字符串 : is copy-on-write involved here?

(免责声明:我不知道C++标准对此会说什么……我知道,我很糟糕)在处理非常大的字符串时,我注意到std::string正在使用写时复制。我设法编写了最小的循环来重现观察到的行为,例如,下面的循环运行得非常快:#includeusingstd::string;intmain(void){stringbasestr(1024*1024*10,'A');for(inti=0;i在循环体a_copy[1]='B';中添加写入时,显然发生了实际复制,并且程序在0.3秒内运行,而不是几毫秒。100次写入使其速度减慢了大约100倍。但后来变得很奇怪。我的一些字符串没有写入,只是读取,这没有反射(re