���� JFIF �� � ( %"1"%)+...383,7(-.-
![]() Server : Apache/2.4.6 (CentOS) OpenSSL/1.0.2k-fips PHP/7.4.20 System : Linux st2.domain.com 3.10.0-1127.10.1.el7.x86_64 #1 SMP Wed Jun 3 14:28:03 UTC 2020 x86_64 User : apache ( 48) PHP Version : 7.4.20 Disable Function : NONE Directory : /home/real/node-v13.0.1/test/addons/worker-addon/ |
#include <assert.h> #include <node.h> #include <stdio.h> #include <stdlib.h> #include <v8.h> #include <uv.h> using v8::Context; using v8::HandleScope; using v8::Isolate; using v8::Local; using v8::Object; using v8::Value; size_t count = 0; struct statically_allocated { statically_allocated() { assert(count == 0); printf("ctor "); } ~statically_allocated() { assert(count == 0); printf("dtor "); } } var; void Dummy(void*) { assert(0); } void Cleanup(void* str) { printf("%s ", static_cast<const char*>(str)); } void Initialize(Local<Object> exports, Local<Value> module, Local<Context> context) { node::AddEnvironmentCleanupHook( context->GetIsolate(), Cleanup, const_cast<void*>(static_cast<const void*>("cleanup"))); node::AddEnvironmentCleanupHook(context->GetIsolate(), Dummy, nullptr); node::RemoveEnvironmentCleanupHook(context->GetIsolate(), Dummy, nullptr); if (getenv("addExtraItemToEventLoop") != nullptr) { // Add an item to the event loop that we do not clean up in order to make // sure that for the main thread, this addon's memory persists even after // the Environment instance has been destroyed. static uv_async_t extra_async; uv_loop_t* loop = node::GetCurrentEventLoop(context->GetIsolate()); int err = uv_async_init(loop, &extra_async, [](uv_async_t*) {}); assert(err == 0); uv_unref(reinterpret_cast<uv_handle_t*>(&extra_async)); } } NODE_MODULE_CONTEXT_AWARE(NODE_GYP_MODULE_NAME, Initialize)