如何使用C++中的property库?
由于代码还没有整理,大量的特化和偏特化散乱在代码里,所以我就暂时不发布源码了,不过这是迟早的事情,呵呵。先来说说怎么用吧,个人觉得还是蛮有意思的。
以下是可读写属性的声明方法:
#include<rdx/property.h>
data:image/s3,"s3://crabby-images/0a27b/0a27b3b6ae663e4dea594550834815eb2eb3388d" alt="如何使用C++中的property库?"
classTestProperty
data:image/s3,"s3://crabby-images/785f8/785f8ba162dcda682040e92e9404491fb9452e6e" alt="如何使用C++中的property库?"
...{
typedefTestPropertyMyType;
data:image/s3,"s3://crabby-images/cae3b/cae3b5a648b989c587c0ccfc6871a2aa46c667cb" alt="如何使用C++中的property库?"
public:
intset_X(intvalue)
data:image/s3,"s3://crabby-images/75c35/75c3528bf9d8a809ff742fff02e2040be28b39aa" alt="如何使用C++中的property库?"
...{
returnrdxLib::put(X,value*2);//为X设置新的值,
}
data:image/s3,"s3://crabby-images/cae3b/cae3b5a648b989c587c0ccfc6871a2aa46c667cb" alt="如何使用C++中的property库?"
public:
rdxLib::property_bag<MyType,int,read_write>X;
data:image/s3,"s3://crabby-images/cae3b/cae3b5a648b989c587c0ccfc6871a2aa46c667cb" alt="如何使用C++中的property库?"
TestProperty()
:X(&MyType::X,&MyType::set_X)
data:image/s3,"s3://crabby-images/75c35/75c3528bf9d8a809ff742fff02e2040be28b39aa" alt="如何使用C++中的property库?"
...{
}
};
data:image/s3,"s3://crabby-images/0a27b/0a27b3b6ae663e4dea594550834815eb2eb3388d" alt="如何使用C++中的property库?"
用法是:
intmain()
data:image/s3,"s3://crabby-images/785f8/785f8ba162dcda682040e92e9404491fb9452e6e" alt="如何使用C++中的property库?"
...{
TestPropertyprop;
prop.X=12;
std::cout<<prop.X<<std::endl;//shouldbe24.
intcalculate=2*prop.X+6-prop.X;
std::cout<<calculate<<std::endl;//shouldbe30.
prop.X+=22;
std::cout<<prop.X<<std::endl;//shouldbe68.
data:image/s3,"s3://crabby-images/cae3b/cae3b5a648b989c587c0ccfc6871a2aa46c667cb" alt="如何使用C++中的property库?"
return0;
}
这里注意到几点:
1. 对于可读写的属性,我直接把属性值就存在X当中,它
既是接口又是容器,用这种方法实现了默认的get和set函数。如果没有必要,就
可以根本不写get和set,使这个属性自动的退化成一个public成员。
2. 对于X的用法,可以把它完全当作一个简单的int来用,完全感觉不到它和普通int的区别。
还有一个好消息,如果在类的声明里面将int都改成一个类,比如std::string,那么在使用的时候,X就和普通的std::string一个样,代码如下:
#include<string>
#include<rdx/property.h>
data:image/s3,"s3://crabby-images/0a27b/0a27b3b6ae663e4dea594550834815eb2eb3388d" alt="如何使用C++中的property库?"
classTestProperty
data:image/s3,"s3://crabby-images/785f8/785f8ba162dcda682040e92e9404491fb9452e6e" alt="如何使用C++中的property库?"
...{
typedefTestPropertyMyType;
data:image/s3,"s3://crabby-images/cae3b/cae3b5a648b989c587c0ccfc6871a2aa46c667cb" alt="如何使用C++中的property库?"
public:
std::string&set_Name(conststd::string&value)
data:image/s3,"s3://crabby-images/75c35/75c3528bf9d8a809ff742fff02e2040be28b39aa" alt="如何使用C++中的property库?"
...{
returnrdxLib::put(Name,value+"ab");//SetadifferentvalueforName.
}
data:image/s3,"s3://crabby-images/cae3b/cae3b5a648b989c587c0ccfc6871a2aa46c667cb" alt="如何使用C++中的property库?"
public:
rdxLib::property_bag<MyType,std::string,read_write>Name;
data:image/s3,"s3://crabby-images/cae3b/cae3b5a648b989c587c0ccfc6871a2aa46c667cb" alt="如何使用C++中的property库?"
TestProperty()
:Name(&MyType::Name,&MyType::set_Name)
data:image/s3,"s3://crabby-images/75c35/75c3528bf9d8a809ff742fff02e2040be28b39aa" alt="如何使用C++中的property库?"
...{
}
};
data:image/s3,"s3://crabby-images/0a27b/0a27b3b6ae663e4dea594550834815eb2eb3388d" alt="如何使用C++中的property库?"
intmain()
data:image/s3,"s3://crabby-images/785f8/785f8ba162dcda682040e92e9404491fb9452e6e" alt="如何使用C++中的property库?"
...{
TestPropertyprop;
prop.Name="Hello";
std::stringstr="_test_";
std::cout<<prop.Name<<std::endl;//shouldbe"Helloab"
prop.Name+=str+prop.Name;
std::cout<<prop.Name<<std::endl;//shouldbe"Helloab_test_Helloabab"
std::cout<<prop.Name->size()<<std::endl;//shouldbe22.
data:image/s3,"s3://crabby-images/cae3b/cae3b5a648b989c587c0ccfc6871a2aa46c667cb" alt="如何使用C++中的property库?"
return0;
}
请注意,我可以写prop.Name->size()这样的代码,同时也可以调用std::string中的
所有const的公共成员和方法,真的就和普通std::string没区别了。原因呢,是因为property_bag从std::string派生,并且没有添加任何多余的公有成员或方法。
至于readonly和writeonly属性,就有一些不同了,因为这些属性注定不能直接存储在property_bag对象里面,property_bag就
退化成纯粹的接口。此时,如果Name是一个readonly的property,那么依然可以调用std::string所有const的公共成员和方法,这个和read_write的property一样。
这种readonly和writeonly属性声明方法如下:
#include<string>
#include<rdx/property.h>
data:image/s3,"s3://crabby-images/0a27b/0a27b3b6ae663e4dea594550834815eb2eb3388d" alt="如何使用C++中的property库?"
classTestProperty
data:image/s3,"s3://crabby-images/785f8/785f8ba162dcda682040e92e9404491fb9452e6e" alt="如何使用C++中的property库?"
...{
typedefTestPropertyMyType;
data:image/s3,"s3://crabby-images/cae3b/cae3b5a648b989c587c0ccfc6871a2aa46c667cb" alt="如何使用C++中的property库?"
intx_;
std::stringname_;
data:image/s3,"s3://crabby-images/cae3b/cae3b5a648b989c587c0ccfc6871a2aa46c667cb" alt="如何使用C++中的property库?"
public:
intget_X()const
data:image/s3,"s3://crabby-images/75c35/75c3528bf9d8a809ff742fff02e2040be28b39aa" alt="如何使用C++中的property库?"
...{
returnx_;
}
data:image/s3,"s3://crabby-images/cae3b/cae3b5a648b989c587c0ccfc6871a2aa46c667cb" alt="如何使用C++中的property库?"
std::string&set_Name(conststd::string&value)
data:image/s3,"s3://crabby-images/75c35/75c3528bf9d8a809ff742fff02e2040be28b39aa" alt="如何使用C++中的property库?"
...{
name_=value;
returnname_;
}
data:image/s3,"s3://crabby-images/cae3b/cae3b5a648b989c587c0ccfc6871a2aa46c667cb" alt="如何使用C++中的property库?"
public:
rdxLib::property_bag<MyType,int,readonly>X
rdxLib::property_bag<MyType,std::string,writeonly>Name;
data:image/s3,"s3://crabby-images/cae3b/cae3b5a648b989c587c0ccfc6871a2aa46c667cb" alt="如何使用C++中的property库?"
TestProperty()
:X(&MyType::X,&MyType::get_X)
,Name(&MyType::Name,&MyType::set_Name)
data:image/s3,"s3://crabby-images/75c35/75c3528bf9d8a809ff742fff02e2040be28b39aa" alt="如何使用C++中的property库?"
...{
}
};
如果在代码里面尝试给X赋值或读取Name,都会得到编译期间错误。
OK,这就是这个rdxLib.property的overview了。
本文地址:
http://www.45fan.com/a/question/69025.html