operator[]()之越界设计

某考题有大概如下代码, 如果越界情况返回一个@或者其他符号:
 
char CMystring::operator []( const int i)
{
 if(i>=0 && i<=last)
      return str[i];
 else
      return '@';
}
 
这一段代码的设计思想是有问题的, 原因:
(1)正常的字符串也会返回@, 函数使用者无法依据这个@判断是否越界在代码中直接报错!
     至少,返回0都比这乱七八糟的@好。
(2)如果工程实践中真的出了bug,程序员要找出这个bug会非常困难。粗暴地让计算机死机,
     或者让计算机抛个出错对话框,反而可以让程序员最方便定位错误的.现在这种方法,看
     起来健壮,反而使bug隐藏得很深,很难发现错误!这种walk-around的假安全没有价值!
(3)operator[]是高频访问接口,因此效率很重要,如果MyString类已经提供
     length()之类的函数,用户自己有义务不要乱访问。
(4)特别要说明的是,按照"[]"操作符的语义,返回char&更好!
     
     查看了一下STL里面的vector代码,用户如果敢越界,直接报错,不让程序执行下去了。
(4)如果实在要强调安全,可以用异常抛出方法,那是java语言的一贯实践。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值