草庐IT

External_variable

全部标签

c++ - VC++ 中 Unresolved external 错误

我正在学习vc++,正在用代码查看内存的使用信息。这个程序给我三个Unresolvedexternal错误..errorLNK2019:unresolvedexternalsymbol_GetProcessMemoryInfo@12referencedinfunction"void__cdeclPrintMemoryInfo(unsignedlong)"(?PrintMemoryInfo@@YAXK@Z)errorLNK2019:unresolvedexternalsymbol_EnumProcesses@12referencedinfunction_mainerrorLNK1120:

c++ - 冒号 : used in variable initialization?

这个问题在这里已经有了答案:Whatdoesacoloninastructdeclarationmean,suchas:1,:7,:16,or:32?(3个答案)关闭7年前。我找到这条线here:uint32bIsHungry:1;...而且我从未见过这种用于初始化变量的语法。我已经习惯看到这个了:uint32bIsHungry=1;它看起来有点像一个初始化列表,但是对于单个字段?它是什么,它有什么作用,我为什么要关心?

c++ - 为什么 `const type& variable` 作为函数输入?

我正在将一些函数从Matlab转换为C++,其中有一些与矩阵有关。我在Internet的某处找到了这个简单的函数:typedefstd::vector>Matrix;Matrixsum(constMatrix&a,constMatrix&b){size_tnrows=a.size();size_tncols=a[0].size();Matrixc(nrows,std::vector(ncols));for(inti=0;i谁能解释一下为什么他们使用constMatrix&a而不是Matrixa作为输入?他们是否习惯使用它,或者使用它有什么好处,因为我没有看到2个版本(constMatr

C++11 - 无法使用 std::thread 和 std::condition_variable 唤醒线程

当我试图通过另一个线程唤醒一个线程时遇到了一个问题。一个简单的生产者/消费者。代码下方。第85行是我不明白为什么它不起作用的地方。生产者线程填充std::queue并调用std::condition_variable.notify_one()而消费者线程正在等待NOTstd::queue.empty()。在此先感谢您的帮助#include#include#include#include#include#include//requestclassrequest:publicstd::mutex,publicstd::condition_variable,publicstd::queue{

c++ - Qt 5.4 静态构建在 Visual Studio 2013 中产生 "unresolved external symbol"链接错误

我想使用Qt5.4的静态构建。由于没有可用的预编译静态构建,您必须自己从Qt源代码构建一个。我的环境如下:Windows7x64VisualStudio2013终极更新4Qt5VisualStudio插件1.2.4已安装ActivePerl/ActivePython(需要构建Qt源代码)我的程序如下(参见QtDocumentation>Qt5.4>QtforWindows-BuildingfromSource):下载qt-everywhere-opensource-src-5.4.0.zip解压缩到一个临时文件夹按照here所述打开命令提示符(基本上,这类似于打开“VisualStud

c++ - std::unique_lock 和 std::condition_variable 如何工作

我需要弄清楚lock和condition_variable是如何工作的。在此处的-稍微修改过的代码中cplusplusreferencestd::mutexm;std::condition_variablecv;std::stringdata;boolready=false;boolprocessed=false;voidworker_thread(){//Waituntilmain()sendsdatastd::unique_locklk(m);cv.wait(lk,[]{returnready;});//afterthewait,weownthelock.std::coutlk(m

c++ - Unresolved external symbol 错误仅发生在 64 位模式中,而不是在 32 位构建中

我有一个VC++代码(使用VS2008构建),它使用了一些静态库(*.lib文件在编译时静态链接)。为了便于理解,我们将我的EXE代码称为“AAA.EXE”并将lib文件称为“A.lib”、b.lib等...AAA.EXE代码和静态库代码都是使用VS2008构建的。我看到我的“AAA.EXE”在32位版本中运行良好,并且在以64位模式构建AAA.EXE时显示以下链接器错误。当然,我已经在64位模式下重建了静态库,并在我的AAA.EXE中提供了lib路径,如下所示:::“对应于AAA.EXE的项目配置属性->链接器->常规/输入”。这个链接器错误真的困扰了我很长时间。任何帮助是极大的赞赏

c++ - 什么时候可以在没有谓词的情况下使用 std::condition_variable?

如果std::condition_variable可以由于虚假唤醒而发出信号(并且我们不能确定我们需要的条件是否真的得到满足),为什么C++标准库提供重载没有谓词的wait()方法?什么场景可以使用这种行为? 最佳答案 假设一个复杂条件:A||B。当条件的任何部分为真时,应执行适当的操作,actionA或actionB。使用predicate版本,代码如下:cond.wait(lock,[]{return(A||B);});if(A){actionA();}else{actionB();}但如果使用非谓词等待,代码可能更快:whil

c++ - 为什么 std::condition_variable 的通知和等待函数都需要一个锁定的互斥量

在我对理解std::contion_variable的永无止境的探索中,我遇到了以下问题。在thispage它说了以下内容:voidprint_id(intid){std::unique_locklck(mtx);while(!ready)cv.wait(lck);//...std::cout然后它说:voidgo(){std::unique_locklck(mtx);ready=true;cv.notify_all();}据我所知,这两个函数都将在std::unqique_lock行停止。直到获得唯一锁。也就是说,没有其他线程有锁。假设print_id函数首先执行。将获取唯一锁,函数

c++ - 变长数组 : How to create a buffer with variable size in C++

我目前正在编写一个移动平均线类。目标是在创建Running_Average类的新对象时能够将缓冲区大小指定为构造函数的一部分。#include#include"Complex.h"#include#include#include#includeusingnamespacestd;classRunning_Average{public:doublesum=0;doubleaverage=0;inti;doubleAverage(void);//MemberfunctionsdeclarationvoidAddSample(double);Running_Average(int);};Ru