淺談socket網絡編程函數參數(二)

bind()函數

bind()函數把一個地址族中的特定地址賦給socket。
例如對應AF_INET、AF_INET6就是把一個ipv4或ipv6地址和端口號組合賦給socket。

int bind(int sockfd, const struct sockaddr *addr, socklen_t addrlen);

參數解析

  • sockfd:即socket描述字,它是通過socket()函數創建了,唯一標識一個socket。bind()函數就是將給這個描述字綁定一個名字。
  • addr:一個const struct sockaddr *指針,指向要綁定給sockfd的協議地址。這個地址結構根據地址創建socket時的地址協議族的不同而不同,
    ipv4對應的是:
    解析:https://blog.csdn.net/csdn_kou/article/details/81452166
 struct sockaddr_in {sa_family_t    sin_family; /* address family: AF_INET */in_port_t      sin_port;   /* port in network byte order */struct in_addr sin_addr;   /* internet address */
};/* Internet address. */
struct in_addr {uint32_t       s_addr;     /* address in network byte order */
};

addrlen:對應的是地址的長度。

listen()

如果作為一個服務器,在調用socket()、bind()之后就會調用listen()來監聽這個socket,如果客戶端這時調用connect()發出連接請求,服務器端就會接收到這個請求。

int listen(int sockfd, int backlog);
  • listen函數的第一個參數即為要監聽的socket描述字,第二個參數為相應socket可以排隊的最大連接個數。
  • socket()函數創建的socket默認是一個主動類型的,listen函數將socket變為被動類型的,等待客戶的連接請求。

connect()函數

int connect(int sockfd, const struct sockaddr *addr, socklen_t addrlen);
  • connect函數的第一個參數即為客戶端的socket描述字
  • 第二參數為服務器的socket地址
  • 第三個參數為socket地址的長度。
  • 客戶端通過調用connect函數來建立與TCP服務器的連接。

accept()函數

概念

TCP服務器端依次調用socket()、bind()、listen()之后,就會監聽指定的socket地址了。TCP客戶端依次調用socket()、connect()之后就向TCP服務器發送了一個連接請求。TCP服務器監聽到這個請求之后,就會調用accept()函數取接收請求,這樣連接就建立好了。之后就可以開始網絡I/O操作了,即類同于普通文件的讀寫I/O操作。

關鍵點

*accept()會創建一個新的socket,并且正是這個新的socket會與執行connect()的對象socket進行連接。

返回值

accept()的返回結果是已經連接的socket文件描述符
int accept(int sockfd, struct sockaddr *addr, socklen_t *addrlen); //返回連接connect_fd

用法

        int newfd = -1;struct sockaddr_in cli_addr;newfd = accept(lst_fd, (struct sockaddr*)&cli_addr, &len);if (newfd < 0) {perror("accept error");continue;}
---------------------------------------------------------------socklen_t len = sizeof(struct sockaddr_in);int lst_fd = -1;lst_fd = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);if (lst_fd < 0) {perror("socket error");return -1;}
  • 參數sockfd就是上面解釋中的監聽套接字,這個套接字用來監聽一個端口,當有一個客戶與服務器連接時,它使用這個一個端口號,而此時這個端口號正與這個套接字關聯。當然客戶不知道套接字這些細節,它只知道一個地址和一個端口號。
  • 參數addr
    這是一個結果參數,它用來接受一個返回值,這返回值指定客戶端的地址,當然這個地址是通過某個地址結構來描述的,用戶應該知道這一個什么樣的地址結構。如果對客戶的地址不感興趣,那么可以把這個值設置為NULL。
  • 參數len
    如同大家所認為的,它也是結果的參數,用來接受上述addr的結構的大小的,它指明addr結構所占有的字節個數。同樣的,它也可以被設置為NULL。

close()函數

在服務器與客戶端建立連接之后,會進行一些讀寫操作,完成了讀寫操作就要關閉相應的socket描述字

#include <unistd.h>
int close(int fd);

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/382666.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/382666.shtml
英文地址,請注明出處:http://en.pswp.cn/news/382666.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

對引用的理解3

對數組的引用&#xff0c; 相關語法 int main() { //引用于法// type &引用名 原名//數組的引用//1) 先定義一個數組int array[10];int (&refArray)[10] array;for (int i 0; i < 10; i) {array[i] i;}for (int i 0; i < 10; i) {cout << refArray[i…

運算符與,|與||的區別

|和&是位運算&#xff0c;運算結果是二進制數。 &&,||是邏輯運算&#xff0c;運算結果是真&#xff0c;或者假。 6&3110&0110102 6|3110|0111117&, &&和||計算時注意&#xff0c; 題目&#xff1a;條件1&&條件2&&條件3 如…

C++ 對引用的理解4

引用的注意事項 // 引用注意事項&#xff0c; 不能返回局部變量的引用 int & test3() { //因為局部變量出了函數體外 就會被銷毀int a 10;return a; }// 引用注意事項&#xff0c; 返回值如果是引用&#xff0c; 那么函數可以作為左值進行運算 int & test4() {static…

關于argc和argv的輸出

代碼 #include <stdio.h>int main(int argc ,char * argv[]) {printf("argc ->%d\n",argc);for(int i 0; i < argc;i){printf("%s\n",argv[i]);}return 0; } 輸出結果 [koulocalhost 8_6網絡計算器]$ ./a.out 192.168.1.1 9000 argc ->…

C++ 對引用的理解5

常量引用 int main() { // int &m 10; // 錯誤&#xff0c; 引用必須引一塊合法的內存空間&#xff08;什么是合法的內存空間&#xff0c; 這個10在程序中有內存嗎&#xff1f;&#xff09;const int &m 10; //加入const后&#xff0c;語法就通過了&#xff0c;編譯…

為什么計算機起始時間是1970年1月1日

1969年8月&#xff0c;貝爾實驗室的程序員肯湯普遜利用妻兒離開一個月的機會&#xff0c;開始著手創造一個全新的革命性的操作系統&#xff0c;他使用B編譯語言在老舊的PDP-7機器上開發出了Unix的一個版本。隨后&#xff0c;湯普遜和同事丹尼斯里奇改進了B語言&#xff0c;開發…

C++ 使用extern C簡單使用

先說一下函數重載&#xff0c; C 之所以會進行函數重載&#xff0c; 是因為對函數名進行二次修飾(重新命名) 在C文件中寫好的程序&#xff0c; C引入過來&#xff0c;卻沒法使用提示 無法連接的外部符號&#xff0c;那是因為C按照C的函數命名機制來尋找函數的實現. 第一種情況&…

IP數據包格式netinet/ip.h

轉載地址https://www.cnblogs.com/embedded-linux/p/4986449.html 頭文件netinet/ip.h中定義ip&#xff1a; struct ip{#if __BYTE_ORDER __LITTLE_ENDIANunsigned int ip_hl:4; /* header length */unsigned int ip_v:4; /* version */#endif#if __BYTE_ORDER __BIG_ENDIA…

c 結構體的簡單封裝1

先看C語言的 借助結構體 struct Person{char name[64];int age; }; void PersonEat(struct Person *p) {printf("%s在吃飯", p->name); } void test() {struct Person p;strcpy(p.name, "隔壁老王");PersonEat(&p); }

C++ 構造函數分類以及調用

#define _CRT_SECURE_NO_WARNINGS #include<iostream> using namespace std;//1、分類 //按照參數進行分類 有參構造函數 無參構造函數&#xff08;默認構造函數&#xff09; //按照類型進行分類 普通構造函數 拷貝構造函數 class Person { public://默認構造Per…

內存泄漏Valgrind

#內存泄漏Valgrind valgrind --toolmemcheck --leak-checkfull [Your progame option]; https://cloud.tencent.com/developer/article/1006199 https://www.cnblogs.com/zhoudayang/p/6110360.html https://www.cnblogs.com/napoleon_liu/articles/2001802.html https://…

C++ 拷貝構造函數的使用場景

#define _CRT_SECURE_NO_WARNINGS #include<iostream> using namespace std;class Person { public:Person(){cout << "默認構造函數調用" << endl;}Person(int a){m_Age a;cout << "有參構造函數調用" << endl;}Person(co…

大數據多路歸并算法

https://blog.csdn.net/wongson/article/details/49209903 先把一個大的數據分成若干小份&#xff0c;然后對這些小份文件進行排序。排序好之后對這些小份文件進行如下處理。 我們舉個簡單的例子&#xff1a; 文件1&#xff1a;3,6,9 文件2&#xff1a;2,4,8 文件3&#xff…

C++ 深淺拷貝 01

1.C中成員對象如果指向了堆內存的空間&#xff0c;如果這時候使用了系統提供的拷貝構造函數&#xff08;默認淺拷貝&#xff09;&#xff0c;會造成內存重復釋放的問題&#xff0c;導致程序down掉&#xff0c;解決辦法修改默認的拷貝構造函數&#xff0c;也給新的對象需要堆內存…

文件描述符和fcntl及阻塞非阻塞

Linux 文件描述符和重定向 https://www.cnblogs.com/chenmh/p/5382044.html fcntl函數的用法總結 https://www.cnblogs.com/zxc2man/p/7649240.html 簡述linux同步與異步、阻塞與非阻塞概念以及五種IO模型 https://www.cnblogs.com/chaser24/p/6112071.html

C++拷貝構造函數的調用時機

#define _CRT_SECURE_NO_WARNINGS #include<iostream> using namespace std;class Person { public:Person(){cout << "默認構造函數調用" << endl;}Person(int a){m_Age a;cout << "有參構造函數調用" << endl;}Person(co…

守護進程nohup的用法

使./a.out后臺運行 nohup ./a.out & exit // 如果你使用的bash客戶端或者是screen窗口&#xff0c;直接關閉窗口那么該進程也會終止&#xff0c;所以要用exit關于nohup重定向 在使用nohup命令的時候&#xff0c;經常由于輸出nohup.out的路徑沒有寫入權限&#xff0c;而無…

C++ 不懂的地方 記錄01

C 中初始化列表&#xff0c; 的詳細使用&#xff1f;沒有默認構造函數的類類型&#xff0c;因為使用初始化列表可以不必調用默認構造函數來初始化&#xff0c;而是直接調用拷貝構造函數初始化 這句話不是很理解 //手機類 class Phone { public:Phone(string pName){cout <&…

簡答面向數據報,面向字節流

先來一個例子 用UDP傳輸100個字節的數據: 面向數據報 如果發送端調用一次sendto, 發送100個字節, 那么接收端也必須調用對應的一次recvfrom, 接收100個字節; 而不能循環調用10次recvfrom, 每次接收10個字節; 面向字節流 由于緩沖區的存在, TCP程序的讀和寫不需要一一匹配…