📄 float.h
字号:
// file: $isip/class/math/scalar/Float/Float.h// version: $Id: Float.h,v 1.31 2001/10/14 04:25:55 bahety Exp $//// make sure definitions are only made once//#ifndef ISIP_FLOAT#define ISIP_FLOAT// isip include files//#ifndef ISIP_SCALAR#include <MScalar.h>#endif// Float: a class that manages a 32-bit float. this class mainly// inherits the MScalar template functionality. we only need to add Sof file// support and memory management//class Float : public MScalar<float, float32> { //--------------------------------------------------------------------------- // // public constants // //---------------------------------------------------------------------------public: // define the class name // static const String CLASS_NAME; //---------------------------------------- // // other important constants // //---------------------------------------- //---------------------------------------- // // default values and arguments // //---------------------------------------- // define the default value(s) of the class data // // default arguments to methods // //---------------------------------------- // // error codes // //---------------------------------------- static const long ERR = 21000; //--------------------------------------------------------------------------- // // protected data // //---------------------------------------------------------------------------protected: // static memory manager // static MemoryManager mgr_d; //--------------------------------------------------------------------------- // // required public methods // //---------------------------------------------------------------------------public: // method: name // static const String& name() { return CLASS_NAME; } // other static methods // static boolean diagnose(Integral::DEBUG debug_level); // debug methods: // the setDebug method is inherited from the MScalar template class // boolean debug(const unichar* message) const; // method: destructor // ~Float() {} // method: default constructor // Float(float arg = DEF_VALUE) { value_d = arg; } // method: copy constructor // Float(const Float& arg) { assign(arg.value_d); } // assign methods: // these methods are inherited from the MScalar template class // // method: operator= // Float& operator= (const Float& arg) { assign(arg); return *this; } // i/o methods: // sofSize, readData and writeData are inherited from the MScalar // template class // // method: read // boolean read(Sof& sof, long tag, const String& name = CLASS_NAME) { return MScalar<float, float32>::read(sof, tag, name); } // method: write // boolean write(Sof& sof, long tag, const String& name = CLASS_NAME) const { return MScalar<float, float32>::write(sof, tag, name); } // equality methods: // the eq method is inherited from the MScalar template class // // method: new // static void* operator new(size_t size) { return mgr_d.get(); } // method: new[] // static void* operator new[](size_t size) { return mgr_d.getBlock(size); } // method: delete // static void operator delete(void* ptr) { mgr_d.release(ptr); } // method: delete[] // static void operator delete[](void* ptr) { mgr_d.releaseBlock(ptr); } // method: setGrowSize // static boolean setGrowSize(long grow_size) { return mgr_d.setGrow(grow_size); } // other memory management methods: // these methods are inherited from the MScalar template class // //----------------------------------------------------------------------- // // class-specific public methods // //----------------------------------------------------------------------- // method: operator= // Float& operator= (float arg) { value_d = arg; return *this; } //--------------------------------------------------------------------------- // // private methods // //---------------------------------------------------------------------------private: // declare bitwise methods as private member functions because they // are not defined for floating point operations // float bor(float, float); float band(float, float); float bxor(float, float); float brs(float, float); float bls(float, float); float bcmpl(float); // declare modulus methods as private member functions because they // are not defined for floating point operations // float mod(float, float); float& operator%= (float); float operator% (float);};// end of include file//#endif
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -