编译过程中弹出new(35) : error C2061: syntax error : identifier 'THIS_FILE'问题的原因及解决方法

本文介绍了一种常见的MFC程序编译错误,并详细解释了如何通过调整头文件的包含顺序来解决这类问题。

http://www.99inf.net/SoftwareDev/VC/27092.htm

 

原本一直正常的程序,今天编译时突然弹出以下内容

c:/program files/microsoft visual studio/vc98/include/new(35) : error C2061: syntax error : identifier 'THIS_FILE'
c:/program files/microsoft visual studio/vc98/include/new(35) : error C2091: function returns function
c:/program files/microsoft visual studio/vc98/include/new(35) : error C2809: 'operator new' has no formal parameters
c:/program files/microsoft visual studio/vc98/include/new(36) : error C2061: syntax error : identifier 'THIS_FILE'
c:/program files/microsoft visual studio/vc98/include/new(37) : error C2091: function returns function

等等

 

最后在网上查明后才知道原因,在往mfc类添加头文件时,需注意

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

这一段内容,添加的头文件必须在该段程序之前,否则编译不通过。

 

例如:

 

#include "Config.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

 

正确

 


以下的错误,将头文件放在该段程序之后将编译不通过
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

 

#include "Config.h"

出现 `near "uvm_sequence": syntax error, unexpected IDENTIFIER` 这类错误通常是由于代码语法问题导致的,以下是一些可能的解决方案: ### 1. 检查 UVM 库的包含情况 确保已经正确包含了 UVM 库,并且 Questasim 能够找到这些库文件。在编译代码之前,需要设置好 UVM 的环境变量和库路径。例如,在 Questasim 中可以使用以下命令来包含 UVM 库: ```tcl # 设置 UVM 库路径 set UVM_HOME /path/to/uvm # 编译 UVM 库 vlog -work work +incdir+$UVM_HOME/src $UVM_HOME/src/uvm_pkg.sv # 编译自己的代码 vlog -work work +incdir+$UVM_HOME/src your_file.sv ``` ### 2. 检查类定义语法 错误信息提示在 `uvm_sequence` 附近有语法错误,需要检查代码中涉及 `uvm_sequence` 的类定义部分。确保类的定义和继承语法正确。例如,正确的类继承语法如下: ```systemverilog class my_sequence extends uvm_sequence; // 类的内容 `uvm_object_utils(my_sequence) function new(string name = "my_sequence"); super.new(name); endfunction // 其他方法 endclass ``` ### 3. 检查代码拼写和大小写 确保 `uvm_sequence` 以及相关的 UVM 类名和宏的拼写和大小写都是正确的。SystemVerilog 是区分大小写的,拼写错误会导致语法错误。 ### 4. 检查文件编码 确保代码文件的编码格式是 Questasim 支持的,一般建议使用 UTF-8 编码。某些特殊字符或编码问题可能会导致语法错误。 ### 5. 检查代码依赖关系 确保在使用 `uvm_sequence` 之前,相关的 UVM 包已经被正确编译和加载。如果代码中有多个文件,需要确保文件的编译顺序正确。 ### 6. 检查 Questasim 版本兼容性 确保使用的 Questasim 版本与 UVM 库版本兼容。不同版本的 Questasim 对 SystemVerilog 语法的支持可能会有所不同,某些 UVM 特性可能在旧版本的 Questasim 中不被支持。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值