您好,登錄后才能下訂單哦!
這期內(nèi)容當(dāng)中小編將會(huì)給大家?guī)?lái)有關(guān)Vscode搭建遠(yuǎn)程c開(kāi)發(fā)環(huán)境的過(guò)程是怎樣的,文章內(nèi)容豐富且以專(zhuān)業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
目標(biāo)機(jī):ubuntu20
開(kāi)發(fā)機(jī):win10、mac 安裝
本機(jī)和目標(biāo)機(jī)都需要安裝。
參考 vscode 免密登錄服務(wù)器編輯
配置服務(wù)器信息,用vscode打開(kāi)遠(yuǎn)程電腦的一個(gè)目錄。
#include <stdio.h> #include <stdlib.h> #include <unistd.h> //系統(tǒng)函數(shù) #include <string.h> #include <pthread.h> //多線(xiàn)程庫(kù) #include "net_control_client.h" ts_tcp_client s_tcp_client; static int connect_to_server(void) { while(connect(s_tcp_client.socket_fd, (struct sockaddr *) &(s_tcp_client.server_socket_addr), sizeof(struct sockaddr)) != 0){ //if connect error reconnect after 5 seconds perror("connect"); printf("***reconnect after 5s***\n"); sleep(5); printf("***reconnect...***\n"); } printf("***connected***\n"); #if 1//test message send sleep(1); char test_msg[] = "This is from client"; send(s_tcp_client.socket_fd, test_msg ,sizeof(test_msg),0); #endif return 0; } /* * 接收socket數(shù)據(jù)函數(shù). * client_fd - 客戶(hù)端連接的socket。 */ static int receive_packet(int client_fd) { unsigned char buf[TCP_BUFFER_SIZE]; int recvbytes; while(1){ /*接收*/ bzero(buf,sizeof(buf)); recvbytes = recv(client_fd,buf,TCP_BUFFER_SIZE,0); printf("Receive %d bytes\n",recvbytes); if (recvbytes <= 0){//receive error or disconnected perror("recv"); /*reconnect to server*/ printf("close socket id = %d\n", s_tcp_client.socket_fd); close(s_tcp_client.socket_fd); //關(guān)閉通道 s_tcp_client.socket_fd = socket(AF_INET, SOCK_STREAM, 0); if (s_tcp_client.socket_fd == -1){ printf("###socket init error###\n"); perror("socket"); return -1; } printf("new socket id = %d\n", s_tcp_client.socket_fd); if (connect_to_server() != 0){ printf("###connect_to_server error###\n"); return -1; } }else{//receive success #if 1//test int i; printf("***GET:\n"); for (i = 0; i < recvbytes; i++){ printf("0x%02X %c\n", *(buf+i), *(buf+i)); } #endif } } return 0; } /*tcp clinet send thread*/ int tcp_send_start(void) { char buf[100]; uint32_t i = 0; while(1) { sleep(5); memset(buf,0,sizeof(buf)); sprintf(buf,"***send data:hello world : %d\n",i); i++; printf("%s",buf); send(s_tcp_client.socket_fd, buf ,strlen(buf),0); } } /*tcp clinet running function*/ int tcp_client_start(void) { pthread_t tcp_send_thread_id;//返回的線(xiàn)程值 printf("***connect to %s:%d....***\n", s_tcp_client.server_ip,s_tcp_client.server_port); /*connect to server*/ if (connect_to_server() != 0){ printf("###connect_to_server error###\n"); return -1; } //create thread for TCP send pthread_create(&tcp_send_thread_id, NULL, (void *)tcp_send_start, NULL); receive_packet(s_tcp_client.socket_fd); return 0; } /* * tcp_client initialize function * port_num - TCP server port number * server_ip - TCP server ip * */ int tcp_client_init(unsigned short port_num, char *server_ip) { int res; struct in_addr test_addr; /*initialize variable*/ if (port_num > 0){ s_tcp_client.server_port = port_num; }else{ printf("###invalid tcp server port:%d###\n", port_num); return -1; } if (server_ip == NULL){ printf("###server_ip cannot be NULL###\n"); return -1; }else{ strcpy(s_tcp_client.server_ip, server_ip);//record ip } printf("server ip is: %s\r\n",s_tcp_client.server_ip); /*建立socket描述符*/ if ((s_tcp_client.socket_fd = socket(AF_INET, SOCK_STREAM, 0)) == -1){ perror("socket"); return -1; } printf("socket id = %d\n", s_tcp_client.socket_fd); /* * 填充服務(wù)器sockaddr結(jié)構(gòu) */ bzero(&(s_tcp_client.server_socket_addr), sizeof(struct sockaddr_in)); //memset s_tcp_client.server_socket_addr.sin_family = AF_INET; inet_pton(AF_INET, s_tcp_client.server_ip, &(s_tcp_client.server_socket_addr.sin_addr.s_addr)); //把ip地址轉(zhuǎn)化為用于網(wǎng)絡(luò)傳輸?shù)亩M(jìn)制數(shù)值 s_tcp_client.server_socket_addr.sin_port = htons(s_tcp_client.server_port); //將主機(jī)字節(jié)順序轉(zhuǎn)為網(wǎng)絡(luò)字節(jié)順序 bzero(&(s_tcp_client.server_socket_addr.sin_zero), 8); return 0; } int main(int argc, char *argv[]) { int i = 0; int res; pthread_t tcp_thread_id;//返回的線(xiàn)程值 char tcp_server_port[256]; char tcp_server_ip[256]; printf("enter main\r\n"); if (argc >= 2){ if (strcmp(argv[1],"-v") == 0){ printf("net_control_client v1.0\n"); return 0; }else if (strcmp(argv[1],"-h") == 0){ printf("-v for version\n"); printf("-h for help\n"); printf("tcp_connect <IP> <port>\n"); return 0; }else if (strcmp(argv[1], "tcp_connect") == 0){ /*tcp demo*/ strcpy(tcp_server_ip, argv[2]); strcpy(tcp_server_port, argv[3]); /*initialize functions*/ res = tcp_client_init((unsigned short)atoi(tcp_server_port), tcp_server_ip);//set tcp clinet setting if (res == -1){ printf("###tcp_server_init error###\n"); return -1; } //create thread for TCP communication pthread_create(&tcp_thread_id, NULL, (void *)tcp_client_start, NULL); }else{ printf("Unknown argument %s\n",argv[1]); return -1; } } else{ printf("please input ip and port\r\n"); exit(0); } while(1){ if (i < 100){ i++; }else{ i = 0; } sleep(1); } exit(0); }
.h文件
#ifndef NET_CONTROL_CLINET_H_ #define NET_CONTROL_CLINET_H_ #include <arpa/inet.h> #define TCP_BUFFER_SIZE 1024//max buff of receive buffer for tcp typedef struct{//tcp client class unsigned short server_port; char server_ip[64]; int socket_fd;//socket struct sockaddr_in server_socket_addr; }ts_tcp_client; #endif /* NET_CONTROL_CLINET_H_ */
進(jìn)入 'main.c'文件,然后點(diǎn)擊菜單欄 終端->配置默認(rèn)生成任務(wù)
,系統(tǒng)會(huì)自動(dòng)建立一個(gè)task.json
文件,如下
{ "version": "2.0.0", "tasks": [ { "type": "cppbuild", "label": "C/C++: gcc 生成活動(dòng)文件", "command": "/usr/bin/gcc", "args": [ "-fdiagnostics-color=always", "-g", "${file}", "-o", "${fileDirname}/${fileBasenameNoExtension}", "-lpthread" ], "options": { "cwd": "${fileDirname}" }, "problemMatcher": [ "$gcc" ], "group": { "kind": "build", "isDefault": true }, "detail": "編譯器: /usr/bin/gcc" } ] }
task.json
用來(lái)告訴vscode 怎么去編譯源文件main.c
lablel 定義該任務(wù)的名稱(chēng),后續(xù)調(diào)試會(huì)根據(jù)該名稱(chēng)調(diào)用本任務(wù),這里名為C/C++: gcc 生成活動(dòng)文
args :編譯時(shí)的參數(shù),比如假設(shè)程序依賴(lài) pthread
庫(kù),,那么在這里指定,這里和手動(dòng)在命令行輸入 gcc xxx 命令相同
cwd:指定當(dāng)前運(yùn)行路徑 配置調(diào)試程序
仍然保證 編輯區(qū)打開(kāi)的是main.c
文件,然后點(diǎn)擊菜單欄 運(yùn)行->添加配置
,系統(tǒng)會(huì)自動(dòng)建立一個(gè)launch.json
文件,如下
{ // 使用 IntelliSense 了解相關(guān)屬性。 // 懸停以查看現(xiàn)有屬性的描述。 // 欲了解更多信息,請(qǐng)?jiān)L問(wèn): https://go.microsoft.com/fwlink/?linkid=830387 "version": "0.2.0", "configurations": [ { "name": "gcc - 生成和調(diào)試活動(dòng)文件", "type": "cppdbg", "request": "launch", "program": "${fileDirname}/${fileBasenameNoExtension}", "args": ["tcp_connect","192.168.1.201","8888"],//調(diào)試時(shí)傳遞給程序的命令行參數(shù) "stopAtEntry": true,//是否停留在main函數(shù) "cwd": "${fileDirname}",//調(diào)試程序時(shí)的工作目錄 "environment": [],//環(huán)境變量 "externalConsole": false,//調(diào)試時(shí)是否顯示控制臺(tái)窗口 "MIMode": "gdb",//指定連接的調(diào)試器,可以為gdb或lldb "setupCommands": [ { "description": "為 gdb 啟用整齊打印", "text": "-enable-pretty-printing", "ignoreFailures": true } ], "preLaunchTask": "C/C++: gcc 生成活動(dòng)文件",//調(diào)試開(kāi)始前執(zhí)行的任務(wù),一般為編譯程序 對(duì)應(yīng) tasks.json中的label "miDebuggerPath": "/usr/bin/gdb" } ] }
默認(rèn)內(nèi)容和我貼出來(lái)的略有不同,我增加了一些參數(shù)
launch.json 文件用來(lái)告訴vscode怎么調(diào)用gdb去調(diào)試,指定了一些參數(shù),
preLaunchTask:調(diào)試開(kāi)始前執(zhí)行的任務(wù),一般為編譯程序 對(duì)應(yīng) tasks.json中的label
stopAtEntry": true,//是否停留在main函數(shù)
“args”: [“tcp_connect”,“192.168.1.201”,“8888”],//調(diào)試時(shí)傳遞給程序的命令行參數(shù) 比如我調(diào)試這個(gè)函數(shù)需要在命令行輸入,也就是標(biāo)準(zhǔn)輸入 輸入一些參數(shù),那么填在這里
仍然保證 編輯區(qū)打開(kāi)的是main.c
文件,
點(diǎn)擊菜單欄終端->運(yùn)行生成任務(wù)
或者 ctrl+shift+b
打開(kāi) vscode 側(cè)邊欄 選擇調(diào)試標(biāo)簽
觀察 綠色三角箭頭 右側(cè)的名稱(chēng),與launch.json中
name`一致。
點(diǎn)擊綠色箭頭,或者按F5 進(jìn)入調(diào)試。
在生成配置,或者調(diào)試時(shí),一定要保證當(dāng)前編輯器打開(kāi)的是待調(diào)試的c文件,而不是新建的launch.json
或者tasks.json
上述就是小編為大家分享的Vscode搭建遠(yuǎn)程c開(kāi)發(fā)環(huán)境的過(guò)程是怎樣的了,如果剛好有類(lèi)似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。