c++ - 如何将数值数据序列化为 char*

标签 c++

我需要序列化int、double、long 和 float 进入字符缓冲区,这就是我目前的做法

int value = 42;
char* data = new char[64];
std::sprintf(data, "%d", value);

// check
printf( "%s\n", data );

首先,我不确定这是否是最好的方法,但我眼前的问题是确定缓冲区的大小。
在这种情况下,数字 64 纯粹是任意的。 我怎样才能知道传递的数字的确切大小,以便我可以分配准确的内存;不大于不小于要求?

C 或 C++ 解决方案都可以。

编辑
根据下面约翰的回答(分配足够大的缓冲区..),我正在考虑这样做

char *data = 0;
int value = 42;
char buffer[999];
std::sprintf(buffer, "%d", value);
data = new char[strlen(buffer)+1];
memcpy(data,buffer,strlen(buffer)+1);

printf( "%s\n", data );

也许可以以牺牲速度为代价来避免浪费。并且并没有完全解决潜在的溢出
或者我可以只使用足以表示类型的最大值。

最佳答案

在 C++ 中,您可以使用字符串流,而不必担心缓冲区的大小:

#include <sstream>

...

std::ostringstream os;
int value=42;
os<<42; // you use string streams as regular streams (cout, etc.)
std::string data = os.str(); // now data contains "42"

(如果您愿意,可以通过 c_str() 方法从 std::string 获取 const char *)


在 C 中,您可以使用 snprintf 来“伪造”写入并获取要分配的缓冲区的大小;事实上,如果您将 0 作为 snprintf 的第二个参数传递,则可以将 NULL 作为目标字符串传递,并且您将获得将作为返回值写入的字符。所以在 C 中你可以这样做:

int value = 42;
char * data;
size_t bufSize=snprintf(NULL, 0 "%d", value)+1; /* +1 for the NUL terminator */
data = malloc(bufSize);
if(data==NULL)
{
    // ... handle allocation failure ...
}
snprintf(data, bufSize, "%d", value);
// ...
free(data);

关于c++ - 如何将数值数据序列化为 char*,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7140943/

相关文章:

c++ - BLAS中的元素 vector vector 乘法?

c++ - 你如何断言一个对象在 C++ 中有一个特定的方法?

c++ - wxSlider点击鼠标时如何设置步长?

c++ - 空类和空函数的大小?

C++ WinAPI - GetConsoleScreenBufferInfo 总是因句柄无效而失败(返回 0)

c++ - 何时使用 std::make_shared_for_overwrite?

c++ - 在圆圈周围放置一个 ofImage

c++ - 在 linux 中,如何判断我是链接到静态库还是动态库?

c++ - 如何使用 windbg "dt"命令从命名空间污染的内存转储中获取信息

c++ - 访问 `std::vector` 的保留但未调整大小的内存作为原始内存是否安全?