3 回答

TA貢獻1784條經驗 獲得超2個贊
很簡單,第一次的時候p跑到str里面'\0'的位置停了,然后'\0'被換成了*val,str數組就沒有結束符了;所以以后的while循環都會因為len=50越界而return了,下面的*p=*val執行不到的。第一次打印str是原來的字符串+一串亂碼吧,危險呢。

TA貢獻1946條經驗 獲得超3個贊
int PASCAL FAR sendto( SOCKET s, const char FAR* buf, int len, int flags,
const struct sockaddr FAR* to, int tolen);
你定義個結構指針,buf這個參數填這個指針,len填sizeof(結構體),這樣就可以了。

TA貢獻1865條經驗 獲得超7個贊
相關函數:send, sendmsg, recv, recvfrom, socket
頭文件:#include
<sys/types.h> #include <sys/socket.h>
定義函數:int sendto(int
s, const void * msg, int len, unsigned int flags, const struct sockaddr * to,
int tolen);
函數說明:sendto() 用來將數據由指定的socket 傳給對方主機. 參數s 為已建好連線的socket, 如果利用UDP協議則不需經過連線操作. 參數msg 指向欲連線的數據內容, 參數flags 一般設0, 詳細描述請參考send(). 參數to 用來指定欲傳送的網絡地址, 結構sockaddr 請參考bind(). 參數tolen 為sockaddr 的結果長度。
返回值:成功則返回實際傳送出去的字符數, 失敗返回-1, 錯誤原因存于errno 中。
范例:?
#include <sys/types.h>
#include <sys/socket.h>
#include
<netinet.in.h>
#include <arpa.inet.h>
#define PORT 2345
/*使用的port */
main()
{
int sockfd, len;
struct sockaddr_in
addr;
char buffer[256];
//建立socket
if(sockfd =
socket(AF_INET, SOCK_DGRAM, 0)) < 0)
{
perror
("socket");
exit(1);
}
//填寫sockaddr_in 結構
bzero(&addr, sizeof(addr));
addr.sin_family = AF_INET;
addr.sin_port = htons(PORT);
addr.sin_addr = hton1(INADDR_ANY);
if(bind(sockfd, &addr, sizeof(addr)) < 0)
{
perror("connect");
exit(1);
}
while(1)
{
bezro(buffer, sizeof(buffer));
len = recvfrom(socket, buffer,
sizeof(buffer), 0, &addr &addr_len);
//顯示client 端的網絡地址
printf("receive from %s\n ", inet_ntoa(addr.sin_addr));
//將字串返回給client 端
sendto(sockfd, buffer, len, 0, &addr,
addr_len);
}
}
- 3 回答
- 0 關注
- 451 瀏覽
添加回答
舉報