草庐IT

c - 如何在 C 中覆盖 Windows 系统函数

我们正在为将在汽车硬件上运行的软件组件开发测试模拟器(在Windows环境中,使用C语言)。实际上,测试模拟器是一个Windows应用程序,它包括作为核心源的sw组件,并允许测试核心的I/O接口(interface),并以这种方式测试其正确行为。不幸的是,在核心中定义的函数GetSystemTime导致与同名的Windows函数发生冲突:[core]returnTypeGetSystemsTime(UInt32*time)[windows]WINBASEAPIVOIDWINAPIGetSystemTime(LPSYSTEMTIMElpSystemTime)无法修改核心功能,因为它是组件

c++ - OpenGL——多个 glDrawArrays() 调用只显示第一次的结果?

所以我遍历了几个网格,每个网格都存储在自己的GL_ARRAY_BUFFER中,但它们共享相同的glVertexAttribPointer结构。我在for循环中遍历每个渲染/绘制过程:if(sConfig.mRendering.isRenderTypeActive(RENDER_TYPE_SINGLE_MESH)||sConfig.mRendering.isRenderTypeActive(RENDER_TYPE_TWO_MESH)){constintmesh_count=sConfig.mRendering.isRenderTypeActive(RENDER_TYPE_TWO_MESH

c - wglCreateContext 失败,错误为 "The pixel format is invalid"

我正在尝试使用上下文访问整个屏幕。这是我当前的代码(目前只有这个文件):#include#include#include#include#includeintmain(intargc,char*argv[]){HDChdc=GetDC(NULL);HGLRChglrc;hglrc=wglCreateContext(hdc);//Handleerrorsif(hglrc==NULL){DWORDerrorCode=GetLastError();LPVOIDlpMsgBuf;FormatMessage(FORMAT_MESSAGE_ALLOCATE_BUFFER|FORMAT_MESSAG

c - Windows 10 上的多线程性能比 Linux 差得多

我将一个多线程Linux应用程序移植到Windows,并在运行Windows10专业版的服务器上对其进行测试。与在相同双启动硬件上运行的Linux版本的性能相比,Windows版本的性能非常糟糕。我将代码简化为一个表现出相同症状的小型多线程示例。我希望SO社区能够就此应用程序在Windows和Linux之间存在这种性能差异的原因提供一些见解,并提供有关如何解决该问题的建议。我正在测试的机器具有双IntelXeonGold6136CPU(24/48物理/逻辑内核)@3.0GHz(Turbo加速至3.6GHz)和128GB内存。机器设置为双引导CentOS或Windows10。没有运行Wi

c - Mingw-w64 C版本支持吗?

minigw-w64支持哪些C版本?它使用msvcrt.dll那么它不会只支持ANSIC吗?但后来我看到像VLC这样的程序使用它,但说它们需要C11。这怎么可能?编辑:一些来源:Howtoprintfasize_twithoutwarninginmingw-w64gcc7.1?http://www.mingw.org/wiki/c99 最佳答案 MinGW使用msvcrt.dll,但在需要支持更新/固定功能的地方集成它,在某些情况下提供某些功能的完整重新实现(例如,您可以选择加入GNUprintf/扫描)。此类额外内容要么静态链接,

c - 从C文件中读取unicode字符

我正在尝试从.csv文件中读取UTF-8字符串,然后将其写入控制台。a.csv内容:Gijón在对该主题进行了一整天的研究后,我发现执行此类操作的正确方法应该类似于以下内容:intmain(intargc,char*argv[]){char*locale=setlocale(LC_ALL,"");printf("locale:%s\n",locale);constintMAX_LINE_SIZE=1024;charline[MAX_LINE_SIZE];wchar_twline[MAX_LINE_SIZE];//Attempt0:nospecialhandlingFILE*stream

C++ 套接字 : Enabling Promiscuous Mode in Windows

我正在尝试修改我当前的套接字程序以捕获混杂的数据包。我目前所拥有的是能够正常抓包的。我已经看到关于如何在Linux上执行此操作的其他答案,但我需要找到一种在Windows上完成此操作的方法。这是我的代码:intmain(intargc,charconst*argv[]){SOCKETs;//Theboundsocketstructsockaddr_inserver;intrecv_len;//Sizeofreceiveddatacharudpbuf[BUFLEN];//Abufferfortheincomingdata.floatdata;//Thedatainthepacket//C

c - 为什么 Windows 要求导入 DLL 数据?

在Windows上,可以从DLL加载数据,但需要通过导入地址表中的指针进行间接访问。因此,编译器必须知道正在访问的对象是否是使用__declspec(dllimport)从DLL导入的。类型说明符。这很不幸,因为这意味着设计用作静态库或动态库的Windows库的header需要知道程序链接到哪个版本的库。此要求不适用于函数,这些函数是为DLL透明地模拟的,stub函数调用实际函数,其地址存储在导入地址表中。在Linux上,动态链接器(ld.so)将所有链接数据对象的值从共享对象复制到每个进程的私有(private)映射区域。这不需要间接寻址,因为私有(private)映射区域的地址是模

c - Detecting if stdout is a console with MS Visual compilation, mingw64提供的console

我维护一个生成二进制数据的命令行实用程序。请求时,数据可以重定向到stdout。这在stdout被重定向到管道或文件时有效,但当stdout是一个控制台时,情况就不太一样了,因为它会垃圾控制台。为了保护用户免受此类错误,程序必须检测stdout是否是控制台,并在是时退出。现在,这并不是什么新鲜事,快速浏览一下Internet就会发现多种解决方案。主要缺点是没有“通用”方法,VisualStudio需要自己的风格。我用于Visual的控制台检测器有一个缺陷:它没有检测到stdout是一个控制台当控制台由mingw提供时,我认为这意味着它是mintty。这里是相关的代码部分:#ifdefi

c - 如何在 C 中的 DLL 中执行线程

我创建了一个运行3个工作线程的DLL,主线程处于循环中等待线程完成。线程已创建,但未执行线程。我尝试在使用CreateThread()创建的函数中设置MessageBox函数,但该框没有出现。我也尝试过调试,CreateThread()的返回值有效,因此线程被创建。BOOLWINAPIDllMain(){main();return1;}intmain(){HANDLEh1,h2,h3;h1=CreateThread(first)...h2=CreateThread(second)...h3=CreateThread(third)...WaitForSingleObject(h3,INF