色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

Linux應用開發【第六章】網絡編程應用開發

weidongshan ? 來源:weidongshan ? 作者:weidongshan ? 2021-12-10 19:17 ? 次閱讀

文章目錄

6 網絡編程應用開發

6.1 網絡編程簡介

6.1.1 五層因特網協議棧

6.1.2 傳輸層和應用層的常見協議

6.2 網絡編程之TCP/UDP比較

6.2.1 TCP和UDP 原理上的區別

6.2.2 為何存在UDP協議

6.2.3 TCP/UDP網絡通信大概交互圖

6.3 網絡編程主要函數介紹

6.3.1 socket函數

6.3.2 bind函數

6.3.3 listen函數

6.3.4 accept函數

6.3.5 connect函數

6.3.6 send函數

6.3.7 recv函數

6.3.8 recvfrom函數

6.3.9 sendto函數

6.4 TCP編程簡單示例

6.4.1 服務器端代碼

6.4.2 客戶端代碼

6.4.3 Makefile文件

6.4.4 執行

6.5 UDP編程簡單示例

6.5.1 服務器端代碼

6.5.2 客戶端代碼

6.5.2.1 客戶端程序1

6.5.2.2 客戶端程序2

6.5.3 Makefile文件

6.5.4 執行

6 網絡編程應用開發

6.1 網絡編程簡介

要編寫通過計算機網絡通信的程序,首先要確定這些程序同通信的協議(protocol),在設計一個協議的細節之前,首先要分清程序是由哪個程序發起以及響應何時產生。

舉例來說,一般認為WEB服務器程序是一個長時間運行的程序(守護進程deamon),它只在響應來自網絡的請求時才發送網絡消息。協議的另一端是web客戶程序,如某種瀏覽器,與服務器進程的通信總是由客戶進程發起。大多數網絡應用就是按照劃分為客戶(clinet)和服務器(server)來組織的。

6.1.1 五層因特網協議棧

為了給網絡協議的設計提供一個結構,網絡設計者以分層(layer)的方式組織協議以及實現這些協議的網絡硬件和軟件。

分層提供了一種結構化方式來討論系統組件。模塊化使更新系統組件更為容易。

協議棧是各層所有協議的總和。

poYBAGGzNzWAdICbAAATy_4rwtM378.png

五層因特網協議棧

應用層:應用層是網絡應用程序及它們的應用層協議存留的地方。

運輸層:因特網的運輸層在應用程序端點之間傳從應用層報文。

網絡層:因特網呃網絡層負責將稱為數據包(datagram)的網絡層分組從一臺主機移動到另一臺主機。

鏈路層:因特網的網絡層通過源和目的地之間的一系列路由器路由數據報。

物理層:雖然鏈路層的任務是將整個幀從一個網絡元素移動到臨近的網絡元素,而物理層的任務是將該幀的一個一個比特從一個節點移動到下一個節點。

6.1.2 傳輸層和應用層的常見協議

我們重點介紹和應用層編程關系密切的應用層和運輸層。

應用層:

因特網的應用層包含很多協議,例如HTTP,SMTP,和 FTP。我們看到的某些網絡功能,比如將www.baidu.com這樣對人友好的端系統名字轉換為32比特網絡地址,也是借助于特定的應用層協議即域名系統(DNS)完成的。

應用層的協議分布在多個端系統上,一個端系統中的應用程序使用協議與另一個端系統中的應用程序交換信息分組。

運輸層:

在英特網中有兩個運輸協議,即TCP和UDP,利用其中的任何一個都能運輸應用層報文。我們寫應用程序的時候具體選擇哪個運輸層協議應該根據實際情況來確定(后面會具體講解)。

6.2 網絡編程之TCP/UDP比較

6.2.1 TCP和UDP 原理上的區別

TCP向它的應用程序提供了面向連接的服務。這種服務包括了應用層報文向目的地的確保傳遞和流量控制(即發送方/接收方速率匹配)。這種服務包括了應用層報文劃分為短報文,并提供擁塞控制機制,因此當網絡擁塞時源抑制其傳輸速率。

UDP協議向它的應用程序提供無連接服務。這是一種不提供不必要服務的服務,沒有可靠性,沒有流量控制,也沒有擁塞控制。

6.2.2 為何存在UDP協議

既然TCP提供了可靠數據傳輸服務,而UDP不能提供,那么TCP是否總是首選呢?答案是否定的,因為有許多應用更適合用UDP,原因有以下幾點:

a. 關于何時發送什么數據控制的更為精細。

采用UDP時只要應用進程將數據傳遞給UDP,UDP就會立即將其傳遞給網絡層。而TCP有重傳機制,而不管可靠交付需要多長時間。但是實時應用通常不希望過分的延遲報文段的傳送,且能容忍一部分數據丟失。

b. 無需建立連接,不會引入建立連接時的延遲。

c. 無連接狀態,能支持更多的活躍客戶。

d. 分組首部開銷較小。

6.2.3 TCP/UDP網絡通信大概交互圖

下面我們分別畫出運用TCP協議和運用UDP協議的客戶端和服務器大概交互圖。

pYYBAGGzNzuAa_SNAABSurUuxzU563.png

面向連接的TCP流模式

poYBAGGzN0GAaiaoAAAz9Vs51Gs694.png

UDP用戶數據包模式

6.3 網絡編程主要函數介紹

6.3.1 socket函數

int socket(int domain, int type,int protocol);

此函數用于創建一個套接字。

domain是網絡程序所在的主機采用的通訊協族(AF_UNIX和AF_INET等)。

AF_UNIX只能夠用于單一的Unix 系統進程間通信,而AF_INET是針對Internet的,因而可以允許遠程通信使用。

type是網絡程序所采用的通訊協議(SOCK_STREAM,SOCK_DGRAM等)。

SOCK_STREAM表明用的是TCP 協議,這樣會提供按順序的,可靠,雙向,面向連接的比特流。

SOCK_DGRAM 表明用的是UDP協議,這樣只會提不可靠,無連接的通信。

關于protocol,由于指定了type,所以這個地方一般只要用0來代替就可以了。

此函數執行成功時返回文件描述符,失敗時返回-1,看errno可知道出錯的詳細情況。

6.3.2 bind函數

int bind(int sockfd, struct sockaddr *my_addr, int addrlen);

從函數用于將地址綁定到一個套接字。

sockfd是由socket函數調用返回的文件描述符。

my_addr是一個指向sockaddr的指針。

addrlen是sockaddr結構的長度。

sockaddr的定義:

struct sockaddr{ unisgned short as_family; char sa_data[14]; };

不過由于系統的兼容性,我們一般使用另外一個結構(struct sockaddr_in) 來代替。

sockaddr_in的定義:

struct sockaddr_in{ unsigned short sin_family; unsigned short int sin_port; struct in_addr sin_addr; unsigned char sin_zero[8]; }

如果使用Internet所以sin_family一般為AF_INET。

sin_addr設置為INADDR_ANY表示可以和任何的主機通信。

sin_port是要監聽的端口號。

bind將本地的端口同socket返回的文件描述符捆綁在一起.成功是返回0,失敗的情況和socket一樣。

6.3.3 listen函數

int listen(int sockfd,int backlog);

此函數宣告服務器可以接受連接請求。

sockfd是bind后的文件描述符。

backlog設置請求排隊的最大長度。當有多個客戶端程序和服務端相連時,使用這個表示可以介紹的排隊長度。

listen函數將bind的文件描述符變為監聽套接字,返回的情況和bind一樣。

6.3.4 accept函數

int accept(int sockfd, struct sockaddr *addr,int *addrlen);

服務器使用此函數獲得連接請求,并且建立連接。

sockfd是listen后的文件描述符。

addr,addrlen是用來給客戶端的程序填寫的,服務器端只要傳遞指針就可以了, bind,listen和accept是服務器端用的函數。

accept調用時,服務器端的程序會一直阻塞到有一個客戶程序發出了連接。 accept成功時返回最后的服務器端的文件描述符,這個時候服務器端可以向該描述符寫信息了,失敗時返回-1 。

6.3.5 connect函數

int connect(int sockfd, struct sockaddr * serv_addr,int addrlen);

可以用connect建立一個連接,在connect中所指定的地址是想與之通信的服務器的地址。

sockfd是socket函數返回的文件描述符。

serv_addr儲存了服務器端的連接信息,其中sin_add是服務端的地址。

addrlen是serv_addr的長度

connect函數是客戶端用來同服務端連接的.成功時返回0,sockfd是同服務端通訊的文件描述符,失敗時返回-1。

6.3.6 send函數

ssize_t send(int sockfd, const void *buf, size_t len, int flags);

sockfd指定發送端套接字描述符;

buf指明一個存放應用程序要發送數據的緩沖區;

len指明實際要發送的數據的字節數;

flags一般置0。

客戶或者服務器應用程序都用send函數來向TCP連接的另一端發送數據

6.3.7 recv函數

ssize_t recv(int sockfd, void *buf, size_t len, int flags);

sockfd指定接收端套接字描述符;

buf指明一個緩沖區,該緩沖區用來存放recv函數接收到的數據;

len指明buf的長度;

flags一般置0。

客戶或者服務器應用程序都用recv函數從TCP連接的另一端接收數據。

6.3.8 recvfrom函數

ssize_t recvfrom(int sockfd, void *buf, size_t len, int flags, struct sockaddr *src_addr, socklen_t *addrlen);

recvfrom通常用于無連接套接字,因為此函數可以獲得發送者的地址。

src_addr是一個struct sockaddr類型的變量,該變量保存源機的IP地址及端口號。

addrlen常置為sizeof (struct sockaddr)。

6.3.9 sendto函數

ssize_t sendto(int sockfd, const void *buf, size_t len, int flags, const struct sockaddr *dest_addr, socklen_t addrlen);

sendto和send相似,區別在于sendto允許在無連接的套接字上指定一個目標地址。

dest_addr表示目地機的IP地址和端口號信息,

addrlen常常被賦值為sizeof (struct sockaddr)。

sendto函數也返回實際發送的數據字節長度或在出現發送錯誤時返回-1。

6.4 TCP編程簡單示例

服務器首先進行初始化操作:調用函數socket創建一個套接字,函數bind將這個套接字與服務器的公認地址綁定在一起,函數listen將這個套接字換成傾聽套接字,然后調用函數accept來等待客戶機的請求。過了一段時間后,客戶機啟動,調用socket創建一個套接字,然后調用函數connect來與服務器建立連接。連接建立之后,客戶機和服務器通過讀、寫套接字來進行通信。

6.4.1 服務器端代碼

參考:TCP/server_line.c

1#include 2#include 3#include 4#include 5#include 6#include 7#include 8#include 9#include 10 11#define SERVER_PORT 8180 12#define C_QUEUE 10 13 14/************************************************************ 15*函數功能描述:從8180端口接收客戶端數據 16*輸入參數:無 17*輸出參數:打印客戶IP以及發來的信息 18*返回值:無 19*修改日期 版本號 修改人 修改內容 20*2020/05/13 v1.0.0 zonghzha reat 21*************************************************************/ 22 23int main(int argc, char **argv) 24{ 25 char buf[512]; 26 int len; 27 int duty_socket; 28 int customer_socket; 29 struct sockaddr_in socket_server_addr; 30 struct sockaddr_in socket_client_addr; 31 int ret; 32 int addr_len; 33 34 signal(SIGCHLD, SIG_IGN); 35 36 /* 服務器端開始建立socket描述符 */ 37 duty_socket = socket(AF_INET, SOCK_STREAM, 0); 38 if (duty_socket == -1) 39 { 40 printf("socket error"); 41 return -1; 42 } 43 44 /* 服務器端填充 sockaddr_in結構 */ 45 socket_server_addr.sin_family = AF_INET; 46 /* 端口號轉換為網絡字節序 */ 47 socket_server_addr.sin_port = htons(SERVER_PORT); 48 /* 接收本機所有網口的數據 */ 49 socket_server_addr.sin_addr.s_addr = INADDR_ANY; 50 memset(socket_server_addr.sin_zero, 0, 8); 51 52 /* 捆綁sockfd描述符 */ 53 ret = bind(duty_socket, (const struct sockaddr *)&socket_server_addr, sizeof(struct sockaddr)); 54 if (ret == -1) 55 { 56 printf("bind error!n"); 57 return -1; 58 } 59 ret = listen(duty_socket, C_QUEUE); 60 if (ret == -1) 61 { 62 printf("listen error!n"); 63 return -1; 64 } 65 66 while (1) 67 { 68 addr_len = sizeof(struct sockaddr); 69 /* 服務器阻塞,直到客戶程序建立連接 */ 70 customer_socket = accept(duty_socket, (struct sockaddr *)&socket_client_addr, &addr_len); 71 if (customer_socket != -1) 72 { 73 /*inet_ntoa的作用是將一個32位Ipv4地址轉換為相應的點分十進制數串*/ 74 printf("Get connect from %sn", inet_ntoa(socket_client_addr.sin_addr)); 75 } 76 if (!fork()) 77 { 78 while (1) 79 { 80 memset(buf, 512, 0); 81 /*接收數據*/ 82 len = recv(customer_socket, buf, sizeof(buf), 0); 83 buf[len] = ''; 84 if (len <= 0) 85 { 86 close(customer_socket); 87 return -1; 88 } 89 else 90 { 91 printf("Get connect from %s, Msg is %sn", inet_ntoa(socket_client_addr.sin_addr), buf); 92 } 93 } 94 } 95 } 96 97 close(duty_socket); 98 return 0; 99}

6.4.2 客戶端代碼

參考:TCP/client_line.c

1#include 2#include 3#include 4#include 5#include 6#include 7#include 8#include 9 10#define SERVER_PORT 8180 11/************************************************************ 12*函數功能描述:向指定IP的8180端口發送數據 13*輸入參數:點分十進制服務器IP 14*輸出參數:無 15*返回值:無 16*修改日期 版本號 修改人 修改內容 17*2020/05/13 v1.0.0 zonghzha creat 18*************************************************************/ 19 20int main(int argc, char **argv) 21{ 22 unsigned char buf[512]; 23 int len; 24 struct sockaddr_in socket_server_addr; 25 int ret; 26 int addr_len; 27 int client_socket; 28 29 30 if (argc != 2) 31 { 32 printf("Usage:n"); 33 printf("%s n", argv[0]); 34 return -1; 35 } 36 37 /* 客戶程序開始建立 sockfd描述符 */ 38 client_socket = socket(AF_INET, SOCK_STREAM, 0); 39 if (client_socket == -1) 40 { 41 printf("socket error"); 42 return -1; 43 } 44 45 /* 客戶程序填充服務端的資料 */ 46 socket_server_addr.sin_family = AF_INET; 47 /*主機字節序轉換為網絡字節序*/ 48 socket_server_addr.sin_port = htons(SERVER_PORT); 49 if (inet_aton(argv[1], &socket_server_addr.sin_addr) == 0) 50 { 51 printf("invalid server ipn"); 52 return -1; 53 } 54 memset(socket_server_addr.sin_zero, 0, 8); 55 /* 客戶程序發起連接請求 */ 56 ret = connect(client_socket, (const struct sockaddr *)&socket_server_addr, sizeof(struct sockaddr)); 57 if (ret == -1) 58 { 59 printf("connect error!n"); 60 return -1; 61 } 62 63 64 while (1) 65 { 66 if (fgets(buf, sizeof(buf), stdin)) 67 { 68 len = send(client_socket, buf, strlen(buf), 0); 69 if (len <= 0) 70 { 71 close(client_socket); 72 return -1; 73 } 74 } 75 } 76 77 close(client_socket); 78 return 0; 79}

6.4.3 Makefile文件

all:server client server:server.c gcc $^ -o $@ client:client.c gcc $^ -o $@ clean: rm server client -f (注意:命令語句的開頭要用“Tab”鍵。)

6.4.4 執行

服務器端:

./server

客戶端:

./client 127.0.0.1

客戶端輸入:

good night

服務器端顯示:

Get connect from 127.0.0.1 Get connect from 127.0.0.1, Msg is good night

6.5 UDP編程簡單示例

UDP服務器首先進行初始化操作:調用函數socket創建一個數據報類型的套接字,函數bind將這個套接字與服務器的公認地址綁定在一起。然后調用函數recvfrom接收UDP客戶機的數據報。UDP客戶機首先調用函數socket創建一個數據報套接字,然后調用函數sendto向服務器發送數據報。在結束通信后,客戶機調用close關閉UDP套接字,服務器繼續使用這個UDP套接字接收其它客戶機的數據報。

6.5.1 服務器端代碼

參考UDP/server_line.c

1#include 2#include 3#include 4//#include 5#include 6#include 7#include 8#include 9#include 10 11/*服務器端口為8180*/ 12#define SERVER_PORT 8180 13 14/************************************************************ 15*函數功能描述:從8180端口接收客戶端數據 16*輸入參數:無 17*輸出參數:打印客戶IP以及發來的信息 18*返回值:無 19*修改日期 版本號 修改人 修改內容 20*2020/05/13 v1.0.0 zonghzha creat 21*************************************************************/ 22 23 24int main(int argc, char **argv) 25{ 26 unsigned char buf[512]; 27 int len; 28 int duty_socket; 29 int customer_socket; 30 struct sockaddr_in socket_server_addr; 31 struct sockaddr_in socket_client_addr; 32 int ret; 33 int addr_len; 34 35 /* 創建數據報套接字 */ 36 duty_socket = socket(AF_INET, SOCK_DGRAM, 0); 37 if (duty_socket == -1) 38 { 39 printf("socket error"); 40 return -1; 41 } 42 43 /* 服務器端填充 sockaddr_in結構 */ 44 socket_server_addr.sin_family = AF_INET; 45 socket_server_addr.sin_port = htons(SERVER_PORT); 46 socket_server_addr.sin_addr.s_addr = INADDR_ANY; 47 memset(socket_server_addr.sin_zero, 0, 8); 48 49 /*綁定套接字*/ 50 ret = bind(duty_socket, (const struct sockaddr *)&socket_server_addr, sizeof(struct sockaddr)); 51 if (ret == -1) 52 { 53 printf("bind error!n"); 54 return -1; 55 } 56 57 58 while (1) 59 { 60 addr_len = sizeof(struct sockaddr); 61 /* 接收客戶端數據報,返回的為接收到的字節數 */ 62 len = recvfrom(duty_socket, buf, sizeof(buf), 0, (struct sockaddr *)&socket_client_addr, &addr_len); 63 if (len > 0) 64 { 65 buf[len] = ''; 66 printf("Get Msg from %s : %sn", inet_ntoa(socket_client_addr.sin_addr), buf); 67 } 68 69 } 70 71 close(duty_socket); 72 return 0; 73} 74

6.5.2 客戶端代碼

6.5.2.1 客戶端程序1

參考UDP/client_line_1.c

1#include 2#include 3#include 4#include 5#include 6#include 7#include 8 9#define SERVER_PORT 8180 10 11/************************************************************ 12*函數功能描述:向指定IP的8180端口發送數據 13*輸入參數:點分十進制服務器IP 14*輸出參數:無 15*返回值:無 16*修改日期 版本號 修改人 修改內容 17*2020/05/13 v1.0.0 zonghzha creat 18*************************************************************/ 19 20int main(int argc, char **argv) 21{ 22 unsigned char buf[512]; 23 int len; 24 struct sockaddr_in socket_server_addr; 25 int ret; 26 int addr_len; 27 int client_socket; 28 29 30 if (argc != 2) 31 { 32 printf("Usage:n"); 33 printf("%s n", argv[0]); 34 return -1; 35 } 36 37 /*創建套接字*/ 38 client_socket = socket(AF_INET, SOCK_DGRAM, 0); 39 if (client_socket == -1) 40 { 41 printf("socket error"); 42 return -1; 43 } 44 45 /* 填充服務端的資料 */ 46 socket_server_addr.sin_family = AF_INET; 47 socket_server_addr.sin_port = htons(SERVER_PORT); 48 if (inet_aton(argv[1], &socket_server_addr.sin_addr) == 0) 49 { 50 printf("invalid server ipn"); 51 return -1; 52 } 53 memset(socket_server_addr.sin_zero, 0, 8); 54 55 56 57 58 while (1) 59 { 60 if (fgets(buf, sizeof(buf), stdin)) 61 { 62 // len = send(client_socket, buf, strlen(buf), 0); 63 /*向服務器端發送數據報*/ 64 addr_len = sizeof(struct sockaddr); 65 len = sendto(client_socket, buf, sizeof(buf), 0, (struct sockaddr *)&socket_server_addr, addr_len); 66 if (len <= 0) 67 { 68 close(client_socket); 69 return -1; 70 } 71 } 72 } 73 74 close(client_socket); 75 return 0; 76} 77

問:用UDP協議寫網絡通訊程序不可以用connect函數嗎?

答:非也。

6.5.2.2 客戶端程序2

參考UDP/client_line_2.c

1#include 2#include 3#include 4#include 5#include 6#include 7#include 8 9/*服務器端口為8180*/ 10#define SERVER_PORT 8180 11 12/************************************************************ 13*函數功能描述:向指定IP的8180端口發送數據 14*輸入參數:點分十進制服務器IP 15*輸出參數:無 16*返回值:無 17*修改日期 版本號 修改人 修改內容 18*2020/05/13 v1.0.0 zonghzha creat 19*************************************************************/ 20 21int main(int argc, char **argv) 22{ 23 unsigned char buf[512]; 24 int len; 25 struct sockaddr_in socket_server_addr; 26 int ret; 27 int addr_len; 28 int client_socket; 29 30 31 if (argc != 2) 32 { 33 printf("Usage:n"); 34 printf("%s n", argv[0]); 35 return -1; 36 } 37 38 /*創建數據報套接字*/ 39 client_socket = socket(AF_INET, SOCK_DGRAM, 0); 40 if (client_socket == -1) 41 { 42 printf("socket error"); 43 return -1; 44 } 45 46 socket_server_addr.sin_family = AF_INET; 47 socket_server_addr.sin_port = htons(SERVER_PORT); 48 if (inet_aton(argv[1], &socket_server_addr.sin_addr) == 0) 49 { 50 printf("invalid server ipn"); 51 return -1; 52 } 53 memset(socket_server_addr.sin_zero, 0, 8); 54 55 ret = connect(client_socket, (const struct sockaddr *)&socket_server_addr, sizeof(struct sockaddr)); 56 if (ret == -1) 57 { 58 printf("connect error!n"); 59 return -1; 60 } 61 62 63 while (1) 64 { 65 if (fgets(buf, sizeof(buf), stdin)) 66 { 67 len = send(client_socket, buf, strlen(buf), 0); 68 if (len <= 0) 69 { 70 close(client_socket); 71 return -1; 72 } 73 } 74 } 75 76 close(client_socket); 77 return 0; 78} 79

在客戶端代碼2中,connect函數并非真的在協議層建立了連接,它只是指定了服務器的地址和端口號信息。

因為在connect中指定了服務器的地址和端口號信息,所以后面的send就可以直接發送了,而不用再次指定地址和端口號。

6.5.3 Makefile文件

all:server client_1 client_2 server:server.c gcc $^ -o $@ client_1:client_1.c gcc $^ -o $@ client_2:client_2.c gcc $^ -o $@ clean: rm server client_1 client_2 -f (注意:命令語句的開頭要用“Tab”鍵。)

6.5.4 執行

服務器端執行:

./server

客戶端執行:

./client_1 127.0.0.1

客戶端輸入:

good night

服務器端顯示:

Get Msg from 127.0.0.1 : good night

審核編輯 黃昊宇

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 網絡
    +關注

    關注

    14

    文章

    7597

    瀏覽量

    89108
  • 編程
    +關注

    關注

    88

    文章

    3637

    瀏覽量

    93908
收藏 人收藏

    評論

    相關推薦

    《DNESP32S3使用指南-IDF版_V1.6》第六章 新建基礎工程

    第六章 新建基礎工程 在前面的章節中,我們已經簡要介紹了ESP32-S3的基礎知識和ESP-IDF的基本概念,并詳細闡述了VS Code IDE環境的搭建以及Espressif插件的安裝流程。現在
    發表于 12-02 14:43

    Linux應用編程的基本概念

    Linux應用編程涉及到在Linux環境下開發和運行應用程序的一系列概念。以下是一些涵蓋Linux應用
    的頭像 發表于 10-24 17:19 ?276次閱讀

    【北京迅為】i.mx8mm嵌入式linux開發指南第四篇 嵌入式Linux系統移植篇第六十九章uboot移植

    【北京迅為】i.mx8mm嵌入式linux開發指南第四篇 嵌入式Linux系統移植篇第六十九章uboot移植
    的頭像 發表于 10-22 14:46 ?725次閱讀
    【北京迅為】i.mx8mm嵌入式<b class='flag-5'>linux</b><b class='flag-5'>開發</b>指南第四篇 嵌入式<b class='flag-5'>Linux</b>系統移植篇<b class='flag-5'>第六</b>十九章uboot移植

    《DNK210使用指南 -CanMV版 V1.0》第六章 Kendryte K210固件燒錄

    第六章 Kendryte K210固件燒錄 本章將為讀者介紹Kendryte K210的固件燒錄,以及Kendryte K210外部NOR Flash的空間分布。本章分為如下幾個小節:6.1 外部
    發表于 09-12 14:20

    【北京迅為】《stm32mp157開發板嵌入式linux開發指南》第五 Ubuntu使用apt-get下載

    【北京迅為】《stm32mp157開發板嵌入式linux開發指南》第五 Ubuntu使用apt-get下載
    的頭像 發表于 09-03 16:26 ?847次閱讀
    【北京迅為】《stm32mp157<b class='flag-5'>開發</b>板嵌入式<b class='flag-5'>linux</b><b class='flag-5'>開發</b>指南》第五<b class='flag-5'>章</b> Ubuntu使用apt-get下載

    linux開發板與樹莓派的區別

    操作系統的微型計算機,主要用于教育、編程、媒體播放等領域。 硬件配置 Linux開發板:Linux開發板的硬件配置因廠商和型號而異,通常包括
    的頭像 發表于 08-30 15:34 ?1105次閱讀

    linux開發板和單片機開發的區別

    、PIC等,處理能力和內存容量相對較低。 操作系統 Linux開發板通常使用Linux操作系統,具有豐富的軟件資源和開發工具。單片機開發則通
    的頭像 發表于 08-30 15:30 ?1109次閱讀

    Linux 驅動開發與應用開發,你知道多少?

    一、Linux驅動開發與應用開發的區別開發層次不同:Linux驅動開發主要是針對硬件設備進行
    的頭像 發表于 08-30 12:16 ?896次閱讀
    <b class='flag-5'>Linux</b> 驅動<b class='flag-5'>開發</b>與應用<b class='flag-5'>開發</b>,你知道多少?

    SK海力士開發第六代10納米級DDR5 DRAM

    SK海力士宣布了一項重大技術突破,成功開發出全球首款采用第六代10納米級(1c)工藝的16Gb DDR5 DRAM。這一里程碑式的成就標志著SK海力士在半導體存儲技術領域的領先地位。
    的頭像 發表于 08-29 16:39 ?709次閱讀

    【「ARM MCU嵌入式開發 | 基于國產GD32F10x芯片」閱讀體驗】+書籍整體概況

    ,這里包含系統滴答定時器SysTick,RTC實時時鐘,看門狗(獨立看門狗與窗口看門狗),定時器(基本定時器、通用定時器、高級定時器),以及PWM實現呼吸燈效果實驗。第六章為通用同步/異步串行通信
    發表于 08-25 22:48

    第六章-電機驅動和PWM STM32項目

    萬字筆記、12多個小時視頻、20多章節代碼手把手教會你如何開發和調試。讓你更快掌握嵌入式系統開發。** V3.3.0-STM32智能小車 視頻: https
    的頭像 發表于 08-21 16:46 ?665次閱讀
    <b class='flag-5'>第六章</b>-電機驅動和PWM STM32項目

    雙麒麟系統!迅為RK3588開發板+銀河麒麟/開放麒麟

    Build root系統功能測試 第四 Ubuntu系統功能測試 第五 Debian系統功能測試 第六章 openkylin系統功能測試 第七 銀河麒麟系統功能測試
    發表于 07-15 10:35

    第3_UART 開發基礎

    第3_UART 開發基礎
    的頭像 發表于 06-29 14:27 ?756次閱讀
    第3<b class='flag-5'>章</b>_UART <b class='flag-5'>開發</b>基礎

    搭配100教學實驗案例,輕松解決老師備課難題!

    Linux系統使用實驗第三Linux設備驅動程序開發實驗第四基于ARM基礎外設實驗第五Li
    的頭像 發表于 05-01 08:31 ?446次閱讀
    搭配100教學實驗案例,輕松解決老師備課難題!

    fpga開發板與linux開發板區別

    (Field-Programmable Gate Array)是一種可編程邏輯器件,它可以通過編程改變硬件邏輯電路的功能和結構。FPGA采用了可編程的門極,可以根據需要重新配置內部電路,從而實現不同的功能和邏輯關系。而
    的頭像 發表于 02-01 17:09 ?2393次閱讀
    主站蜘蛛池模板: 久章草一区二区 | 99久久亚洲精品影院 | 亚洲精品免费观看 | 97人人爽人人爽人人人片AV | 成人性生交片无码免费看 | 老师的玉足高跟鞋满足我 | 久久亚洲精品中文字幕60分钟 | 动漫在线观看免费肉肉 | 成人毛片100部免费看 | 啊轻点灬大JI巴又大又粗 | 男神插曲女生软件完整版 | 中文字幕精品无码一区二区 | 性直播免费| 亚洲一区在线观看无码欧美 | 久久草香蕉频线观 | 欧洲最大无人区免费高清完整版 | adc影院在线 | 好大好爽好深舒服死了 | 日日操夜夜摸 | 免费看www视频 | 台湾18成人影院 | a在线观看视频 | 无人区国产片 | 国产精品99精品无码视亚 | www.av色| 果冻传媒在线观看资源七夕 | 精品网站一区二区三区网站 | www.97干| 好男人视频免费高清在线观看www | 涩涩涩涩爱网站 | 中国明星16xxxxhd | 97在线超碰免费视频 | 亚洲永久免费视频 | 偷拍 拍自 欧美色区 | 亚洲精品成人在线 | 好男人在线视频 | 国产扒开美女双腿屁股流白浆 | 亚洲精品视频在线免费 | 亚洲免费视频网站 | 香蕉久久夜色精品国产小优 | 亚洲中字幕永久在线观看 |