草庐IT

check_val

全部标签

java - 使用 JGit 从 Git 存储库中 check out 特定修订

我正在尝试使用jGit克隆存储库并checkout特定提交。假设提交哈希是:1e9ae842ca94f326215358917c620ac407323c81。我的第一步是://CloningtherepositoryGit.cloneRepository().setURI(remotePath).setDirectory(localPath).call();然后我发现了另一个建议这种方法的问题:git.checkout().setCreateBranch(true).setName("branchName").setUpstreamMode(CreateBranchCommand.Se

c++ - 什么是 clang-check 的垃圾值

我收到以下警告:test.cpp:14:25:warning:Therightoperandof'/'isagarbagevaluereturn(std::abs(a)/size)>10;^~~~~对于这段代码:#include#include#include#includeusingnamespacestd;doublepitchDetect(conststd::vector>&dft,unsignedintsamplingRate)noexcept{if(dft.empty())return0.0;autoit=find_if(begin(dft),end(dft),[size=d

c++ - Boost.Spirit.Lex :( 中 Phoenix 占位符 _val 出错

我是Boost.Spirit.Lex的新手。每次我尝试在我的简单词法分析器的语义操作中使用lex::_val时,都会出现一些奇怪的错误:#ifndef_TOKENS_H_#define_TOKENS_H_#include#include#include#include#include#includenamespacelex=boost::spirit::lex;namespacephx=boost::phoenix;enumtokenids{ID_IDENTIFICATOR=1,ID_CONSTANT,ID_OPERATION,ID_BRACKET,ID_WHITESPACES};te

c++ - C++11 中的 checked_array_iterator<T>

C++11提供了std::array包装C数组,但仅限于在编译时知道数组大小的地方。处理大小仅在运行时已知的数组的最佳方法是什么?背景我正在将一些代码从MSVC移植到GCC。MSVC提供了stdext::checked_array_iterator为这样的代码行提供一些保护的模板:std::copy(v.begin(),v.end(),stdext::checked_array_iterator(arr,numVals));到目前为止,我可以想到两种选择:放弃安全检查或编写自己的实现。关于这一点,如果您对此实现提出任何建设性意见,我将不胜感激:namespacestdext{templ

Java 等效于 C++ 模板 <int val> class foo{ };

我是Java的新手,正在尝试做类似于以下C++模板的事情:templateclassFoo{....};具有不同value_的实例化行为相同,但具有不同value_的两个实例之间的交互将取决于value1和value2。特别是,如果某些函数中的value1!=value2会导致编译时失败。一种可能的解决方案可能是将此类值存储在java类中并抛出运行时异常,但编译时检测会很有用。 最佳答案 Java最接近模板的是generics,但它严格限于强制使用“正确的”类型。Java没有任何基于值的模板机制。您最好的办法是通过为您感兴趣的值创建

c++ - __sync_val_compare_and_swap 与 __sync_bool_compare_and_swap

我一直在思考这两个函数的返回值。__sync_bool_compare_and_swap函数的返回值似乎有明显的好处,即我可以用它来判断交换操作是否发生。但是,我看不到__sync_val_compare_and_swap的返回值的良好用途。首先,让我们有一个函数签名供引用(来自GCC文档减去varargs):type__sync_val_compare_and_swap(type*ptr,typeoldvaltypenewval);我看到的问题是__sync_val_compare_and_swap的返回值是*ptr的旧值。准确地说,这是在设置了适当的内存屏障后,此函数的实现所看到的

异常情况下的 C++ 错误 C2228( '.val' 左侧必须有类/结构/union )

在C++中,我正在尝试实现自己的any使用C++的类。然而,在我能够对其进行测试之前(如果我的实现不好,请随时纠正我),我得到了错误:errorC2228:leftof'.val'musthaveclass/struct/union使用value()两次功能两次,当它在其他地方工作时,这看起来很奇怪。我唯一能想到的就是decltype函数前面导致错误,但它不应该:编辑:我更新了为templateany(TV){...}更改变量的方式构造函数classany{protected:templatestructvariable{public:Tval;variable(){}variable

c++ - 成员函数检查 : Implement compilation-time checkings with C++11 features

我读到C++11有足够的静态检查(编译时),以便实现C++11的大部分内容(已删除)。(我在最近关于已删除概念的问题的评论中读到过此内容...-该问题因不具有建设性而很快被关闭)。下面的C++03代码仅检查类中是否存在成员函数(我的模板类要在该类上工作)。这里有4个搜索的成员函数,我总是使用相同的模式:定义函数原型(prototype)的typedef如果类型名称TExtension没有定义这样的成员函数,或者如果它有不同的原型(prototype),则调用static_cast会中断编译代码如下:templateclass{...voidcheckTemplateConcept(){

c++ - GCC -fstack-check 选项在 C 中引发了什么异常

根据gcc文档-fstack-checkGeneratecodetoverifythatyoudonotgobeyondtheboundaryofthestack.Notethatthisswitchdoesnotactuallycausecheckingtobedone;theoperatingsystemmustdothat.Theswitchcausesgenerationofcodetoensurethattheoperatingsystemseesthestackbeingextended.我的假设是这个额外的代码会产生异常让操作系统知道。使用C语言时,我需要知道额外代码生成

c++ - 打开 : check if nested parallesim

假设我有一个方法将两个std::vector相乘:doublemultiply(std::vectorconst&a,std::vectorconst&b){doubletmp(0);/*hereIcouldeasilydoaparallelizationwith*//*#pragmaompparallelloopfor*/for(unsignedinti=0;i如果我在此函数中设置pragma宏,将运行对multiply(...)的调用在所有线程上。现在假设我想在其他地方做很多vector乘法:voidmany_multiplication(std::vector*a,std::ve