<div dir="ltr">我把gst_init/gst_deinit移到了动态库的外部,也就是进程仅做一次gst_init/gst_deinit.<div>然后出现创想GstAudioClock的时候失败:</div><div>(cowplayer_test:5466): GLib-GObject-WARNING **: cannot register existing type 'GstAudioClock'<br>(cowplayer_test:5466): GLib-CRITICAL **: g_once_init_leave: assertion 'result != 0' failed<br>(cowplayer_test:5466): GLib-GObject-CRITICAL **: g_object_new: assertion 'G_TYPE_IS_OBJECT (object_type)' failed<br></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">Halley Zhao <<a href="mailto:aihua.halley.zhao@gmail.com">aihua.halley.zhao@gmail.com</a>> 于2019年6月20日周四 下午6:05写道:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr">Hi experts:<div>I created a dynamic lib to use gst, and the lib is loaded by dlopen.</div><div>then there is exception to load the lib for a second playback.</div><div><br></div><div>1. if I call gst_deinit() before dlclose the lib. I fail to create any gst element next time after calling gst_init() again.  gst_init_check() said gst has already been inited.</div><div><br></div><div>0:00:08.140795000  5131 0xffff98003e90 DEBUG               GST_INIT gst.c:417:gst_init_check: already initialized gst<br>0:00:08.140939875  5131 0xffff98003e90 WARN     GST_ELEMENT_FACTORY gstelementfactory.c:456:gst_element_factory_make: no such element factory "appsrc"!<br></div><div><br></div><div>2. if I skip call gst_deinit() before dlclose the lib, some exception comes for g_type_check</div><div>(gdb) bt<br>#0  0x0000ffffbeb67dd8 in strcmp () from /usr/lib64/libc.so.6<br>#1  0x0000ffffbf16ba5c in g_str_equal () from /usr/lib64/<a href="http://libglib-2.0.so" target="_blank">libglib-2.0.so</a><br>#2  0x0000ffffbf16af08 in g_hash_table_lookup ()<br>   from /usr/lib64/<a href="http://libglib-2.0.so" target="_blank">libglib-2.0.so</a><br>#3  0x0000ffffbf18d648 in g_intern_static_string ()<br>   from /usr/lib64/<a href="http://libglib-2.0.so" target="_blank">libglib-2.0.so</a><br>#4  0x0000ffffb70548dc in gst_audio_clock_get_type ()<br>   from /usr/lib64/libgstaudio-1.0.so.0<br>#5  0x0000ffffb705494c in gst_audio_clock_new ()<br>   from /usr/lib64/libgstaudio-1.0.so.0<br></div></div>
</blockquote></div>