对于跨平台开发,我不确定需要什么来使Delphi代码跨平台使用PostMessage和SendMessage调用进行进程内和进程间通信,因为关于Delphi的新运行库的信息很少。
在web上有相当多的Delphi代码示例,它们使用Windows消息队列来执行编程任务(例如,在线程通信方面),这对于跨平台开发人员来说可能变得无用。
没有仿真层将旧的特定于操作的消息发送代码映射到跨平台解决方案的可能性有多大?应用程序开发人员是否应该现在就开始审查现有代码,并使用更适合跨平台操作的新消息传递实现?
发布于 2011-03-30 00:14:57
PostMessage和SendMessage是特定于Windows的-它们是Windows API的一部分。如果你的程序使用了它们,那么它就不是跨平台的。您可能应该重写使用这些函数的代码。
发布于 2011-03-30 02:32:30
其他操作系统可能根本没有消息队列。必须隔离或删除特定于Windows的代码才能构建跨平台应用程序。他们为Kylix编写CLX库的原因之一是VCL是如此受Windows的限制,以至于不能轻易地转换为跨平台的libray。
发布于 2011-03-30 04:02:14
我怀疑您可以实现自己的Queue对象,该对象可以以特定于平台的方式实现。在Win32中,它可以包装底层Win32窗口句柄,而在其他一些平台中,可能会消耗一些其他资源。
如果你现在就开始,通过减少你的平台特定的代码,到封装你所需要的功能的特定单元,会怎么样呢?这意味着您需要避免使用PostMessage/SendMessage作为直接使用的机制。
首先,假设PostMessage和SendMessage不存在,您需要一种创建队列的方法。例如,您可以使用套接字或命名管道,它们存在于大多数平台上。你需要多写一点代码,才能做到这一点。
在QT库上,它们提供了自己的功能来帮助应用程序作者重写他们的C++应用程序,以使用他们的函数而不是Win32函数,所以您也可以尝试这种方法。QT函数postEvent就是一个这样的例子。QT还提供了信号和槽,这是在他们的框架中进行通知的更常用的方式。
也许,在跨平台Delphi推出的任何新框架中处理通知的方式都可能包含一种全新的方式。这是我的希望。
https://stackoverflow.com/questions/5475581
复制相似问题