为了提高不同设备之间程序的可移植性,ISO C,POSIX,XSI三个标准对一些值作出了限制,如int最大值的下限(在ISO C中,即实现的int的最大值必须大于这个值),每个进程能够打开的文件数的下限(在POSIX中),路径名中字节数(在XSI中)。这些编译时限制的常量都列在头文件<limits.h>当中;而还有一些限制值需要在运行时确定,使用函数 sysconf, pathconf, fpathconf 确定。使用这些限制的常量而非系统实际支持的量或幻数可以提高程序的可移植性。举例来说,守护进程中一个常见的代码序列是关闭所有打开的文件。有些程序假定<sys/param.h>头文件中定义了常量NOFILE:
#include <sys/param.h>
for (int i = 0; i < NOFILE; i++)
close(i);
还有一些程序使用<stdio.h>版本提供的作为上限的常量_NFILE。某些程序甚至直接将上限值硬编码为20。但这些方法都不可移植。如果希望用POSIX.1的OPEN_MAX确定这个上届值来提高可移植性:
#include <unistd.h>
for (int i = 0; i < sysconf(_SC_OPEN_MAX); i++)
close(i);
此时还会出现一个问题,即如果OPEN_MAX是一个不确定的值,sysconf会返回-1,使得for循环不会执行。
《Unix环境高级编程》对这种状况提出的方法是在OPEN_MAX为不确定的条件下选择一个限制值,虽然不能在所有的情况下都能正确工作,但这是能够选择的最好方法。