- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个使用 UDP 数据报将数组数据发送到服务器的客户端。为了能够跟踪我发送的数据,我用数字填充了我的数组。例如; 在客户端代码中我填buf[7] = 7;
这个索引是为了表示分片总数。我希望在服务器中也能看到相同的。
但是,我的 buf
in server 没有得到这些值。我必须在服务器中使用固定大小的字符数组 我无法更改它。 (我对数据进行了长时间的计算,因为与问题无关,所以没有放)
我要解释一下服务器结构:
buf
已满且其数据仍在文件中,则应使用 buf2
等等。这是为了优化目的。我怀疑线程,当我评论它时,接收功能卡住了。我怀疑类型的数组,因为我发送了 char 指针数组但收到了固定大小的 char 数组。 (同样,我必须在接收时使用固定大小)
All I want is to see the data correctly transferred. When I look at server I want to see the same data at same indexes.
Here is my simple client code
void main(int argc, char* argv[]){
WSADATA data;
WORD version = MAKEWORD(2, 2);
int wsOk = WSAStartup(version, &data);
if (wsOk != 0)
{
cout << "Can't start Winsock! " << wsOk;
return;
}
sockaddr_in server;
server.sin_family = AF_INET; // AF_INET = IPv4 addresses
server.sin_port = htons(...port no...); // Little to big endian conversion
inet_pton(AF_INET, "...IP....", &server.sin_addr); // Convert from string to byte array
SOCKET out = socket(AF_INET, SOCK_DGRAM, 0);
int sendOk = 0;
int *buf = new int[1450];
//just fill it with ordered number to be able to trace from other side
for (int i = 0; i < 1450; i++)
{
buf[i] = i;
}
buf[7] = 7; // this index represent TotalFragmentCount in UDP
while (true) {
for (int fragmentNumber = 1; fragmentNumber < 8; fragmentNumber++) {
//I want to set this index to count fragment number when I look at server
buf[9] = fragmentNumber;
//I give it as char * array with reinterpret_cast, since sendto accepts pointer char array
sendOk = sendto(out, reinterpret_cast<char*>(&buf), 1450, 0, (sockaddr*)& server, sizeof(server));
}
}
if (sendOk == SOCKET_ERROR)
{
cout << "That didn't work! " << WSAGetLastError() << endl;
}
closesocket(out);
WSACleanup();
}
Here is my server code
void writeToFile(char buf[], vector<uint16_t> &intData, ofstream &file) {
while (true) {
if (signaled == 1) {
thread_mutex.lock();
//writing...
for (const auto& e : intData) {
file << e << "\n";
}
buffers.pop(); // pops front which is written by this time
buffers.push(buf);
thread_mutex.unlock();
break;
}
else{
continue;
}
}
}
// Main entry point into the server
void main()
{
WSADATA data;
WORD version = MAKEWORD(2, 2);
int wsOk = WSAStartup(version, &data);
if (wsOk != 0)
{
// Not ok! Get out quickly
cout << "Can't start Winsock! " << wsOk;
return;
}
// Create a socket, notice that it is a user datagram socket (UDP)
SOCKET in = socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP);
sockaddr_in serverHint;
serverHint.sin_addr.S_un.S_addr = ADDR_ANY; // Us any IP address available on the machine
serverHint.sin_family = AF_INET; // Address format is IPv4
serverHint.sin_port = htons(4660); // Convert from little to big endian
// Try and bind the socket to the IP and port
if (bind(in, (sockaddr*)&serverHint, sizeof(serverHint)) == SOCKET_ERROR)
{
cout << "Can't bind socket! " << WSAGetLastError() << endl;
return;
}
sockaddr_in client; // Use to hold the client information (port / ip address)
int clientLength = sizeof(client); // The size of the client information
char buf[1550] = { 0 }; //message gets here
char buf2[1550]= { 0 };
char buf3[1550]= { 0 };
// Control buffer traffic with queue
buffers.push(buf);
buffers.push(buf2);
buffers.push(buf3);
std::thread thread_write(writeToFile, std::ref(buffers.front()), std::ref( intData), std::ref(file)); //front returns first element of the queue
bytesIn = recvfrom(in, buffers.front(), 1550, 0, (sockaddr*)& client, &clientLength);
cout << "";
while (ReceivedFrameCount != 100)
{
ZeroMemory(&client, clientLength); // Clear the client structure
// Wait for message
bytesIn = recvfrom(in, buffers.front(), 1550, 0, (sockaddr*)& client, &clientLength);
if (bytesIn == SOCKET_ERROR)
{
cout << "Error receiving from client " << WSAGetLastError() << endl;
continue;
}
// Parse the byte array
TotalFragmentCount = (uint16_t)(buf[6] << 8 | buf[7]);
FrameFragmentNo = (uint16_t)(buf[8] << 8 | buf[9]);
signaled = 1;
}// end of while
// Close socket
closesocket(in);
file.close();
WSACleanup();
thread_write.join();
}
最佳答案
reinterpret_cast<char*>(&buf)
不做你认为它做的事。应该是reinterpret_cast<char*>(buf)
.和 1450
应该是 1450*sizeof(int)
因为你有 1450 个整数,每个整数都超过一个字节。
sendto 需要一个指向它将发送的数据的指针。如果你通过了&buf
(指向 buf
的指针)那么您正在发送指针 buf
.如果你通过了buf
(指向缓冲区的指针)然后您正在发送缓冲区。
当你构建一个整数数组时,你的计算机将它们作为字节存储在内存中,如下所示:(也许 - 它是特定于平台的!)
Byte 0: 0 \
Byte 1: 0 |
Byte 2: 0 | int 0
Byte 3: 0 /
Byte 4: 1 \
Byte 5: 0 |
Byte 6: 0 | int 1
Byte 7: 0 /
Byte 8: 2 \
Byte 9: 0 |
Byte 10: 0 | int 2
Byte 11: 0 /
当服务器将这些视为字节时,它将在索引 8 处看到数字 2,依此类推。如果您希望它匹配,那么客户端也许应该创建一个字节数组(字符,与服务器相同)而不是整数。
关于c++ - C++中客户端到服务器的数据传输问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58200957/
#include using namespace std; class C{ private: int value; public: C(){ value = 0;
这个问题已经有答案了: What is the difference between char a[] = ?string?; and char *p = ?string?;? (8 个回答) 已关闭
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 7 年前。 此帖子已于 8 个月
除了调试之外,是否有任何针对 c、c++ 或 c# 的测试工具,其工作原理类似于将独立函数复制粘贴到某个文本框,然后在其他文本框中输入参数? 最佳答案 也许您会考虑单元测试。我推荐你谷歌测试和谷歌模拟
我想在第二台显示器中移动一个窗口 (HWND)。问题是我尝试了很多方法,例如将分辨率加倍或输入负值,但它永远无法将窗口放在我的第二台显示器上。 关于如何在 C/C++/c# 中执行此操作的任何线索 最
我正在寻找 C/C++/C## 中不同类型 DES 的现有实现。我的运行平台是Windows XP/Vista/7。 我正在尝试编写一个 C# 程序,它将使用 DES 算法进行加密和解密。我需要一些实
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
有没有办法强制将另一个 窗口置于顶部? 不是应用程序的窗口,而是另一个已经在系统上运行的窗口。 (Windows, C/C++/C#) 最佳答案 SetWindowPos(that_window_ha
假设您可以在 C/C++ 或 Csharp 之间做出选择,并且您打算在 Windows 和 Linux 服务器上运行同一服务器的多个实例,那么构建套接字服务器应用程序的最明智选择是什么? 最佳答案 如
你们能告诉我它们之间的区别吗? 顺便问一下,有什么叫C++库或C库的吗? 最佳答案 C++ 标准库 和 C 标准库 是 C++ 和 C 标准定义的库,提供给 C++ 和 C 程序使用。那是那些词的共同
下面的测试代码,我将输出信息放在注释中。我使用的是 gcc 4.8.5 和 Centos 7.2。 #include #include class C { public:
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我的客户将使用名为 annoucement 的结构/类与客户通信。我想我会用 C++ 编写服务器。会有很多不同的类继承annoucement。我的问题是通过网络将这些类发送给客户端 我想也许我应该使用
我在 C# 中有以下函数: public Matrix ConcatDescriptors(IList> descriptors) { int cols = descriptors[0].Co
我有一个项目要编写一个函数来对某些数据执行某些操作。我可以用 C/C++ 编写代码,但我不想与雇主共享该函数的代码。相反,我只想让他有权在他自己的代码中调用该函数。是否可以?我想到了这两种方法 - 在
我使用的是编写糟糕的第 3 方 (C/C++) Api。我从托管代码(C++/CLI)中使用它。有时会出现“访问冲突错误”。这使整个应用程序崩溃。我知道我无法处理这些错误[如果指针访问非法内存位置等,
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 7 年前。
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,因为
我有一些 C 代码,将使用 P/Invoke 从 C# 调用。我正在尝试为这个 C 函数定义一个 C# 等效项。 SomeData* DoSomething(); struct SomeData {
这个问题已经有答案了: Why are these constructs using pre and post-increment undefined behavior? (14 个回答) 已关闭 6
我是一名优秀的程序员,十分优秀!