Ada,Pascal和许多其他语言支持范围,一种子类型整数的方法.范围是有符号整数值,其范围从值(第一个)到另一个(最后一个).实现一个在OOP中执行相同操作的类很容易,但我认为本机支持该功能可以让编译器进行额外的静态检查.
我知道静态验证在一个范围内定义的变量不会"溢出"运行时,即由于输入错误,我无法进行验证,但我认为可以做一些事情.我想到了契约式设计方法(Eiffel)和Spec#(C#Contracts),它们提供了更为通用的解决方案.
是否有一个更简单的解决方案,至少在编译时检查C++,C#和Java中的静态越界赋值?某种静态断言?
编辑:我知道"范围"可以用于不同的目的:
迭代器
统计员
整数子类型
我会专注于后者,因为前者很容易在C*语言上映射.我考虑一组封闭的值,比如音乐音量,即从1到100的范围.我想用一个值递增或递减.我希望在静态溢出的情况下出现编译错误,例如:
volume=rangeInt(0,100); volume=101; // compile error! volume=getIntFromInput(); // possible runtime exception
谢谢.