java从1.4开始引入了断言,但是默认断言的功能是不开启的,java断言的开启不同于c语言,c语言是在编译的时候加入断言的,而java断言的启用是在运行时期指定的。
由于1.4以后系统类中也有断言的使用,所以如果要开启系统类的断言需要使用java -esa,如果需要开启用户类的断言则需要java -ea。
在实际使用中,对于边界值和函数入参、返回值的校验我们一般是通过if..else来进行,除了向控制台报错之外,有可能还要使用一些应用定义的exception或者向数据库中记录一个日志,可以发出告警等等,总体来说这样做的可控性是非常强的。
java这个assert功能是个鸡肋,很难想象有谁会在系统上线的时候会在系统运行的时候加入一个-ea来开启断言,一定要这样做的后果是,如果参数越界的的话程序会抛出一个不应捕获的严重级别的Error错误,不可控也不可靠。
在开发阶段,唯一有用的地方有可能就是和testng结合使用了,可是我貌似更喜欢junit4一点,一样有annotation的强力支持,所以总结一下,java assert的出现和使用都是没有必要的。
由于1.4以后系统类中也有断言的使用,所以如果要开启系统类的断言需要使用java -esa,如果需要开启用户类的断言则需要java -ea。
在实际使用中,对于边界值和函数入参、返回值的校验我们一般是通过if..else来进行,除了向控制台报错之外,有可能还要使用一些应用定义的exception或者向数据库中记录一个日志,可以发出告警等等,总体来说这样做的可控性是非常强的。
java这个assert功能是个鸡肋,很难想象有谁会在系统上线的时候会在系统运行的时候加入一个-ea来开启断言,一定要这样做的后果是,如果参数越界的的话程序会抛出一个不应捕获的严重级别的Error错误,不可控也不可靠。
在开发阶段,唯一有用的地方有可能就是和testng结合使用了,可是我貌似更喜欢junit4一点,一样有annotation的强力支持,所以总结一下,java assert的出现和使用都是没有必要的。