UC股市2011/11/23

 

1. Chat Message过程

* 向Server发信息

CChatMainDlg::SendData()

CChatSession::SendData()

CConfSession(ISessionClient)::SendData()

CConference::SenddData()

CConfPort::SendData()                                                            // reliable or assitant connection ? 2011/12/04

CConfConnection::SendData()                                               // package 的优先级处理。2011/12/04

Server

 

* 从Server接收信息

Server

CConfConnection::OnReceiveData()

CConference::OnReceiveData()                                              // Why not CConfPort this time ?

                                                                                                        // 是否因为CConfPort提供了reliable/assistant connection选择,而receive的时候不需要? 2012/04/06

CConfSession(ISessionClient)::OnReceiveData()

CChatSession::OnReceiveData()

CChatMainDlg::OnReceiveData()

CChatMainDlg::Display Chat Message

 

CConfManage -> CConfSession-> CConference -> XXXConnection -> Server ?

 

2. step-by-step running

 

Loaded 'C:\WINDOWS\system32\wshtcpip.dll', no matching symbolic information found.
$20111123 08:59:31.031 6012/5168 ERROR: CRtAcceptorTcp::StartListen, bind() failed! addr=172.16.14.6 port=1221 err=10049:在其上下文中,该请求的地址无效。
 this=0x16baae0

A: The IP changed to 172.16.14.3

Q: Why no issue for Controller ?


Q:如何给chat module的DllMain()设置break point?

      A:这是不可能的。只有当dll加载后才能调break point,而如果dll已经被加载,则意味着DllMain()已经执行过了。


3. rtchat.dll加载过程:


STACK TRACE:

ComponentContainer::InsertObject(HWND__ * 0x00060aca, const char * 0x020a8431, IL_SESS_TYPE IL_SESSION_CHAT) line 29
CManageBase::CreateComponentBase(ILInterfaceID IL_IID_COMPONENT_CHAT, IL_SESS_TYPE IL_SESSION_CHAT, HWND__ * 0x00060aca, const CSessionKey & {...}, ISessionClient * 0x020b03a8, CInfoRosterInfo & {...}, long 0, const CInfoSID & {...}, const CInfoSID & {...}) line 165 + 56 bytes
CChatManage::CreateComponent(HWND__ * 0x00060aca, const CSessionKey & {...}, ISessionClient * 0x020b03a8, CInfoRosterInfo & {...}, long 0, const CInfoSID & {...}, const CInfoSID & {...}) line 47 + 40 bytes
CConfManage::CreateComponent(const CSessionKey & {...}, const CRtString & {0x020b10f9 ""}, ISessionClient * 0x020b03a8, const CInfoSID & {...}) line 2694 + 69 bytes
CConfManage::OnSessionCreateConfirm(int 0, const CSessionKey & {...}, const CRtString & {0x020b10f9 ""}, ISessionClient * 0x020b03a8) line 874 + 30 bytes
CConference::HandleSessionCreateIndicate(CInfoSvrSessionCreateIndicatePdu * 0x020c1d10) line 1800 + 54 bytes
CConference::OnReceiveData(CRtMessageBlock & {...}) line 1404
CConfConnection::OnReceiveData(CRtMessageBlock & {...}, IConnection * 0x020add24) line 170
CRtIMConnection::OnReceive(CRtMessageBlock & {...}, IRtTransport * 0x020ad2b0, CRtTransportParameter * 0x00000000) line 890 + 50 bytes
CRtEventOnReceive::OnEventFire() line 375 + 50 bytes
CRtEventQueueBase::ProcessOneEvent(IRtEvent * 0x020b0780) line 229 + 12 bytes
CRtEventQueueBase::ProcessEvents(const std::list<IRtEvent *,std::allocator<IRtEvent *> > & {...}) line 217
CRtReactorBase::ProcessHandleEvent(void * 0xffffffff, long 256, int 0, int 1, int 0) line 324 + 18 bytes
CRtReactorWin32Message::Win32SocketWndProc(HWND__ * 0x001007da, unsigned int 1058, unsigned int 4294967295, long 256) line 115

                                                           ^ 在这一步,肯定是因为network thread向UI Thread发送了Event,并Notify Handler 2011/12/04
USER32! 77d18734()
USER32! 77d18816()
USER32! 77d189cd()
USER32! 77d196c7()
WTL::CMessageLoop::Run() line 468 + 15 bytes
Run(char * 0x00151f28, int 1) line 207 + 11 bytes
LaunchConf(HINSTANCE__ * 0x00400000, char * 0x00151f28, int 1) line 318 + 13 bytes
WinMain(HINSTANCE__ * 0x00400000, HINSTANCE__ * 0x00000000, char * 0x00151f28, int 1) line 85 + 20 bytes
WinMainCRTStartup() line 330 + 54 bytes
KERNEL32! 7c817077()


ComponentContainer::InsertObject(..)

{

        ....
m_hModule = LoadLibrary(lpszPath);
m_pfnNewInstance = (ILNewInstanceProc)GetProcAddress(m_hModule, "ILNewInstance");
        m_pfnDeleteInstance = (ILDeleteInstanceProc)GetProcAddress(m_hModule, "ILDeleteInstance");
m_pfnGetComponentBase = (ILGetComponentBaseProc)GetProcAddress(m_hModule, "ILGetComponentBase");
        ......
m_hComponent = m_pfnNewInstance(hWndParent, sessType);
       return TRUE;
}

注:在SessionCreateRequest的响应中,创建Chat Component,并将Session与其绑定?


4. conference/session/component 创建过程

CMainFrame::OnCreate()->

CConfManage::CreateConference() -> CConfManage::JoinConference()

CConference::HandleJoinConfRspn()-> Enroll Conf Request -> 

CConference::HandleEnrollConfResp() ->

CConfManage::OnConferenceJoinConfirm() -> 

CConfManaage::CreateAllSessions() -> 

CConference::CreateSession() ->

......

CConference::OnReceiveData() -> CConference::HandleSessionCreateIndicate() -> OnSessionCreateConfirm() ->

CConfManage::CreateComponent() -> 

component dll loaded. 




内容概要:本文围绕《【卫星信号】模拟卫星信号传播研究(Matlab代码实现)》这一技术资源展开,系统介绍了利用Matlab进行卫星信号传播过程建模与仿真的方法。该资源聚焦于构建卫星信号在复杂空间环境中的传播模型,综合考虑自由空间路径损耗、大气吸收、多径效应、多普勒频移、电离层闪烁及噪声干扰等多种物理因素,通过Matlab编程实现信号传输特性的动态仿真与可视化分析,帮助研究人员深入掌握卫星通信信道的关键特性与建模流程。; 适合人群:具备Matlab编程能力和通信原理基础知识的高校研究生、科研机构研究人员及从事卫星通信、导航定位、遥感遥测等领域的工程技术人员,特别适用于需要完成相关课题仿真、毕业设计或项目开发的初级与中级科研人员。; 使用场景及目标:①用于教学与课程设计中加深对卫星信号传播机制的理解;②支撑卫星通信系统链路预算、接收机灵敏度分析与抗干扰算法设计;③服务于学术论文撰写、科研项目申报中的仿真验证环节,提供可复用的代码框架与建模思路。; 阅读建议:建议读者结合经典通信理论教材同步学习,重点剖析代码中关于信号调制、信道建模、噪声叠加与接收端解调等模块的实现逻辑,动手运行并调整轨道参数、频率、环境条件等变量,观察信号质量变化,从而深化对卫星信道动态行为的认知。
内容概要:本文系统介绍了2024年最新提出的两种智能优化算法——青蒿素优化算法与霜冰优化算法(RIME),并通过Matlab代码实现对二者进行了深入对比研究。文档不仅阐述了两种算法的核心原理与数学模型,还全面展示了其在电力系统优化、新能源调度、路径规划、机器学习参数调优等复杂工程问题中的应用性能差异。文中涵盖了微电网调度、电动汽车充电优化、无人机三维路径规划、风光互补制氢系统调度等多个前沿科研方向的典型案例,并配套提供了完整的Matlab仿真代码与模型资源,便于读者复现高水平学术论文成果并开展创新性研究。; 适合人群:具备一定编程基础,熟练掌握Matlab/Simulink环境,正在从事智能优化算法相关研究的研究生、高校教师及工程技术人员,尤其适用于专注于能源系统优化、智能交通、智能制造、自动化控制等领域的科研工作者。; 使用场景及目标:①深入理解青蒿素算法与RIME算法的基本思想、迭代机制与收敛特性;②通过实际代码复现EI、顶刊级别论文中的优化模型;③在具体科研项目中对比两类算法的寻优能力、稳定性与计算效率,完成算法选型与改进;④拓展新型优化算法在多能互补系统、智能路径规划、分布式调度等交叉学科中的创新应用。; 阅读建议:建议读者结合网盘提供的完整代码资源,按照文档中给出的应用实例循序渐进地实践操作,重点关注不同场景下的参数设置策略、算法收敛曲线分析与鲁棒性表现,同时关注公众号“荔枝科研社”获取持续的技术支持与更新资料。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值