jjzjj

c++ - xorps 在同一个寄存器上的目的是什么?

我正在查看以下反汇编的c++代码autotest2=convert(2.0);00007FF6D6475ECCmoveax,16Dh00007FF6D6475ED1xorpsxmm1,xmm100007FF6D6475ED4cvtsi2sdxmm1,rax00007FF6D6475ED9mulsdxmm1,mmwordptr[__real@4000000000000000(07FF6D64AFE38h)]00007FF6D6475EE1divsdxmm1,mmwordptr[__real@401c000000000000(07FF6D64AFE58h)]并且很好奇xorpsxmm1,x

c++ - 告诉编译器我希望变量始终存储在寄存器中的正确方法是什么?

阅读thisquestion的答案我注意到register在C++17中不再是有效的存储说明符。一些评论甚至暗示编译器已经忽略register一段时间了。我将GCC6.x与ARMCortex-MMCU一起使用,并且有一些内联汇编代码,它绝对需要在寄存器中有一个变量。以前我假设register关键字会为我做这件事,但显然它不会。在现代C++中,确保编译器始终为给定变量使用寄存器的正确方法是什么?如果没有标准方法,是否有特定于GCC的方法?也许某种属性?还是编译器特定的关键字?编辑:为什么我需要在寄存器中存储一些东西?我正在使用ARMLDREX/STREX指令实现无锁环形缓冲区。我需要将A

c++ - ecx 寄存器是否用于传递静态函数调用中的参数之一?

我知道在c++中调用对象的非静态成员函数时,this指针是传入ecx寄存器的。静态函数呢,因为没有this指针,在这种情况下,编译器是否使用ecx寄存器来传递常规参数之一?编辑-我在这里谈论的是cdecl调用约定。 最佳答案 调用函数时ecx(或任何其他寄存器)的用途取决于callingconvention.例如,考虑C++代码structS{staticvoidf(int,int){}voidg(int){}};voidg(){S::f(3,4);Ss;s.g(3);}通过MicrosoftVisualStudio2010(64位

c++ - 何时使用 `__fastcall` 调用约定

我们有很多用C++编写的基于VCL的应用程序。所有VCL方法(在__published类修饰符下)都需要__fastcall调用约定。但是,无论出于何种原因,开发人员一直在将__fastcall添加到其他private、protected或public的非VCL函数。基于thisarticle,这对我来说毫无意义,因为它不必要地使代码复杂化,甚至可能会影响性能(虽然可能可以忽略不计)。尽管如此,在建议我们在某些地方删除它之后,我被告知我们一直都是这样做的,所以要保持一致,这只是一个风格问题。我认为如果没有必要,它实际上会让人们感到困惑,所以这是不好的做法。我的问题是,什么时候使用__f

c++ - 为什么我可以获取寄存器变量的地址?

引用自《Thinkinginc++》一书中关于寄存器变量的部分:“寄存器变量的使用有限制。您不能获取或计算寄存器变量的地址。寄存器变量只能在block(你不能有全局或静态寄存器变量)。”所以我写了这段程序来测试:intglobal=2;//error//registerintglobal2=3;intmain(){registerintlocal2=2;cout但是g++没有产生错误,并且local2的地址被打印出来了。那么为什么我可以毫无错误地获取地址呢? 最佳答案 的确,从历史上看,您无法获取register变量的地址。现在这只

java - 在 Java/C/C++ 中创建 MIPS 机器

大家好,我正在上汇编语言和计算机组织类(class)。最近我接到一项任务,要求我创建一个程序,该程序用Java、C或C++模拟MIPS机器。程序从ASM文件中读取十六进制并将行存储在数组中。然后它应该模拟MIPS机器。我一直在四处寻找,但不知道如何开始。有没有人有一些想法甚至伪代码让我走上正确的道路?要读取的文件示例:240800192409001e240a002301094020010a402000082021如果有人能让我走上正确的道路,那就太好了,谢谢! 最佳答案 您需要做的第一件事就是学会破译这些指令。看起来它们是8个十六进

c++ - 测试 AVX 寄存器是否包含一些相等的整数

考虑一个包含四个64位整数的256位寄存器。是否有可能在AVX/AVX2中有效地测试其中一些整数是否相等?例如:a){43,17,25,8}:结果必须是false因为4个数字中没有2个是相等的。b){47,17,23,17}:结果必须为“真”,因为编号17在AVXvector寄存器中出现2次。如果可能的话,我想在C++中执行此操作,但如有必要,我可以转到汇编。 最佳答案 对于AVX512(AVX512VL+AVX512CD),您将使用VPCONFLICTQ,专为此目的而设计。对于AVX2:通过减少冗余比较减少了一些操作:inttes

c++ - 有没有比添加 0.5f 和截断转换更直接的方法来将 float 转换为 int 并进行舍入?

在处理浮点数据的C++代码中,从float到int的舍入转换经常发生。例如,一种用途是生成转换表。考虑这个代码片段://ConvertapositivefloatvalueandroundtothenearestintegerintRoundedIntValue=(int)(FloatValue+0.5f);C/C++语言将(int)转换定义为截断,因此必须添加0.5f以确保向上舍入到最接近的正整数(当输入为正时)。对于以上,VS2015的编译器生成如下代码:movssxmm9,DWORDPTR__real@3f000000//0.5faddssxmm0,xmm9cvttss2siea

c++ - 获取线程 ID 在性能方面是否昂贵?

我需要从不受我控制的线程访问线程ID(它在一个异步回调函数中,并且从一组不同的线程中调用)。我想知道访问线程ID在性能方面是否代价高昂?我打算在Windows中使用boost::this_thread::get_id()或GetCurrentThreadId()。澄清一下,当数据从我的回调到达时,我需要准备一些本地缓存数组,我正在计划,以避免错误和锁定以对每个线程使用本地缓存,并使用访问正确的缓存线程ID。也因为来的数据总是大小不一,我不能把它放到栈中,我想避免一直创建和删除堆数据。 最佳答案 Windows将所有线程特定信息存储在

c++ - 我什么时候可以自信地使用 -O3 编译程序?

我看到很多人提示-O3选项:GCC:programdoesn'tworkwithcompilationoption-O3FloatingPointProblemprovidedbyDavidHammen我查看GCC的手册:-O3Optimizeyetmore.-O3turnsonalloptimizationsspecifiedby-O2andalsoturnsonthe-finline-functionsand-frename-registersoptions.而且我还确认了代码,以确保两个选项是-O3中仅有的两个优化:if(optimize>=3){flag_inline_func