//header file
namespace odbclib
{
class MemoryBlock
{
public:
typedef unsigned char byte;
explicit MemoryBlock(size_t = 0xff) throw(runtime_error);
MemoryBlock(MemoryBlock const&) throw(runtime_error);
virtual ~MemoryBlock();
MemoryBlock& initBlock(byte);
void const* getRawBlock() const;
void* getRawBlock();
void writeRawBlock(void const*,size_t);
size_t getSize()const;
MemoryBlock& setSize(size_t) throw(runtime_error);
template<typename T>
T getValue() const
{
//TODO:may cross memory boundary
T *p = (T *)m_buffer;
return *p;
}
template<typename T>
MemoryBlock& setValue(T const& t)
{
initBlock(0);
memcpy(m_buffer,(void const*)&t,min(sizeof(T),m_size));
return *this;
}
template<typename T,size_t N>
MemoryBlock& setValue(T const (&t)[N])
{
T * p = (T *)m_buffer;
T * end = (T *)((byte*)m_buffer + m_size);
int i = 0;
initBlock(0);
while(end - p > 0)
memcpy(p++,&t[i++],sizeof(T));
return *this;
}
private:
void * m_buffer;
size_t m_size;
};
template<> string MemoryBlock::getValue()const;
template<> MemoryBlock& MemoryBlock::setValue<string>(string const&);
}
//source file
namespace odbclib
{
MemoryBlock::MemoryBlock(size_t sz) throw(runtime_error)
:m_buffer(0),
m_size(0)
{
m_buffer = (byte*)::malloc(sz);
if(!m_buffer)
throw runtime_error("malloc failed!");
m_size = sz;
}
MemoryBlock::MemoryBlock(MemoryBlock const& other) throw(runtime_error)
:m_buffer(0),
m_size(0)
{
m_buffer = (byte*)::malloc(other.m_size);
if(!m_buffer)
throw runtime_error("malloc failed!");
m_size = other.m_size;
memcpy(m_buffer,(void*)other.m_buffer,m_size);
}
MemoryBlock::~MemoryBlock()
{
::free(m_buffer);
m_buffer = (void*)0;
m_size = 0u;
}
void const* MemoryBlock::getRawBlock() const{return (void*)m_buffer;}
void* MemoryBlock::getRawBlock(){return (void*)m_buffer;}
void MemoryBlock::writeRawBlock(void const* mem,size_t memsz)
{
memcpy(m_buffer,mem,min(memsz,m_size));
}
size_t MemoryBlock::getSize()const{return m_size;}
MemoryBlock& MemoryBlock::setSize(size_t sz) throw(runtime_error)
{
byte* newAddr = (byte*)::realloc(m_buffer,sz);
if(!newAddr)
throw runtime_error("realloc failed!");
m_buffer = newAddr;
m_size = sz;
return *this;
}
MemoryBlock& MemoryBlock::initBlock(byte data)
{
memset(m_buffer,data,m_size);
return *this;
}
template<>
string MemoryBlock::getValue()const
{
byte *lastByte = (byte*)m_buffer + m_size - 1;
byte data = *lastByte;
*lastByte = byte(0);
string s((char const*)m_buffer);
*lastByte = data;
return s;
}
template<>
MemoryBlock& MemoryBlock::setValue<string>(string const& s)
{
initBlock(0);
memcpy(m_buffer,s.data(),min(s.size(),m_size));
*((byte*)m_buffer + m_size - 1) = byte(0);
return *this;
}
}
通过 vc 2010 , g++ 4.5.2
分享到:
相关推荐
但在某些情况下,例如需要为特定类型提供不同的实现逻辑时,函数模板特化就派上用场了。在 `TC` 类模板的示例中,`funtest()` 函数的全特化版针对 `double, double` 参数进行了定制: ```cpp template void TC, ...
模板编程中如果要特化或偏特化(局部特化)一个类模板,需要特化该类模板的所有成员函数。类模板中大多数成员函数的功能可能是一模一样的,特化时我们可能只需要重新实现1、2个成员函数即可。在这种情况下,如果全部...
在这个特化的`swap`函数中,我们直接使用了`std::string`的`swap`成员函数,这通常比拷贝字符数组更高效。 在C++ Builder环境中,你可以创建一个新项目(Project1.cbproj),并在其中添加源代码文件(如Unit1.cpp和...
在C++泛型编程中,有时我们希望对模板类中的某个特定成员函数进行特化,而不是整个类。这是因为模板类的大部分代码可能都是通用的,只有极个别函数需要根据特定类型或条件有所不同。这种情况下,如果完全特化整个类...
模板特化包括函数模板特化和类模板特化。 - **函数模板特化**:例如,`Max` 函数模板可以处理各种类型的数值比较,但处理字符串时需要比较字符串内容而不是地址。通过函数模板特化,可以为`const char*`类型定义一...
这里 `A` 类包含两个模板参数 `T1` 和 `T2`,并且提供了一个 `function` 成员函数用于处理这两种类型的值。当我们在 `main` 函数中创建了 `A, char>` 的实例时,即: ```cpp A, char> a; a.function(12, 'b'); ``` ...
C++中有关模板的试题题型练习题是C++模板类型题型的综合应用,涵盖了函数模板、类模板的设计方法和实现。下面对标题、描述、标签和部分内容进行详细的解释和分析。 一、函数模板设计 函数模板是C++模板技术的核心...
类模板可以包含模板成员函数,这些函数可以使用类模板的参数作为其自己的参数。 ```cpp template class MyClass { public: template void myFunction(U u) { // ... } }; ``` #### 六、模板元编程 模板元...
// 其他成员函数... private: T* data; int size; int capacity; }; ``` 这个模板类可以创建如`Vector<int>`或`Vector<std::string>`等不同类型的向量类实例。 ### 模板特化与偏特化 有时候,我们可能希望为...
模板分为两类:类模板和函数模板。 类模板用于创建可参数化的类,其中`T`是模板参数,代表一种类型。在类模板中,`T`可以被任何类型替换,如整型、浮点型、自定义类型等。例如,下面的代码定义了一个名为`TClass`的...
5. **模板成员函数**:类模板中的函数也可以是模板,这称为成员函数模板。这种情况下,每个成员函数都可以有自己的类型参数。 6. **模板元编程**:VC++支持模板元编程,这是一种利用编译时计算和类型系统进行编程的...
// 函数模板特化 template void swap(int& a, int& b) { // 特化后的交换实现 } // 类模板偏特化 template class MyClass; // 基础模板 template class MyClass<int> { // 特化为int的类 public: // 特化后的...
类模板特化是C++中提高代码复用性和灵活性的重要手段。显式特化适用于为特定类型提供完全不同的实现,而局部特化允许对部分模板参数进行特化,更灵活地处理类型组合。同时,通过成员特化,我们可以针对个别成员函数...
有两种类型的模板特化:函数模板特化和类模板特化。 1. 函数模板特化:当标准模板不能满足特定类型的需求时,可以为这些类型定义特化的版本。例如,在比较字符串时,原始的`IsEqual`模板函数只能比较值,对于`char*...
2. **模板特化**:对于某些特定的数据类型,可以提供特化的函数模板,以优化特定类型的处理。 3. **隐式类型转换**:函数模板调用时,如果类型匹配不完全,编译器会尝试进行隐式类型转换。而普通函数则没有这个特性...
这在处理模板类的成员函数或模板模板参数时非常有用。偏特化可以更加精确地控制模板在特定情况下的行为。 **五、模板元编程** 模板元编程是一种在编译时进行计算的技术,利用模板的特性来生成代码。在VC++6.0中,...