linux中atoi函数的实现 值得借鉴,atoi 函数实现

要考虑的东西实在也挺多的。总结如下:

1 前面空格分隔符号的时候

2 第一个符号位处理+ -

3 遇到非数字字符退出

4 为正数的时候,大于INT_MAX上溢

5 为负数的时候, 小于INT_MIN下溢

6 为空字符串或者空指针的时候

1 int atoi(const char *str)

2 {

3 if (str == nullptr) return 0;

4 //注意:判断空字符串数组

5 if(*str == ‘\0‘) return 0;

6 long long llnum = 0;

7 int sign = 1;

8

9 while (*str == ‘ ‘)

10 {

11 str++;

12 }

13 if (*str == ‘-‘)

14 {

15 sign = -1;

16 str++;

17 }

18 //注意:不要溜了要判断+号的情况

19 else if(*str == ‘+‘)

20 {

21 str++;

22 }

23 while (*str >= ‘0‘ && *str <= ‘9‘)

24 {

25 int i = *str - ‘0‘;

26 llnum = llnum*10 + i;

27 if (llnum*sign > INT_MAX)

28 {

29 llnum = INT_MAX;

30 break;

31 }

32 else if (llnum*sign < INT_MIN)

33 {

34 llnum = INT_MIN;

35 break;

36 }

37 str++;

38 }

39 return int(sign*llnum);

40 }

头文件和INT_MAX和INT_MIN的含义用法。

一般情况下,C中int类型32位,范围是-2147483648到2147483647.

(1)最轻微的上溢是 INT_MAX + 1 :结果是 INT_MIN。

(2)最严重的上溢是 INT_MAX + INT_MAX :结果是 -2。

(3)最轻微的下溢是 INT_MIN - 1 :结果是 INT_MAX。

(4)最严重的下溢是 INT_MIN +INT_MIN :结果是 0。

应付溢出的最佳方法就是防范于未然:充分了解数据的范围,选择恰当的变量类型。

时间: 10-29

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值