五十一、UDF错误代码排查

1.UDF错误代码排查

UDF出错如何进行错误排查???

 

五十一、UDF错误代码排查的图1

1.1有错误信息显示

根据错误信息定位到具体错误类型,如代码错误、命名错误、内存分配错误或线程错误等问题。详细可查看五十、UDF常见错误及报错信息

五十一、UDF错误代码排查的图2

1.2无错误信息显示

常见问题介绍了很多有错误信息的UDF问题,这类问题一般比较容易定位错误,能够更容易的解决。

但是还存在一类build之后没有任何错误信息的代码,编译能正常编译,但是只要calculation或者初始化就会出错,这类问题如果实在找不到问题,那就进行逐句排查。

 

2.排查举例

比如一个曾经困扰我一整天的问题:

 

五十一、UDF错误代码排查的图3

以上代码看起来没有任何问题,导入Fluent,编译之后报错,出现以下错误信息

 

五十一、UDF错误代码排查的图4

显示第一行出错,但是第一行确实没有任何问题。到底哪里有问题呢??你能不能看出来??

 

虽然这个例子有错误信息,但是这个错误信息却是一种误导。如果真想找到问题应该怎么做??

 

首先把DEFINE宏{}内所有的代码行全部删除或注释掉,再次编译,查看是否有错误信息。如果是点击calculation才会出错的,则需要删除代码后点击calculation。

 

五十一、UDF错误代码排查的图5

点击build之后,控制台出现界面如下,没有报错。

 

五十一、UDF错误代码排查的图6

 

然后依次还原各行代码,对于比较简单的代码,不需要验证可直接还原。将前三句代码还原

五十一、UDF错误代码排查的图7

点击build,出现如下信息,没有报错。

 

五十一、UDF错误代码排查的图8

 

再次还原代码

 

五十一、UDF错误代码排查的图9

点击build之后,又出现报错信息

 

五十一、UDF错误代码排查的图10

由此我们可以定位到错误代码

 

五十一、UDF错误代码排查的图11

到底哪里有问题呢??

经过我反复实验,原来是注释出了问题。C语言有两种注释方法//和/*.......*/。这一行的注释//*0.8.........乘以0.8的*被C语言认为是注释语句,因此两种注释叠用,导致出错。只要将*去掉就可以。

 

五十一、UDF错误代码排查的图12

 

上面的例子只是为了做一下示范,实际上的UDF代码更加复杂,问题也更加多样。如果通过错误提示或者经验都找不到错误,使用这种方式虽然繁琐,但基本是通用的,几乎所有的问题代码都能找到。

 

 

为了方便大家学习交流,我创建了QQ群:群一人数已满员,可加二群:876525686,大家可以在其中讨论相关的问题,同时我会将所有文章的源文件都放到QQ群中,还会放一些其它的学习文件。欢迎大家加入。

登录后免费查看全文
立即登录
App下载
技术邻APP
工程师必备
  • 项目客服
  • 培训客服
  • 平台客服

TOP

1