微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

现代C方式将字符串复制到char *

这样做的现代方法是什么?像< cstring>这样的标题不推荐使用,并且某些编码样式禁止使用“类C”函数.我有三种做同样事情的方法.现代C中哪一个最惯用?

1.使用迭代器并包含null终止符

{
    std::string test{"hello,world!"};
    char* output = new char[test.size() + 1];
    std::copy(test.begin(),test.end(),output);
    output[test.size() + 1] = '\0';
    std::cout << output;
    delete output;
}

2.使用包含空终止符的c_str()

{
    std::string test{"hello,world!"};
    char* output = new char[test.size() + 1];
    std::copy(test.c_str(),test.c_str() + std::strlen(test.c_str()),output);
    std::cout << output;
    delete output;
}

3.使用std :: strcpy

{
    std::string test{"hello,world!"};
    char* output = new char[test.size() + 1];
    std::strcpy(output,test.c_str());
    std::cout << output;
    delete output;
}

我不希望看起来像一个面试官说“你用strcpy,你必须是C程序员”的菜鸟.

解决方法

获得连续缓冲区的现代安全前C 17方法是std :: vector.

std::string test{"hello,world!"};
std::vector<char> output(test.c_str(),test.c_str()+test.size()+1);
// use output.data() here...

从C 17开始,std :: string有一个非const data()重载.

std::string test{"hello,world!"};
char * p = test.data();

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐