MainThread

JavaShareClient
1.队列:
里面有一个队列static SkDeque gFuncPtrQ(sizeof(FuncPtrRec));
这个队列里面的类型是
    struct FuncPtrRec {
        void (*fProc)(void* payload);
        void* fPayload;
    };
2.入队函数
void JavaSharedClient::EnqueueFunctionPtr(void (*proc)(void* payload),
                                              void* payload)
向队列放入成员
调用这个函数的地方有如下几处:
a.static void anp_postEvent(NPP instance, const ANPEvent* event)
b.void EnqueueFunctionPtrAndroid(void (*proc)(void*), void* payload)//MainThreadAndroid调用
c.void AndroidThreading::scheduleDispatchFunctionsOnMainThread()//MainThreadAndroid调用,support同2
d.WebIconDatabase::didImportIconURLForPageURL

a.anp_postEvent->JavaSharedClient::EnqueueFunctionPtr
b.WebIconDatabase::didImportIconURLForPageURL->JavaSharedClient::EnqueueFunctionPtr
c.MainThread.cpp->scheduleDispatchFunctionsOnMainThread->EnqueueFunctionPtrAndroid->JavaSharedClient::EnqueueFunctionPtr
MainThread.cpp->AndroidThreading::scheduleDispatchFunctionsOnMainThread()->JavaSharedClient::EnqueueFunctionPtr
2.1
dispatchFunctionsFromMainThread
callOnMainThread
callOnMainThreadAndWait
setMainThreadCallbacksPaused


3. 调度函数
void JavaSharedClient::ServiceFunctionPtrQueue()
取出元素进行处理。
这个函数在void JavaBridge::ServiceFuncPtrQueue(JNIEnv*)调用,就是java的
所以nativeServiceFuncPtrQueue->JavaBridge::ServiceFuncPtrQueue->
JavaSharedClient::ServiceFunctionPtrQueue()->JavaSharedClient::ServiceFunctionPtrQueue()
3.1 调度函数入口
JavaSharedClient::EnqueueFunctionPtr
void JavaBridge::ServiceFuncPtrQueue
env->CallVoidMethod(mJavaObject, mSignalFuncPtrQueue);
JWebCoreJavaBridge.signalServiceFuncPtrQueue
所以每添加一个就会调度一次。




4.其他
scheduleDispatchFunctionsOnMainThread()
{EnqueueFunctionPtrAndroid(timeoutFired, 0);}
会把某些函数让主线程调用,传入函数指针。
但是这里却传入了另一个消息队列处理函数,相当于一种级联吧,功能有扩充,还没细看。


既然有消息处理,那肯定有放入队列的地方。
就是上面的callOnMainThread和callOnMainThreadAndWait


5.总结
所以要在主线程执行有如下几种办法
JavaSharedClient::EnqueueFunctionPtr。
callOnMainThread和callOnMainThreadAndWait

当然后两种调用的是第一个的函数。



6.主线程的初始化
有webcore线程调过来,调用到
Webkit InitializeThreading.cpp中的initializeThreading。
会将主线程id设置为当前线程。

### 回答1: 这个问题可以通过将主线程加入主循环来解决。可以使用事件循环机制来实现,例如使用 asyncio 库中的 run_until_complete() 函数。另外,也可以使用 Qt 框架中的 QEventLoop 类来实现。具体的实现方法需要根据具体的代码情况来确定。 ### 回答2: "main thread is not in main loop" 是一个错误消息,通常在编程中使用多线程或多进程的情况下出现。它表示主线程没有在主循环中运行,可能是由于一些错误或逻辑问题造成的。 要解决这个问题,我们可以采取以下步骤: 1. 检查代码逻辑:首先,确保代码中没有错误。检查是否有意外的跳出主循环的语句或逻辑错误。请确认程序流程是否正确,且没有意外的退出或退出循环的情况。 2. 确保主线程在主循环中运行:确认主线程是在主循环中运行的。主循环是一个应用程序的核心部分,负责处理用户输入,事件和其他任务。确保代码中没有在主线程外执行的操作。 3. 使用正确的多线程或多进程机制:如果需要使用多线程或多进程,确保使用正确的机制。例如,在Python中,可以使用threading和multiprocessing模块来实现这些功能。确保将主线程放在主循环中运行,并正确管理其他线程或进程。 4. 使用同步机制:如果涉及共享数据或同时访问关键资源的情况,确保使用适当的同步机制。例如,使用锁或线程安全的数据结构来避免竞争条件和数据不一致问题。 5. 参考文档和示例代码:如果以上方法仍然无法解决问题,建议参考相关文档和示例代码。对于特定语言和框架,通常会有详细的说明和示例,可以帮助理解并解决此问题。 最后,解决"main thread is not in main loop"问题需要仔细分析代码,确保所有的线程和进程都正确地在主循环中运行,并且使用适当的同步机制来保证程序的正确性。 ### 回答3: 解决 "main thread is not in main loop" 的问题的方法取决于出现此错误的具体情况。一般来说,这个错误意味着主线程(main thread)没有在主循环(main loop)中。以下是几种可能的解决方法: 1. 检查代码:仔细检查代码,确保所有与主线程有关的操作都在主循环中执行。主线程通常用于处理用户交互和应用程序逻辑,而主循环负责处理事件和更新UI。如果有操作没有放在主循环中,可以将其移动到适当的位置。 2. 使用合适的线程:如果有其他线程在执行操作,确保它们不会影响主线程的运行。可以使用线程同步机制,如锁或条件变量,来协调不同线程之间的操作,以确保主线程的正常运行。 3. 检查库或框架:如果错误是在使用某个库或框架时出现的,建议查阅相关文档或寻求社区支持。库或框架的作者通常会提供解决此类错误的具体建议或修复方法。 4. 更新软件版本:如果错误是由软件版本不兼容或存在已知错误导致的,可以尝试更新软件版本。这样可以获得已修复的错误和改进的功能,从而解决问题。 5. 寻求专业帮助:如果无法解决问题,建议联系相关领域的专业人员寻求帮助。他们可能会针对具体情况提供更具体的解决方法。 值得注意的是,由于缺乏具体的背景信息,这些解决方法可能并不适用于所有情况。因此,理解问题的具体背景和原因是解决问题的关键。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值