⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 memblock.cc

📁 A C++ class library for scientific computing
💻 CC
字号:
/* * Copyright (C) 1997 Todd Veldhuizen <tveldhui@oonumerics.org> * All rights reserved.  Please see <blitz/blitz.h> for terms and * conditions of use. * */#ifndef BZ_MEMBLOCK_CC#define BZ_MEMBLOCK_CC#include <blitz/numtrait.h>BZ_NAMESPACE(blitz)// Null memory block for each (template) instantiation of MemoryBlockReferencetemplate<typename P_type> NullMemoryBlock<P_type> MemoryBlockReference<P_type>::nullBlock_;template<typename P_type>void MemoryBlock<P_type>::deallocate(){#ifndef BZ_ALIGN_BLOCKS_ON_CACHELINE_BOUNDARY    delete [] dataBlockAddress_;#else    if (!NumericTypeTraits<T_type>::hasTrivialCtor) {        for (int i=0; i < length_; ++i)            data_[i].~T_type();        delete [] reinterpret_cast<char*>(dataBlockAddress_);    }    else {        delete [] dataBlockAddress_;    }#endif}template<typename P_type>inline void MemoryBlock<P_type>::allocate(size_t length){    TAU_TYPE_STRING(p1, "MemoryBlock<T>::allocate() [T="        + CT(P_type) + "]");    TAU_PROFILE(p1, "void ()", TAU_BLITZ);#ifndef BZ_ALIGN_BLOCKS_ON_CACHELINE_BOUNDARY    dataBlockAddress_ = new T_type[length];    data_ = dataBlockAddress_;#else    size_t numBytes = length * sizeof(T_type);    if (numBytes < 1024)    {        dataBlockAddress_ = new T_type[length];        data_ = dataBlockAddress_;    }    else    {        // We're allocating a large array.  For performance reasons,        // it's advantageous to force the array to start on a        // cache line boundary.  We do this by allocating a little        // more memory than necessary, then shifting the pointer        // to the next cache line boundary.        // Patches by Petter Urkedal to support types with nontrivial        // constructors.        const int cacheBlockSize = 128;    // Will work for 32, 16 also        dataBlockAddress_ = reinterpret_cast<T_type*>            (new char[numBytes + cacheBlockSize - 1]);        // Shift to the next cache line boundary        ptrdiff_t offset = ptrdiff_t(dataBlockAddress_) % cacheBlockSize;        ptrdiff_t shift = (offset == 0) ? 0 : (cacheBlockSize - offset);        data_ = reinterpret_cast<T_type*>                (reinterpret_cast<char*>(dataBlockAddress_) + shift);        // Use placement new to construct types with nontrival ctors        if (!NumericTypeTraits<T_type>::hasTrivialCtor) {            for (int i=0; i < length; ++i)                new(&data_[i]) T_type;        }    }#endif}BZ_NAMESPACE_END#endif // BZ_MEMBLOCK_CC

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -