2、向主程序线程可以通过PostThreamdMessage() API来发送消息。
API中的WPARAM/ LPARAM 参数基本上可以通过强转成任意类型的指针,具体应用就看你的需求了。 但是在发送/响应消息需要注意几点:
1、需要等待消息返回结果的话,需要用SendMessage() API,不能采用PostMessage() API。
2、如果动态库不需要等待返回结果,只是发送简单类型数据(比如int /char)等,可以直接PostMessage() API发送。 对于复杂类型,比如结构之类的,可以将结构地址指针强转成LPARAM参数类型进行发送,但是需要注意: 如果是结构变量在栈上,你不能采用PostMessage() 来发送, 因为PostMessage() 是异步发送的, 当主程序接收到消息时,可能结构的内存已经在栈上释放或覆盖,导致接收的数据为垃圾数据。可以通过SendMessage()/ReplyMessage()组合完成。
3、当动态库发送的结构/指针在堆上, 且由动态库中new/malloc的分配的内存, 需要在主程序释放时, 要注意动态库编译类型如果是采用/MT编译的,则需要动态库来释放,或由动态库导出释放内存接口供主程序显式调用释放,不然会产生跨模块释放内存的问题,很容易产生一些莫名其妙的崩溃。
revKey[i] = fgetc(fp) ^ recvBuffer[i]//将接收到的加密文件与mac.txt文件中的密钥进行异或解密这里 你没有判断revKey的长度是否小于i的值,可能造成了内存溢出引起了
添加一句 if(i >= revKey.length()) break试试看有没有错误
以下的程序测试过了,可以满足你的要求了。#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main()
{
//输出HTTP头
printf("Content-type: text/plain\n\n")
//从CONTENT_LENGTH环境变量中取出其值
int n = atoi(getenv("CONTENT_LENGTH"))
printf("%d\n", n)
char buf[20]
memset(buf, 0, sizeof(buf))
//从stdin标准输入流中读取数据
fgets(buf, n, stdin)
//输出
printf("Hi, this is CGI with c\n")
printf("%s\n", buf)
return 0
}
大致流程你都懂,就是有些细节不清楚吧。从stdin读取数据时,首先要知道读多长的数据,而这个长度保存在“CONTENT_LENGTH‘整个环境变量中。另外从stdin读取数据要用fgets函数,scanf不是用在网络通信中读取数据用的。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)