并非所有的代码都有返回值

superhjtc 2006-08-08 12:39:42
大家好,小弟做一个asp。net项目,有一代码要搜索出菜单的一个节点:
private MenuItem FindMenuItem(MenuItem startMenu, string menuValue)
{
foreach (MenuItem mItem in startMenu.ChildItems)
{
if (mItem.Value == menuValue)
{
return mItem;
}
else if (mItem.ChildItems.Count > 0)
{
return FindMenuItem(mItem, menuValue);
}
}
}
但是代码编译不了,说是并非所有的代码都有返回值,请各位高手帮帮小弟看看该怎么解决。
...全文
324 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
Zine_Alone 2006-08-08
  • 打赏
  • 举报
回复
该代码并不能保证能执行到return.也就是说该段代码可能出现没有返回值的情况。

foreach 如果其中的项为0呢?则根本不会进到里面去。
GXY2005 2006-08-08
  • 打赏
  • 举报
回复
楼主刚出道??
jf
blueice008 2006-08-08
  • 打赏
  • 举报
回复
在 foreach结束后给一个返回值。
gzlaspnet 2006-08-08
  • 打赏
  • 举报
回复
在 foreach结束后给一个返回值。
pccc1984 2006-08-08
  • 打赏
  • 举报
回复
你把return都写在if中了.不一定保证有返回值.所以要在if外写个return.返回null也好.在接受调用的地方再判断一下
exiori 2006-08-08
  • 打赏
  • 举报
回复
返回值的层次不对。
superhjtc 2006-08-08
  • 打赏
  • 举报
回复
小弟确实刚出道啊,下学期要读大三,呵呵,趁还有两年时间给小公司写些代码混点小经验。

代码中单单加个return null语法过了,逻辑还不行,今天改了改,要改成
private MenuItem FindMenuItem(MenuItem startMenu, string menuValue)
{
MenuItem temp;

foreach (MenuItem mItem in startMenu.ChildItems)
{
if (mItem.Value == menuValue)
{
return mItem;
}
else if (mItem.ChildItems.Count > 0)
{
temp = FindMenuItem(mItem, menuValue);
if (temp != null)
{
return temp;
}
}
}

return null;
}

就ok了哈。
szc21 2006-08-08
  • 打赏
  • 举报
回复
并非所有代码都有返回值就是你代码里面没考虑完所有的返回情况,如LS说的,后面加个return就可以了
_-_-_-_- 2006-08-08
  • 打赏
  • 举报
回复
private MenuItem FindMenuItem(MenuItem startMenu, string menuValue)
{
foreach (MenuItem mItem in startMenu.ChildItems)
{
if (mItem.Value == menuValue)
{
return mItem;
}
else if (mItem.ChildItems.Count > 0)
{
return FindMenuItem(mItem, menuValue);
}
}
return null;
}


改成这样
当没有符合条件的..就返回一个空值

62,046

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧