我有一个代码,如果之前在代码中有错误,那么这些代码必须不能执行.我实际上使用一个名为bool的bool变量EndProg,如果设置为true,将指示程序避免执行某些代码部分.
我的问题是我不想使用这种方法而我更愿意使用goto它,因为它会使程序跳转到清理部分并避免EndProg多次检查值.
另一个问题是我在StackOverflow和其他网站上的许多页面上阅读过使用goto被认为是一种不好的做法,并且它可能使代码更难以阅读或创建错误.
我的代码很简单,我只需要使用一个标签,所以我怀疑这会产生问题; 但是我想知道是否有其他方法可以做我想要的而不创建执行清理任务或使用的函数return(因为,例如,我需要多次编写清理代码)而且我也不想在多个地方编写相同的大清理代码,然后使用return或执行其他操作.
我不想增加代码行数,也不想使用return或使用很多if也不检查状态变量的值.你会推荐什么 ?
这是一段代码:
bool EndProg=false;
/*
Lot of code that can set EndProg to true
*/
ClassType ClassName;
if(!EndProg && LoadConf(&ConfFilePath,&ClassName)==0)
{
int fildes=-1;
if(ClassName.abc) // bool
{
if(ClassName.FilePath==0) // char *
{
ClassName.FilePath=new(std::nothrow) char[9]();
if(ClassName.FilePath!=0)strcpy(ClassName.FilePath,"file.ext");
else EndProg=true;
}
if(!EndProg && mkfifo(ClassName.FilePath,S_IRUSR | S_IWUSR)==-1)
{
if(errno==EEXIST)
{
/* EEXIST is returned if the file already exists
We …Run Code Online (Sandbox Code Playgroud)