1

我做了我自己的strtod()功能。

我可以printf在控制台中,但它在运行时会发出这样的警告:

myStrTod.c|29|警告:“赋值从指针目标类型中丢弃 'const' 限定符”|


#include<stdio.h>
float myStrTod(const char * nPtr, char ** endPtr);
int rakamMi(int c);

int main()
{
    float d;
    const char *string = "51.2% kabul edildi";
    char *stringPtr;

    d = myStrTod(string,&stringPtr);
    printf("%.3f %s\n",d,stringPtr);
    return 0;
}

float myStrTod(const char * nPtr, char ** endPtr)
{
    char s1[20],s2[50];
    int i,j,k = 0,pnt,y = 1,num1 = 0,num2= 0;
    float f1,f2;
    for(i = 0; nPtr[i]; i++){
        if(rakamMi(nPtr[i]) || nPtr[i] == '.')
            s1[i] = nPtr[i];
        else break;
    }
    j = i;
    for(; nPtr[i]; i++)
       endPtr[i - j] = nPtr + i;

    for(i = 0; s1[i]; i++)
        if(s1[i] == '.'){
            pnt = i;
            break;
        }

    for (i = 0; s1[i]; i++)
    {
        if(i < pnt) num1 = num1 * 10 + (s1[i] - 48);
        else if (i == pnt) continue;
        else{
            num2 = num2 * 10 + (s1[i] - 48);
            ++k;
        }
    }
    for(i = 1; i <= k; i++)
        y = y * 10;

    f1 = num2 / (float) y;
    f2 = num1 + f1;
   // endPtr = s2;
    return f2;
}

int rakamMi(int c)
{
    if(c >= 48 && c <= 57)
        return 1;
    else
        return 0;
}
4

2 回答 2

1

您正在尝试将指针到常量字符类型的值分配给指针字符类型的变量。您可以更改的签名,myStrTod以便您的输出是指向 const char 的指针:

float myStrTod(const char *nPtr, const char **endPtr);

然后GCC会报不同的错误:

40937624.c: In function ‘main’:
40937624.c:11:25: warning: passing argument 2 of ‘myStrTod’ from incompatible pointer type [-Wincompatible-pointer-types]
     d = myStrTod(string,&stringPtr);
                         ^
40937624.c:2:7: note: expected ‘const char **’ but argument is of type ‘char **’

这可以通过声明stringPtr为指向 const 的指针来解决:

const char *stringPtr;

由于您从不写入 的内容*stringPtr,因此这就足够了。

于 2016-12-05T12:36:36.857 回答
0

程序给出了结果,但在该 program.exe 停止工作之后!

原因是这样的:

    j = i;
    for(; nPtr[i]; i++)
       endPtr[i - j] = nPtr + i;

您只是将单个的地址传递char *stringPtr给函数,但使用参数endPtr就像有一个 的数组一样char *,从而覆盖 . 的存储后面的内存stringPtr。将以上所有内容更改为:

    *endPtr = nPtr + i;
于 2018-03-02T10:39:05.690 回答