在注册对象必须具有唯一名称的系统中,我想在名称中使用/包含对象的this
指针。我想要最简单的方法来创建???
,其中:
std::string name = ???(this);
答案 0 :(得分:33)
您可以使用地址的字符串表示形式:
#include <sstream> //for std::stringstream
#include <string> //for std::string
const void * address = static_cast<const void*>(this);
std::stringstream ss;
ss << address;
std::string name = ss.str();
答案 1 :(得分:7)
您的意思是将指针本身格式化为字符串?
std::ostringstream address;
address << (void const *)this;
std:string name = address.str();
或者......是的,在我输入此内容时所有其他等效答案!
答案 2 :(得分:4)
#include <sstream>
#include <iostream>
struct T
{
T()
{
std::ostringstream oss;
oss << (void*)this;
std::string s(oss.str());
std::cout << s << std::endl;
}
};
int main()
{
T t;
}
答案 3 :(得分:2)
你可以使用ostringstream这个指针的地址并把那个ostringstream的值作为字符串吗?
答案 4 :(得分:0)
在注册对象必须具有唯一名称的系统中,我想在名称中使用/包含对象的this指针。
对象的地址不一定是唯一的。示例:您动态分配此类对象,暂时使用它,删除它,然后再分配另一个此类对象。新分配的对象可能与前一个对象的地址相同。
有更好的方法可以为某些内容生成唯一名称。一个gensym计数器,例如:
// Base class for objects with a unique, autogenerated name.
class Named {
public:
Named() : unique_id(gensym()) {}
Named(const std::string & prefix) : unique_id(gensym(prefix)) {}
const std::string & get_unique_id () { return unique_id; }
private:
static std::string gensym (const std::string & prefix = "gensym");
const std::string unique_id;
};
inline std::string Named::gensym (const std::string & prefix) {
static std::map<std::string, int> counter_map;
int & entry = counter_map[prefix];
std::stringstream sstream;
sstream << prefix << std::setfill('0') << std::setw(7) << ++entry;
return sstream.str();
}
// Derived classes can have their own prefix. For example,
class DerivedNamed : public Named {
public:
DerivedNamed() : Named("Derived") {}
};