mirror of
https://github.com/ossrs/srs.git
synced 2025-03-09 15:49:59 +00:00
refine the ptr array free, 0.9.96
This commit is contained in:
parent
dc66c525fd
commit
3ebda13802
5 changed files with 58 additions and 49 deletions
|
@ -474,6 +474,7 @@ int SrsEdgeForwarder::cycle()
|
||||||
srs_verbose("no packets to forward.");
|
srs_verbose("no packets to forward.");
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
SrsAutoFreeArray(SrsSharedPtrMessage, msgs, count);
|
||||||
|
|
||||||
// all msgs to forward to origin.
|
// all msgs to forward to origin.
|
||||||
// @remark, becareful, all msgs must be free explicitly,
|
// @remark, becareful, all msgs must be free explicitly,
|
||||||
|
@ -484,23 +485,11 @@ int SrsEdgeForwarder::cycle()
|
||||||
srs_assert(msg);
|
srs_assert(msg);
|
||||||
msgs[i] = NULL;
|
msgs[i] = NULL;
|
||||||
|
|
||||||
// never use free msgs array, for it will memory leak.
|
|
||||||
// if error, directly free msgs.
|
|
||||||
if (ret != ERROR_SUCCESS) {
|
|
||||||
srs_freep(msg);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ((ret = client->send_and_free_message(msg)) != ERROR_SUCCESS) {
|
if ((ret = client->send_and_free_message(msg)) != ERROR_SUCCESS) {
|
||||||
srs_error("edge publish forwarder send message to server failed. ret=%d", ret);
|
srs_error("edge publish forwarder send message to server failed. ret=%d", ret);
|
||||||
continue;
|
return ret;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// free the array itself.
|
|
||||||
srs_freep(msgs);
|
|
||||||
if (ret != ERROR_SUCCESS) {
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
|
|
|
@ -352,6 +352,7 @@ int SrsForwarder::forward()
|
||||||
srs_verbose("no packets to forward.");
|
srs_verbose("no packets to forward.");
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
SrsAutoFreeArray(SrsSharedPtrMessage, msgs, count);
|
||||||
|
|
||||||
// all msgs to forward.
|
// all msgs to forward.
|
||||||
// @remark, becareful, all msgs must be free explicitly,
|
// @remark, becareful, all msgs must be free explicitly,
|
||||||
|
@ -362,23 +363,11 @@ int SrsForwarder::forward()
|
||||||
srs_assert(msg);
|
srs_assert(msg);
|
||||||
msgs[i] = NULL;
|
msgs[i] = NULL;
|
||||||
|
|
||||||
// never use free msgs array, for it will memory leak.
|
|
||||||
// if error, directly free msgs.
|
|
||||||
if (ret != ERROR_SUCCESS) {
|
|
||||||
srs_freep(msg);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ((ret = client->send_and_free_message(msg)) != ERROR_SUCCESS) {
|
if ((ret = client->send_and_free_message(msg)) != ERROR_SUCCESS) {
|
||||||
srs_error("forwarder send message to server failed. ret=%d", ret);
|
srs_error("forwarder send message to server failed. ret=%d", ret);
|
||||||
continue;
|
return ret;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// free the array itself.
|
|
||||||
srs_freep(msgs);
|
|
||||||
if (ret != ERROR_SUCCESS) {
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
|
|
|
@ -513,6 +513,7 @@ int SrsRtmpConn::playing(SrsSource* source)
|
||||||
srs_verbose("no packets in queue.");
|
srs_verbose("no packets in queue.");
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
SrsAutoFreeArray(SrsSharedPtrMessage, msgs, count);
|
||||||
|
|
||||||
// sendout messages
|
// sendout messages
|
||||||
// @remark, becareful, all msgs must be free explicitly,
|
// @remark, becareful, all msgs must be free explicitly,
|
||||||
|
@ -526,13 +527,6 @@ int SrsRtmpConn::playing(SrsSource* source)
|
||||||
|
|
||||||
srs_assert(msg);
|
srs_assert(msg);
|
||||||
|
|
||||||
// never use free msgs array, for it will memory leak.
|
|
||||||
// if error, directly free msgs.
|
|
||||||
if (ret != ERROR_SUCCESS) {
|
|
||||||
srs_freep(msg);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
// foreach msg, collect the duration.
|
// foreach msg, collect the duration.
|
||||||
// @remark: never use msg when sent it, for the protocol sdk will free it.
|
// @remark: never use msg when sent it, for the protocol sdk will free it.
|
||||||
if (starttime < 0 || starttime > msg->header.timestamp) {
|
if (starttime < 0 || starttime > msg->header.timestamp) {
|
||||||
|
@ -543,14 +537,9 @@ int SrsRtmpConn::playing(SrsSource* source)
|
||||||
|
|
||||||
if ((ret = rtmp->send_and_free_message(msg)) != ERROR_SUCCESS) {
|
if ((ret = rtmp->send_and_free_message(msg)) != ERROR_SUCCESS) {
|
||||||
srs_error("send message to client failed. ret=%d", ret);
|
srs_error("send message to client failed. ret=%d", ret);
|
||||||
continue;
|
return ret;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// free the array itself.
|
|
||||||
srs_freep(msgs);
|
|
||||||
if (ret != ERROR_SUCCESS) {
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
// if duration specified, and exceed it, stop play live.
|
// if duration specified, and exceed it, stop play live.
|
||||||
// @see: https://github.com/winlinvip/simple-rtmp-server/issues/45
|
// @see: https://github.com/winlinvip/simple-rtmp-server/issues/45
|
||||||
|
|
|
@ -31,7 +31,7 @@ CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
// current release version
|
// current release version
|
||||||
#define VERSION_MAJOR "0"
|
#define VERSION_MAJOR "0"
|
||||||
#define VERSION_MINOR "9"
|
#define VERSION_MINOR "9"
|
||||||
#define VERSION_REVISION "95"
|
#define VERSION_REVISION "96"
|
||||||
#define RTMP_SIG_SRS_VERSION VERSION_MAJOR"."VERSION_MINOR"."VERSION_REVISION
|
#define RTMP_SIG_SRS_VERSION VERSION_MAJOR"."VERSION_MINOR"."VERSION_REVISION
|
||||||
// server info.
|
// server info.
|
||||||
#define RTMP_SIG_SRS_KEY "srs"
|
#define RTMP_SIG_SRS_KEY "srs"
|
||||||
|
|
|
@ -31,11 +31,17 @@ CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
#include <srs_core.hpp>
|
#include <srs_core.hpp>
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* auto free the instance in the current scope.
|
* auto free the instance in the current scope, for instance, MyClass* ptr,
|
||||||
|
* which is a ptr and this class will:
|
||||||
|
* 1. free the ptr.
|
||||||
|
* 2. set ptr to NULL.
|
||||||
|
* Usage:
|
||||||
|
* MyClass* po = new MyClass();
|
||||||
|
* // ...... use po
|
||||||
|
* SrsAutoFree(MyClass, po);
|
||||||
*/
|
*/
|
||||||
#define SrsAutoFree(className, instance) \
|
#define SrsAutoFree(className, instance) \
|
||||||
__SrsAutoFree<className> _auto_free_##instance((className**)&instance)
|
__SrsAutoFree<className> _auto_free_##instance(&instance)
|
||||||
|
|
||||||
template<class T>
|
template<class T>
|
||||||
class __SrsAutoFree
|
class __SrsAutoFree
|
||||||
{
|
{
|
||||||
|
@ -44,13 +50,12 @@ private:
|
||||||
public:
|
public:
|
||||||
/**
|
/**
|
||||||
* auto delete the ptr.
|
* auto delete the ptr.
|
||||||
* @is_array a bool value indicates whether the ptr is a array.
|
|
||||||
*/
|
*/
|
||||||
__SrsAutoFree(T** _ptr){
|
__SrsAutoFree(T** _ptr) {
|
||||||
ptr = _ptr;
|
ptr = _ptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual ~__SrsAutoFree(){
|
virtual ~__SrsAutoFree() {
|
||||||
if (ptr == NULL || *ptr == NULL) {
|
if (ptr == NULL || *ptr == NULL) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -64,13 +69,50 @@ public:
|
||||||
/**
|
/**
|
||||||
* auto free the array ptrs, for example, MyClass* msgs[10],
|
* auto free the array ptrs, for example, MyClass* msgs[10],
|
||||||
* which stores 10 MyClass* objects, this class will:
|
* which stores 10 MyClass* objects, this class will:
|
||||||
* 1. free each MyClass* in array.
|
* 1. free each MyClass* in array.
|
||||||
* 2. free the msgs itself.
|
* 2. free the msgs itself.
|
||||||
|
* 3. set msgs to NULL.
|
||||||
* @remark, MyClass* msgs[] equals to MyClass**, the ptr array equals ptr to ptr.
|
* @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>
|
template<class T>
|
||||||
class SrsObjectPtrArrayAutoFree
|
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
|
#endif
|
Loading…
Add table
Add a link
Reference in a new issue