转载:陷阱:fgets()返回的字符串会连\n一起返回

本文介绍了使用fgets()函数的一个常见陷阱,即它会将换行符一同读取到目标字符串中,这可能导致后续处理出现问题。文章提供了如何避免此问题的具体解决办法,并推荐了一种调试时打印字符串的方法。
陷阱:fgets()返回的字符串会连\n一起返回

    今天同事问我一个问题,说遇到了奇怪的事情,代码是这样的:
    char str[100];
    fgets(str, sizeof(str)-1, fp);
    str[sizeof(str)-1] = '\0';
    gethostbyname(str);     //在这里始终不能得到想要的结果
    而直接用常量就可以:
    gethostbyname("www.baidu.com");

    其原因就是fgets()这个函数,不仅仅返回了文件中一行的内容,连换行符\n也一并读出来了。这是一个陷阱,要注意。
    因此可以这样处理:
    char str[100];
    fgets(str, sizeof(str)-1, fp);
    str[sizeof(str)-1] = '\0';
    int nLen = strlen(str);
    if (str[nLen-1]=='\n')
    {
        str[nLen-1] = '\0';
    }

    还有,在调试的输出中,建议这样打印字符串: printf("[%s]\n", str); 
//在字符串的两端加上[],如果有换行,空格,TAB等不可见的内容,都可以从这里发现,便于提早发现问题。

转载于:https://www.cnblogs.com/zkliuym/archive/2010/04/21/1717541.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值