1.UDF错误代码排查
UDF出错如何进行错误排查???
1.1有错误信息显示
根据错误信息定位到具体错误类型,如代码错误、命名错误、内存分配错误或线程错误等问题。详细可查看五十、UDF常见错误及报错信息
1.2无错误信息显示
常见问题介绍了很多有错误信息的UDF问题,这类问题一般比较容易定位错误,能够更容易的解决。
但是还存在一类build之后没有任何错误信息的代码,编译能正常编译,但是只要calculation或者初始化就会出错,这类问题如果实在找不到问题,那就进行逐句排查。
2.排查举例
比如一个曾经困扰我一整天的问题:
以上代码看起来没有任何问题,导入Fluent,编译之后报错,出现以下错误信息
显示第一行出错,但是第一行确实没有任何问题。到底哪里有问题呢??你能不能看出来??
虽然这个例子有错误信息,但是这个错误信息却是一种误导。如果真想找到问题应该怎么做??
首先把DEFINE宏{}内所有的代码行全部删除或注释掉,再次编译,查看是否有错误信息。如果是点击calculation才会出错的,则需要删除代码后点击calculation。
点击build之后,控制台出现界面如下,没有报错。
然后依次还原各行代码,对于比较简单的代码,不需要验证可直接还原。将前三句代码还原
点击build,出现如下信息,没有报错。
再次还原代码
点击build之后,又出现报错信息
由此我们可以定位到错误代码
到底哪里有问题呢??
经过我反复实验,原来是注释出了问题。C语言有两种注释方法//和/*.......*/。这一行的注释//*0.8.........乘以0.8的*被C语言认为是注释语句,因此两种注释叠用,导致出错。只要将*去掉就可以。
上面的例子只是为了做一下示范,实际上的UDF代码更加复杂,问题也更加多样。如果通过错误提示或者经验都找不到错误,使用这种方式虽然繁琐,但基本是通用的,几乎所有的问题代码都能找到。