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;
    }

        执行结果:


  • 相关阅读:
    js组件之间的通信
    localStorage, localforage, web sql三者的比较
    最近的学习计划
    无状态的web应用
    转 :meta name的含义:<META http-equiv=Content-Type content="text/html; charset=gb2312">
    css清除浮动的方法汇总
    segfault at 7fff6d99febc ip 0000003688644323 sp 00007fff6d99fd30 error 7 in libc.so.6[3688600000+175000]
    Linux内核定时器
    TCPIP网络协议层对应的RFC文档
    UIDocumentPickerViewController使用
  • 原文地址:https://www.cnblogs.com/mfrbuaa/p/4245502.html
Copyright © 2011-2022 走看看