mirror of
https://github.com/ossrs/srs.git
synced 2025-03-09 15:49:59 +00:00
performance refine, support 3k+ connections(270kbps). 0.9.130
This commit is contained in:
parent
e9c96af91a
commit
1ae3e6c64c
18 changed files with 230 additions and 162 deletions
|
@ -31,7 +31,7 @@ CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|||
// current release version
|
||||
#define VERSION_MAJOR "0"
|
||||
#define VERSION_MINOR "9"
|
||||
#define VERSION_REVISION "129"
|
||||
#define VERSION_REVISION "130"
|
||||
#define RTMP_SIG_SRS_VERSION VERSION_MAJOR"."VERSION_MINOR"."VERSION_REVISION
|
||||
// server info.
|
||||
#define RTMP_SIG_SRS_KEY "SRS"
|
||||
|
|
|
@ -66,53 +66,4 @@ public:
|
|||
}
|
||||
};
|
||||
|
||||
/**
|
||||
* auto free the array ptrs, for example, MyClass* msgs[10],
|
||||
* which stores 10 MyClass* objects, this class will:
|
||||
* 1. free each MyClass* in array.
|
||||
* 2. free the msgs itself.
|
||||
* 3. set msgs to NULL.
|
||||
* @remark, MyClass* msgs[] equals to MyClass**, the ptr array equals ptr to ptr.
|
||||
* Usage:
|
||||
* MyClass* msgs[10];
|
||||
* // ...... use msgs.
|
||||
* SrsAutoFreeArray(MyClass, msgs, 10);
|
||||
*/
|
||||
#define SrsAutoFreeArray(className, instance, size) \
|
||||
__SrsAutoFreeArray<className> _auto_free_array_##instance(&instance, size)
|
||||
template<class T>
|
||||
class __SrsAutoFreeArray
|
||||
{
|
||||
private:
|
||||
T*** ptr;
|
||||
int size;
|
||||
public:
|
||||
/**
|
||||
* auto delete the ptr array.
|
||||
*/
|
||||
__SrsAutoFreeArray(T*** _ptr, int _size) {
|
||||
ptr = _ptr;
|
||||
size = _size;
|
||||
}
|
||||
|
||||
virtual ~__SrsAutoFreeArray() {
|
||||
if (ptr == NULL || *ptr == NULL) {
|
||||
return;
|
||||
}
|
||||
|
||||
T** arr = *ptr;
|
||||
for (int i = 0; i < size; i++) {
|
||||
T* pobj = arr[i];
|
||||
if (pobj) {
|
||||
delete pobj;
|
||||
arr[i] = NULL;
|
||||
}
|
||||
}
|
||||
|
||||
delete arr;
|
||||
|
||||
*ptr = NULL;
|
||||
}
|
||||
};
|
||||
|
||||
#endif
|
Loading…
Add table
Add a link
Reference in a new issue