[Erlang開發(fā)之路]十七、套接字編程(TCP&UDP)

TCP編程

1.涉及的模塊和函數(shù)

%gen_tcp是TCP編程的核心模塊
%包括函數(shù)如下
-spec connect(Address, Port, Options, Timeout) -> {ok, Socket} | {error, Reason} when
Address = inet:socket_address() | inet:hostname() %其實可以是字符串
Port = inet:port_number()%整形
Options = [connect_option()]%舉例:[binary,{packet,0},{nodelay,true}]
Timeout = timeout()%超時時間
Socket = socket()
Reason = timeout | inet:posix()

-spec listen(Port, Options) -> {ok, ListenSocket} | {error, Reason} when
Port = inet:port_number()
Options = [listen_option()]
ListenSocket = socket()
Reason = system_limit | inet:posix()

-spec accept(ListenSocket, Timeout) -> {ok, Socket} | {error, Reason} when
ListenSocket = socket()
%Returned by listen/2.
Timeout = timeout()
Socket = socket()
Reason = closed | timeout | system_limit | inet:posix()

-spec recv(Socket, Length, Timeout) -> {ok, Packet} | {error, Reason} when
Socket = socket()
Length = integer() >= 0
Timeout = timeout()
Packet = string() | binary() | HttpPacket
Reason = closed | timeout | inet:posix()
HttpPacket = term()

-spec send(Socket, Packet) -> ok | {error, Reason} when
Packet = string() | binary() | HttpPacket
 
-spec shutdown(Socket, How) -> ok | {error, Reason} %關(guān)閉連接
Socket = socket()
How = read | write | read_write
Reason = inet:posix()
%當(dāng)How==read時寫的操作還是可以進(jìn)行的,反之,=write時讀的操作還可以進(jìn)行,
%如果HOW==READ或Socket端口中沒有緩沖傳出數(shù)據(jù),則立即關(guān)閉套接字并在Reason中返回遇到的任何錯誤。如果套接字端口中有緩沖數(shù)據(jù),則會延遲關(guān)閉套接字的嘗試,直到將數(shù)據(jù)寫入內(nèi)核套接字發(fā)送緩沖區(qū)。如果遇到任何錯誤,則關(guān)閉套接字并在下一個recv / 2或send / 2上返回 {error,closed}。
-spec close(Socket) -> ok 和shutdown差不多,但是shutdown更好,將會即刻關(guān)閉

服務(wù)端:

%來個實例吧:服務(wù)端;每進(jìn)入一個客戶就創(chuàng)建一個新進(jìn)程去Accept和loopRecv
-module(tcpServer).
-export([start/0]).

start()->
    case gen_tcp:listen(6612,[binary,{packet,4},{active,false}]) of%創(chuàng)建一個被動服務(wù)器
        {ok,Socket}->
            io:format("Server Listen Success!~n"),
            loopAccept(Socket);
        {error,Reason}->
            io:format("Server Listen Fail! Reason~p~n",Reason)
    end.
    
loopAccept(Socket)->
    case gen_tcp:accept(Socket) of
        {ok,ClientFd}->
            spawn(tcpServer,fun()->loopAccept(ClientFd) end),
            loopRecv(ClientFd);
        {error,Reason}->
        io:format("Server Accept Fail! Reason~p~n",Reason)
    end.
    
loopRecv(ClientFd)->
    case gen_tcp:recv(ClientFd,0) of
        {ok,Bin}->
            io:format("Recv:~p~n",[binary_to_list(Bin)]),
            loopRecv(ClientFd);
        {error,closed}->
            byebye
    end.
        

客戶端:

%This is a client
-module(tcpClient).
-export([start/1,loopSend/3]).
-spec start(Num)-> any() when
Num:integer().

start(Num)->
    case gen_tcp:connect({127,0,0,1},6612,[binary,{packet,4}]) of
        {ok,Socket}->
            loopSend(Socket,0,Num);
        {error,Reason}->
            Reason
    end.
loopSend(Socket,Index,Target) when Target=<Index ->
    io:format("Send Finish!~n",[]);
loopSend(Socket,Index,Target)->
    gen_tcp:send(Socket,list_to_binary(["This is a message!!"])),
    loopSend(Socket,Index+1,Target).

UDP未完待續(xù)...

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 計算機(jī)網(wǎng)絡(luò)概述 網(wǎng)絡(luò)編程的實質(zhì)就是兩個(或多個)設(shè)備(例如計算機(jī))之間的數(shù)據(jù)傳輸。 按照計算機(jī)網(wǎng)絡(luò)的定義,通過一定...
    蛋炒飯_By閱讀 1,366評論 0 10
  • 轉(zhuǎn)自原文:TCP、UDP以及TCP滑窗,它們的區(qū)別注:文中提到TCP傳輸過程的特點,以及“粘包”的原因和解決方案,...
    半島夏天閱讀 3,682評論 2 31
  • 網(wǎng)絡(luò)編程 一.楔子 你現(xiàn)在已經(jīng)學(xué)會了寫python代碼,假如你寫了兩個python文件a.py和b.py,分別去運...
    go以恒閱讀 2,244評論 0 6
  • 個人認(rèn)為,Goodboy1881先生的TCP /IP 協(xié)議詳解學(xué)習(xí)博客系列博客是一部非常精彩的學(xué)習(xí)筆記,這雖然只是...
    貳零壹柒_fc10閱讀 5,194評論 0 8
  • 史上最全的iOS面試題及答案 iOS面試小貼士———————————————回答好下面的足夠了----------...
    Style_偉閱讀 2,571評論 0 35

友情鏈接更多精彩內(nèi)容