Windows程序设计中min、max宏使用原因备忘

第一种情况:是将一个变量限制在一个合理的范围之内,例如有些变量必须大于0,而且必须小于某个最大值,不然没有意义。

  以下面一行代码为例:

iFont = max (0, min (cFonts - 1, iFont)) ;

上段代码的参考背景:

SetScrollRange (hwnd, SB_VERT, 0, cFonts - 1, TRUE) ;

因为程序中对iFonts有加减运算,所以,计算过程中它就可能变为负值或者大于cFonts,但在滚动条的位置中,是从0到cFonts - 1这个范围,所以,首先使用min在iFont和cFonts中选择小的,再使用max在0和min结果中选择大的,即正的值。

第二种情况:为了提高程序运行的效率,以213页的这段代码为例:

 for (i = 0 ; i < min (cLines, cyClient / cyChar - 1) ; i++)

for循环显示的内容如果超过了“cyClient / cyChar - 1”也看不到,所以也就没必要输出。

原文地址:https://www.cnblogs.com/tingshuixuan2012/p/3130919.html