`
chenqi210
  • 浏览: 78924 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

类成员函数模板特化

    博客分类:
  • c++
阅读更多

 

//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

分享到:
评论

相关推荐

    C++ 类模板、函数模板全特化、偏特化的使用

    但在某些情况下,例如需要为特定类型提供不同的实现逻辑时,函数模板特化就派上用场了。在 `TC` 类模板的示例中,`funtest()` 函数的全特化版针对 `double, double` 参数进行了定制: ```cpp template void TC, ...

    C++模板编程中只特化模板类的一个成员函数

    模板编程中如果要特化或偏特化(局部特化)一个类模板,需要特化该类模板的所有成员函数。类模板中大多数成员函数的功能可能是一模一样的,特化时我们可能只需要重新实现1、2个成员函数即可。在这种情况下,如果全部...

    函数模板完全特化 C++ Builder 示例

    在这个特化的`swap`函数中,我们直接使用了`std::string`的`swap`成员函数,这通常比拷贝字符数组更高效。 在C++ Builder环境中,你可以创建一个新项目(Project1.cbproj),并在其中添加源代码文件(如Unit1.cpp和...

    在C++泛型编程中如何只特化类的某个成员函数

    在C++泛型编程中,有时我们希望对模板类中的某个特定成员函数进行特化,而不是整个类。这是因为模板类的大部分代码可能都是通用的,只有极个别函数需要根据特定类型或条件有所不同。这种情况下,如果完全特化整个类...

    深入分析C++模板特化与偏特化

    模板特化包括函数模板特化和类模板特化。 - **函数模板特化**:例如,`Max` 函数模板可以处理各种类型的数值比较,但处理字符串时需要比较字符串内容而不是地址。通过函数模板特化,可以为`const char*`类型定义一...

    模板的 主版本模板类、全特化、偏特化

    这里 `A` 类包含两个模板参数 `T1` 和 `T2`,并且提供了一个 `function` 成员函数用于处理这两种类型的值。当我们在 `main` 函数中创建了 `A, char&gt;` 的实例时,即: ```cpp A, char&gt; a; a.function(12, 'b'); ``` ...

    C++中有关模板的试题题型练习题

    C++中有关模板的试题题型练习题是C++模板类型题型的综合应用,涵盖了函数模板、类模板的设计方法和实现。下面对标题、描述、标签和部分内容进行详细的解释和分析。 一、函数模板设计 函数模板是C++模板技术的核心...

    C++函数模板详解应用

    类模板可以包含模板成员函数,这些函数可以使用类模板的参数作为其自己的参数。 ```cpp template class MyClass { public: template void myFunction(U u) { // ... } }; ``` #### 六、模板元编程 模板元...

    模板函数和模板类的编程应用

    // 其他成员函数... private: T* data; int size; int capacity; }; ``` 这个模板类可以创建如`Vector&lt;int&gt;`或`Vector&lt;std::string&gt;`等不同类型的向量类实例。 ### 模板特化与偏特化 有时候,我们可能希望为...

    C++模板之特化与偏特化详解

    模板分为两类:类模板和函数模板。 类模板用于创建可参数化的类,其中`T`是模板参数,代表一种类型。在类模板中,`T`可以被任何类型替换,如整型、浮点型、自定义类型等。例如,下面的代码定义了一个名为`TClass`的...

    VC中一些通用类的模板

    5. **模板成员函数**:类模板中的函数也可以是模板,这称为成员函数模板。这种情况下,每个成员函数都可以有自己的类型参数。 6. **模板元编程**:VC++支持模板元编程,这是一种利用编译时计算和类型系统进行编程的...

    深入学习与实践C++模板编程 值得学习

    // 函数模板特化 template void swap(int& a, int& b) { // 特化后的交换实现 } // 类模板偏特化 template class MyClass; // 基础模板 template class MyClass&lt;int&gt; { // 特化为int的类 public: // 特化后的...

    解读C++编程中类模板的三种特化

    类模板特化是C++中提高代码复用性和灵活性的重要手段。显式特化适用于为特定类型提供完全不同的实现,而局部特化允许对部分模板参数进行特化,更灵活地处理类型组合。同时,通过成员特化,我们可以针对个别成员函数...

    程序员常见面试题(算法数据结构)

    有两种类型的模板特化:函数模板特化和类模板特化。 1. 函数模板特化:当标准模板不能满足特定类型的需求时,可以为这些类型定义特化的版本。例如,在比较字符串时,原始的`IsEqual`模板函数只能比较值,对于`char*...

    C++模板的实现

    2. **模板特化**:对于某些特定的数据类型,可以提供特化的函数模板,以优化特定类型的处理。 3. **隐式类型转换**:函数模板调用时,如果类型匹配不完全,编译器会尝试进行隐式类型转换。而普通函数则没有这个特性...

    VC++6.0模板库手册

    这在处理模板类的成员函数或模板模板参数时非常有用。偏特化可以更加精确地控制模板在特定情况下的行为。 **五、模板元编程** 模板元编程是一种在编译时进行计算的技术,利用模板的特性来生成代码。在VC++6.0中,...

Global site tag (gtag.js) - Google Analytics