C连载17-明示变量以及两种头文件举例

一、常量和C预处理器

1.符号常量(symbolic constant)

  • 编译程序的时候程序中的符号常量都会被实际字面量所替换,这一过程称为编译时替换
  • 格式:末尾不加分号,中间不加等号,字面量可以是数字,字符,字符串等
#define CHANGLIANGNAME 890

2.const限定符

  • C90标准增加了const关键字,用于限定一个变量为只读
const int MONTHS = 12;//MONTHS在程序中不可以更改,值为12
  • const用起来比#define更加灵活;
  • const类型限定符声明的是变量不是常量。

3. 明示常量

  • C头文件limits.h和float.h分别提供了与整数类型和浮点类型大小限制相关的详细信息
  • 又称为符号常量
  • limits.h中的一些明示常量
明示常量含义
CHAR_BITchar类型的位数
CHAR_MAXchar类型的最大值
CHAR_MINchar类型的最小值
SCHAR_MAXsigned char类型的最大值
SCHAR_MINsigned char类型的最小值
UCHAR_MAXunsigned char类型的最大值
SHRT_MAXshort类型的最大值
SHRT_MINshort类型的最小值
USHRT_MAXunsigned short类型的最大值
INT_MAXint类型的最大值
INT_MINint类型的最小值
UINT_MAXunsigned int最大值
LONG_MAXlong类型最大值
LONG_MINlong类型最小值
ULONG_MAXunsigned long类型最大值
LLONG_MAXlong long类型最大值
LLONG_MINlong long类型的最小值
ULLONG_MAXunsigned long long类型最大值
  • float.h中的一些明示常量(把明示常量名种的FLT分别替换成DBL和LDBL,即可分别表示double和long double
明示常量含义
FLT_MANT_DIGfloat类型的尾数位数
FLT_DIGfloat类型的最少有效数字位数(十进制)
FLT_MIN_10_EXP带有全部有效数字的float类型的最小负指数(以10为底)
FLT_MAX_10_EXPfloat类型的最大正指数(以10为底)
FLT_MIN保留全部精度的float类型最小整数
FLT_MAXfloat类型的最大正数
FLT_EPSILON1.00和比1.00大的最小float类型值之间的差值
  • 直接代码举例:
#include<stdio.h>
#include<limits.h> //整形限制
#include<float.h> //浮点型限制
#pragma warning(disable:4996)

int D17_defines(void) {
	printf("Some number limits for this system:\n");
	printf("Biggest int: %d\n", INT_MAX);
	printf("Smallest long long: %lld\n", LLONG_MIN);
	printf("One byte = %d bits on this system.\n", CHAR_BIT);
	printf("Largest double:%e\n", DBL_MAX);
	printf("Smallest normal float:%e\n", FLT_MIN);
	printf("float precision = %d digits\n", FLT_DIG);
	printf("float epsilon = %e\n", FLT_EPSILON);

	return 0;
}

17.1

二、源码:

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值