Windows上使用C++11 编译出现错误

1>C:\Program Files (x86)\Windows Kits\10\Include\10.0.19041.0\shared\rpcndr.h(192,14): error C2872: “byte”: 不明确的符号

1>C:\Program Files (x86)\Windows Kits\10\Include\10.0.19041.0\shared\rpcndr.h(191,23): message : 可能是“unsigned char byte”

1>C:\Program Files (x86)\Microsoft Visual Studio\2019\Enterprise\VC\Tools\MSVC\14.28.29910\include\cstddef(29,12): message : 或 “std::byte”

C++17 内部定义了std:byte类型,Windows系统定义了byte类型,两个类型冲突了。并且在rpcndr.h头文件内部使用了byte,编译器不知道该使用哪个byte。rpcndr.h在引入 Windows.h时会导入。

1,不使用 using namespace std; ,这样两个类型在不同的命名空间,因此不会冲突。

2. 全局定义 宏 _HAS_STD_BYTE=0 ,这个会禁用std::byte类型。弊端:如果外部库使用了std::byte可以能会导致无法编译。

3. 提前包含 #include <Windows.h>,Windows.h内部会导入rpcndr.h。

以下是报错代码,报错:rpcndr.h(192,14): error C2872: “byte”: 不明确的符号

#include <cstddef> // for std::byte
using namespace std;
#include <Windows.h>

但以下代码不会报错

#include <cstddef> // for std::byte
#include <Windows.h>
using namespace std;
#include <Windows.h>  // 这个windows.h被上一个屏蔽了

因为使用std命名空间以前以及包含了 Windows.h,而第二个Windows.h被第一个Windows.h屏蔽了不起作用,所以不过会报错。

如果项目中有一个“总同头文件”或“预处理头文件”,在里面添加#include <Windows.h>就可以避免byte类型冲突。顺便可以加上以下宏,消除部分windows.h内部的宏:

    #ifndef NOMINMAX
    #define NOMINMAX 1// prevent windows redefining min/max
    #endif
    #include <Windows.h>
    #undef far
    #undef near
C:\Program Files (x86)\Windows Kits\10\Include\10.0.19041.0\shared\rpcndr.h(192,14): error C2872: “byte”: 不明确的符号
loadLibrary msc error :java.lang.UnsatisfiedLink Error : dalvik.system.PathClassLoader[DexPathList[[zip file “/data/app/com.example.xflinean-1/base.apk”],nativeLibraryDirectories=[/vendor/lib, /system/lib]]] couldn’t find “libmsc.so” 出现加载so包有问题时 在buidl.gradle(module:app)下的a ndr oid{ defaultConfig {
程序在内存中保存数据。在c++ 17引入了 一种std:: byte 类型,它确实表示内存元素的“nature”类型字节。与char或int类型的关键区别在于,它不是字符类型且非算术类型。 byte 只是位的汇集,而且只对它定义逐位运算符。即唯一支持的“计算”操作是位操作符。 1. std:: byte 的使用 下面的例子演示了std:: byte : #include <cstddef>...
编译 pycaffe时报错:fatal error : numpy/arrayobject.h没有那个文件或目录 其实numpy已经是安装的,anaconda2里面有,python中import numpy也没有问题,但就是在此处报错,解决方法:  sudo apt-get install python-numpy sudo make pycaffe -j16 pycaffe就 编译 成功了 如果还是不行,可以试试: import numpy as npnp.get_include() /usr/local/lib/python2.7/dist-packages/num
找了很久的原因,我遇到的问题的根本原因就是命名空间冲突。在 头文件 里包涵了using namespace google::protobuf,同时又用c++17,这样两个命名空间冲突导致报错。把.h文件里的using namespace google放到对应的.cpp里就解决了这个问题。
问题:从网上拷贝了一段代码,粘贴到自己写的程序strcat_compare.c中,然后 编译 gcc -o strcat_compare strcat_compare.c;出现 错误 如下: 代码如下:avid@ubuntu:~/wrk/tmp$ gcc -o strcat_compare strcat_compare.c strcat_compare.c: In function ‘main’:strcat_compare.c:28:1: error : stray ‘\343′ in programstrcat_compare.c:28:1: error : stray ‘\200′ in progr
JNI是什么就不介绍了,网络上面一大推解释; JNI的主要流程就是java的定义好方法,然后使用JAVAH生成头,把 头文件 和对应JDK里面的.H文件,C ++会根据 头文件 实现,然后生成动态库: 第一步:定义 头文件 方法 - 生成 头文件 : package com.koala.auth.jni; import j...
这个问题可能是因为你的交叉 编译 工具链没有正确配置,导致无法找到所需的 头文件 。你可以尝试以下几种方法: 1. 检查交叉 编译 工具链是否正确安装和配置。可以通过执行命令 `which <compiler>` 来查看 编译 器的路径,以及执行命令 `echo $PATH` 来查看环境变量是否设置正确。 2. 检查 头文件 是否存在于正确的路径中。可以使用命令 `find / -name string.h` 来查找该文件的位置。如果找到了该文件,可以将路径添加到 编译 器的搜索路径中,例如使用参数 `-I/path/to/header`。 3. 确认所使用的 编译 器是否支持交叉 编译 。有些 编译 器可能需要特定的参数或配置才能正确进行交叉 编译 。 希望这些方法能够帮助你解决问题。