zoukankan      html  css  js  c++  java
  • atoi()函数的实现

       

        上一篇博客讲的是atoi()函数的功能及举例,如今呢,就自己写写代码(依据atoi()的功能)来表示atoi()函数的实现。我在这里先把atoi()函数的功能贴出来,也好有个參考啊~~~

        atoi()函数的功能:将字符串转换成整型数;atoi()会扫描參数nptr字符串,跳过前面的空格字符,直到遇上数字或正负号才開始做转换,而再遇到非数字或字符串时('')才结束转化,并将结果返回(返回转换后的整型数)。

        atoi()函数实现的代码:

    /*
    * name:xif
    * coder:xifan@2010@yahoo.cn
    * time:08.20.2012
    * file_name:my_atoi.c
    * function:int my_atoi(char* pstr)
    */
    
    int my_atoi(char* pstr)
    {
    	int Ret_Integer = 0;
    	int Integer_sign = 1;
    	
    	/*
    	* 推断指针是否为空
    	*/
    	if(pstr == NULL)
    	{
    		printf("Pointer is NULL
    ");
    		return 0;
    	}
    	
    	/*
    	* 跳过前面的空格字符
    	*/
    	while(isspace(*pstr) == 0)
    	{
    		pstr++;
    	}
    	
    	/*
    	* 推断正负号
    	* 假设是正号,指针指向下一个字符
    	* 假设是符号,把符号标记为Integer_sign置-1,然后再把指针指向下一个字符
    	*/
    	if(*pstr == '-')
    	{
    		Integer_sign = -1;
    	}
    	if(*pstr == '-' || *pstr == '+')
    	{
    		pstr++;
    	}
    	
    	/*
    	* 把数字字符串逐个转换成整数,并把最后转换好的整数赋给Ret_Integer
    	*/
    	while(*pstr >= '0' && *pstr <= '9')
    	{
    		Ret_Integer = Ret_Integer * 10 + *pstr - '0';
    		pstr++;
    	}
    	Ret_Integer = Integer_sign * Ret_Integer;
    	
    	return Ret_Integer;
    }

        如今贴出执行my_atoi()的结果,定义的主函数为:int  main  ()

    int main()
    {
    	char a[] = "-100";
    	char b[] = "456";
    	int c = 0;
    	
    	int my_atoi(char*);	
    
    	c = atoi(a) + atoi(b);
    	
    	printf("atoi(a)=%d
    ",atoi(a));
    	printf("atoi(b)=%d
    ",atoi(b));
    	printf("c = %d
    ",c);
    
    	return 0;
    }

        执行结果:


  • 相关阅读:
    快速排序算法图文详解(模版使用)
    数据库中事务和隔离级别解析
    详解对象的创建,布局,定位,存活判断
    SpringCloud-Ribbon:认识并配置负载均衡
    SpringCloud-Feign:接口式微服务调用
    SpringCloud-Eureka(3)集群配置和了解CAP原则
    SpringCloud-Eureka(2)服务注册与信息配置
    SpringCloud-Eureka(1)认识Eureka和初步配置
    Promise
    es6
  • 原文地址:https://www.cnblogs.com/hrhguanli/p/4554080.html
Copyright © 2011-2022 走看看