linux:

tcpclient.cpp

 #include<iostream>
#include<unistd.h>
#include<sys/types.h>
#include<sys/socket.h>
#include<netdb.h>
#include<arpa/inet.h>
#include<cstring>
#include<sstream> using namespace std; #define BUFSIZE 512 // #define SERVERIP "192.168.41.32"
// #define SERVERPORT 4140 /*error report*/
static void bail(const char *on_what){
fputs(strerror(errno), stderr);
fputs(": ", stderr);
fputs(on_what, stderr);
fputc('\n', stderr);
exit();
} void getarg(int argc,char* argv[],const char** SERVERIP,int* SERVERPORT)
{
for(int i=;i<argc;i++)
{
istringstream iss(argv[i]);
string str;
iss>>str;
if(str=="ip")
{
*SERVERIP=argv[i+];
}
else if(str=="port")
{
istringstream sts(argv[i+]);
string s_port;
sts>>s_port;
*SERVERPORT=stoi(s_port);
}
else
{ } }
} int main(int argc,char *argv[])
{
const char* SERVERIP="192.168.43.230";
int SERVERPORT=; getarg(argc,argv,&SERVERIP,&SERVERPORT); int sockfd;
struct sockaddr_in server_addr;
const char* sendbuf = (char*)"hello,this is client";
char recvbuf[BUFSIZE]; //create socket
if ((sockfd = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP)) <)//创建套接字
{
fprintf(stderr,"Socket error %s\n",strerror(errno));
exit(-);
} memset(&server_addr,, sizeof(server_addr));
server_addr.sin_family = AF_INET;
server_addr.sin_port = htons(SERVERPORT);
server_addr.sin_addr.s_addr = inet_addr(SERVERIP); if ((connect(sockfd, (struct sockaddr*) & server_addr, sizeof(struct sockaddr))) < )//连接远程对等实体
{
fprintf(stderr,"connect error %s\n",strerror(errno));
exit(-);
} if ((send(sockfd, sendbuf, strlen(sendbuf), )) != strlen(sendbuf))//发送数据
{
fprintf(stderr,"send error %s\n",strerror(errno));
exit(-);
} memset(recvbuf, '\0',sizeof(recvbuf));
while (true)
{
int num = recv(sockfd, recvbuf, sizeof(recvbuf), );//接受数据
if (num < )
{
fprintf(stderr,"recv error %s\n",strerror(errno));
exit(-);
}
else
{
cout << recvbuf << endl;
break;
}
} cout<<"exit..."<<endl; close(sockfd);//终止通信并释放套接字描述符 return ;
}

tcpserv.cpp

 #include<iostream>
#include<string.h>
#include <unistd.h>
#include<sys/types.h>
#include<sys/socket.h>
#include<netdb.h>
#include<arpa/inet.h> #define BUFSIZE 512
#define PORT 4140
#define MAXLISTEN 128 /*error report*/
static void bail(const char *on_what){
fputs(strerror(errno), stderr);
fputs(": ", stderr);
fputs(on_what, stderr);
fputc('\n', stderr);
exit();
} int main()
{
int sockfd;//server fd
// int port;
int newfd;//connect fd
struct sockaddr_in server_addr;
struct sockaddr_in client_addr; char reqbuf[BUFSIZE]; /*create server socket*/
if((sockfd=socket(AF_INET,SOCK_STREAM,))<)//创建套接字
{
fprintf(stderr,"Socket error %s\n",strerror(errno));
exit(-);
} /*ready for server addr*/
memset(&server_addr,,sizeof(server_addr));
server_addr.sin_family=AF_INET;
server_addr.sin_addr.s_addr=htonl(INADDR_ANY);
server_addr.sin_port=htons(PORT); /*bind socket addr*/
int tmp=bind(sockfd,(struct sockaddr*)&server_addr,sizeof(server_addr));//将ip和port绑定到套接字上
if(tmp<)
{
fprintf(stderr,"Bind error %s\n",strerror(errno));
exit(-);
} /*listen*/
if((listen(sockfd,MAXLISTEN))<)//将套接字设置为被动模式
{
fprintf(stderr,"Listen error %s\n",strerror(errno));
exit(-);
}
std::cout<<"waiting for client ..."<<std::endl; /*server main while*/
// while(true)
// {
socklen_t size;
size=sizeof(struct sockaddr_in); /*accept client & create new fd*/
if((newfd=accept(sockfd,(struct sockaddr*)&client_addr,&size))<)//接受传入连接请求
{
fprintf(stderr,"Accept error %s\n",strerror(errno));
exit(-);
}
std::cout<<"Server got connect from "<<inet_ntoa(client_addr.sin_addr)<<std::endl; /*recv data from client*/
if((recv(newfd,reqbuf,sizeof(reqbuf),))<)//获取数据
{
fprintf(stderr,"Recv error %s\n",strerror(errno));
exit(-);
}
std::cout<<reqbuf<<std::endl; /*send data to client*/
char *sendbuf=(char*)"hello,this is server.";
if((send(newfd,sendbuf,strlen(sendbuf),))!=strlen(sendbuf))//发送数据
{
fprintf(stderr,"Send error %s\n",strerror(errno));
exit(-);
} /*close new fd*/
close(newfd);//终止通信并释放套接字描述符
// } /*close server fd*/
close(sockfd);//释放套接字描述符 std::cout<<"exit"<<std::endl; return ;
}

udpclient.cpp

 #include<iostream>
#include <unistd.h>
#include<sys/types.h>
#include<sys/socket.h>
#include<netdb.h>
#include<arpa/inet.h>
#include<cstring>
#include<sstream> using namespace std; #define BUFSIZE 512 // #define SERVERIP "192.168.2.169"
// #define SERVERPORT 4140 /*error report*/
static void bail(const char *on_what){
fputs(strerror(errno), stderr);
fputs(": ", stderr);
fputs(on_what, stderr);
fputc('\n', stderr);
exit();
} void getarg(int argc,char* argv[],const char** SERVERIP,int* SERVERPORT)
{
for(int i=;i<argc;i++)
{
istringstream iss(argv[i]);
string str;
iss>>str;
if(str=="ip")
{
*SERVERIP=argv[i+];
}
else if(str=="port")
{
istringstream sts(argv[i+]);
string s_port;
sts>>s_port;
*SERVERPORT=stoi(s_port);
}
else
{ } }
} int main(int argc,char* argv[])
{
const char* SERVERIP="192.168.41.32";
int SERVERPORT=; getarg(argc,argv,&SERVERIP,&SERVERPORT); int sockfd;
struct sockaddr_in server_addr;
struct sockaddr_in client_addr;
char* sendbuf = (char*)"hello,this is client";
char recvbuf[BUFSIZE]; //create socket
if ((sockfd = socket(AF_INET, SOCK_DGRAM,)) <)//创建套接字描述符
{
fprintf(stderr,"socket error %s\n",strerror(errno));
exit(-);
} memset(&server_addr, ,sizeof(server_addr));
server_addr.sin_family = AF_INET;
server_addr.sin_port = htons(SERVERPORT);
server_addr.sin_addr.s_addr = inet_addr(SERVERIP); // if ((connect(sockfd, (struct sockaddr*) & server_addr, sizeof(struct sockaddr))) < 0)
// {
// cout << "Connect Error::" << GetLastError() << endl;
// return -1;
// } if ((sendto(sockfd, sendbuf, strlen(sendbuf), ,(struct sockaddr*)&server_addr,sizeof(struct sockaddr_in))) != strlen(sendbuf))//发送数据
{
fprintf(stderr,"sendto error %s\n",strerror(errno));
exit(-);;
} memset(&client_addr,,sizeof(client_addr));
memset(recvbuf, '\0',sizeof(recvbuf));
while (true)
{
socklen_t len=sizeof(struct sockaddr_in);
int num = recvfrom(sockfd, recvbuf, sizeof(recvbuf), ,(struct sockaddr*)&client_addr,&len);//获取数据
if (num < )
{
fprintf(stderr,"Socket error %s\n",strerror(errno));
exit(-);
}
else
{
cout << recvbuf << endl;
break;
}
} close(sockfd);//终止通信并释放套接字描述符 return ;
}

udpserv.cpp

 #include<iostream>
#include<string.h>
#include <unistd.h>
#include<sys/types.h>
#include<sys/socket.h>
#include<netdb.h>
#include<arpa/inet.h>
// #include<signal.h> #define BUFSIZE 512
#define PORT 4140
#define MAXLISTEN 128 /*error report*/
static void bail(const char *on_what){
fputs(strerror(errno), stderr);
fputs(": ", stderr);
fputs(on_what, stderr);
fputc('\n', stderr);
exit();
} int main()
{
int sockfd;//server fd
// int port;
int newfd;//connect fd
struct sockaddr_in server_addr;
struct sockaddr_in client_addr; char reqbuf[BUFSIZE]; /*create server socket*/
if((sockfd=socket(AF_INET,SOCK_DGRAM,))<)//创建套接字描述符
{
fprintf(stderr,"Socket error %s\n",strerror(errno));
exit(-);
} /*ready for server addr*/
memset(&server_addr,,sizeof(server_addr));
server_addr.sin_family=AF_INET;
server_addr.sin_addr.s_addr=htonl(INADDR_ANY);
server_addr.sin_port=htons(PORT); /*bind socket addr*/
if((bind(sockfd,(struct sockaddr*)&server_addr,sizeof(server_addr)))<)//将ip和port绑定到套接字上
{
fprintf(stderr,"Bind error %s\n",strerror(errno));
exit(-);
} /*server main while*/
// while(true)
// {
socklen_t size;
size=sizeof(struct sockaddr_in);
memset(&client_addr,,sizeof(client_addr)); /*recv data from client*/
if((recvfrom(sockfd,reqbuf,sizeof(reqbuf),,(struct sockaddr*)&client_addr,&size))<)//获取数据
{
fprintf(stderr,"Recvfrom error %s\n",strerror(errno));
exit(-);
}
std::cout<<reqbuf<<std::endl; /*send data to client*/
char *sendbuf=(char*)"hello,this is server.";
if((sendto(sockfd,sendbuf,strlen(sendbuf),,(struct sockaddr*)&client_addr,size))!=strlen(sendbuf))//发送数据
{
fprintf(stderr,"Sendto error %s\n",strerror(errno));
exit(-);
} // } /*close server fd*/
close(sockfd);//终止通信并释放套接字描述符 std::cout<<"exit"<<std::endl; return ;
}

windows:

tcpclient.cpp

 #include<iostream>
#include<WinSock2.h>
#include<cstring>
#include<sstream> #pragma comment(lib, "ws2_32") using namespace std; // #define SERVERIP "192.168.41.32"
// #define SERVERPORT 4140 void getarg(int argc,char* argv[],const char** SERVERIP,int* SERVERPORT)
{
for(int i=;i<argc;i++)
{
istringstream iss(argv[i]);
string str;
iss>>str;
if(str=="ip")
{
*SERVERIP=argv[i+];
}
else if(str=="port")
{
istringstream sts(argv[i+]);
string s_port;
sts>>s_port;
*SERVERPORT=stoi(s_port);
}
else
{ } }
} int main(int argc,char *argv[])
{
const char* SERVERIP="192.168.41.32";
int SERVERPORT=; getarg(argc,argv,&SERVERIP,&SERVERPORT); SOCKET sockfd;
struct sockaddr_in server_addr;
WSADATA ws;
const char* sendbuf = (char*)"hello,this is client";
char recvbuf[MAX_PATH]; //init windows socket
if (WSAStartup(MAKEWORD(, ), &ws) != )
{
cout << "Init Windows Socket Failed::" << GetLastError() << endl;
return -;
} //create socket
if ((sockfd = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP)) == INVALID_SOCKET)//创建套接字描述符
{
cout << "Create Socket Failed::" << GetLastError() << endl;
return -;
} ZeroMemory(&server_addr, sizeof(server_addr));
server_addr.sin_family = AF_INET;
server_addr.sin_port = htons(SERVERPORT);
server_addr.sin_addr.S_un.S_addr = inet_addr(SERVERIP); if ((connect(sockfd, (struct sockaddr*) & server_addr, sizeof(struct sockaddr))) < )//连接远程对等实体
{
cout << "Connect Error::" << GetLastError() << endl;
return -;
} if ((send(sockfd, sendbuf, strlen(sendbuf), )) != strlen(sendbuf))//发送数据
{
cout << "Send Error::" << GetLastError() << endl;
return -;
} ZeroMemory(recvbuf, sizeof(recvbuf));
while (true)
{
int num = recv(sockfd, recvbuf, sizeof(recvbuf), );//获取数据
if (num < )
{
cout << "Recv Error::" << GetLastError() << endl;
return -;
}
else
{
cout << recvbuf << endl;
break;
}
} cout<<"exit..."<<endl; closesocket(sockfd);//终止通信并释放套接字
WSACleanup(); system("pause"); return ;
}

tcpserver.cpp

 #include<iostream>
#include<WinSock2.h>
// #include<cstring>
// #include<unistd.h> #pragma comment(lib, "ws2_32") using namespace std; #define BUFSIZE 512
#define PORT 4140
#define MAXLISTEN 128 /*error report*/
static void bail(const char *on_what){
fputs(strerror(errno), stderr);
fputs(": ", stderr);
fputs(on_what, stderr);
fputc('\n', stderr);
exit();
} int main()
{
SOCKET sockfd;//server fd
// int port;
SOCKET newfd;//connect fd
struct sockaddr_in server_addr;
struct sockaddr_in client_addr;
WSADATA ws; char reqbuf[BUFSIZE]; //init windows socket
if(WSAStartup(MAKEWORD(,),&ws)!=)
{
cout << "Init Windows Socket Failed::" << GetLastError() << endl;
exit(-);
} /*create server socket*/
if((sockfd=socket(AF_INET,SOCK_STREAM,))==INVALID_SOCKET)//创建套接字描述符
{
fprintf(stderr,"Socket error %s\n",strerror(errno));
exit(-);
} /*ready for server addr*/
ZeroMemory(&server_addr,sizeof(server_addr));
ZeroMemory(&reqbuf,sizeof(reqbuf));
server_addr.sin_family=AF_INET;
server_addr.sin_addr.S_un.S_addr=htonl(INADDR_ANY);
server_addr.sin_port=htons(PORT); /*bind socket addr*/
int tmp=bind(sockfd,(struct sockaddr*)&server_addr,sizeof(server_addr));//将ip和port绑定到套接字上
if(tmp<)
{
fprintf(stderr,"Bind error %s\n",strerror(errno));
exit(-);
} /*listen*/
if((listen(sockfd,MAXLISTEN))<)//设置为被动模式
{
fprintf(stderr,"Listen error %s\n",strerror(errno));
exit(-);
}
cout<<"waiting for client ..."<<endl; /*server main while*/
// while(true)
// {
int size;
size=sizeof(struct sockaddr_in); /*accept client & create new fd*/
if((newfd=accept(sockfd,(struct sockaddr*)&client_addr,&size))<)//接受传入请求
{
fprintf(stderr,"Accept error %s\n",strerror(errno));
exit(-);
}
cout<<"Server got connect from "<<inet_ntoa(client_addr.sin_addr)<<endl; /*recv data from client*/
if((recv(newfd,reqbuf,sizeof(reqbuf),))<)//获取数据
{
fprintf(stderr,"Recv error %s\n",strerror(errno));
exit(-);
}
cout<<reqbuf<<endl; /*send data to client*/
char *sendbuf=(char*)"hello,this is server.";
if((send(newfd,sendbuf,strlen(sendbuf),))!=strlen(sendbuf))//发送数据
{
fprintf(stderr,"Send error %s\n",strerror(errno));
exit(-);
} /*close new fd*/
closesocket(newfd);//终止通信并释放套接字
// } /*close server fd*/
closesocket(sockfd);//释放套接字
WSACleanup(); cout<<"exit"<<endl; return ;
}

udpclient.cpp

 #include<iostream>
#include<WinSock2.h>
#include<sstream> #pragma comment(lib, "ws2_32") using namespace std; // #define SERVERIP "192.168.2.169"
// #define SERVERPORT 4140 void getarg(int argc,char* argv[],const char** SERVERIP,int* SERVERPORT)
{
for(int i=;i<argc;i++)
{
istringstream iss(argv[i]);
string str;
iss>>str;
if(str=="ip")
{
*SERVERIP=argv[i+];
}
else if(str=="port")
{
istringstream sts(argv[i+]);
string s_port;
sts>>s_port;
*SERVERPORT=stoi(s_port);
}
else
{ } }
} int main(int argc,char* argv[])
{
const char* SERVERIP="192.168.41.32";
int SERVERPORT=; getarg(argc,argv,&SERVERIP,&SERVERPORT); SOCKET sockfd;
struct sockaddr_in server_addr;
struct sockaddr_in client_addr;
WSADATA ws;
char* sendbuf = (char*)"hello,this is client";
char recvbuf[MAX_PATH]; //init windows socket
if (WSAStartup(MAKEWORD(, ), &ws) != )
{
cout << "Init Windows Socket Failed::" << GetLastError() << endl;
return -;
} //create socket
if ((sockfd = socket(AF_INET, SOCK_DGRAM,)) == INVALID_SOCKET)//创建套接字描述符
{
cout << "Create Socket Failed::" << GetLastError() << endl;
return -;
} ZeroMemory(&server_addr, sizeof(server_addr));
server_addr.sin_family = AF_INET;
server_addr.sin_port = htons(SERVERPORT);
server_addr.sin_addr.S_un.S_addr = inet_addr(SERVERIP); // if ((connect(sockfd, (struct sockaddr*) & server_addr, sizeof(struct sockaddr))) < 0)
// {
// cout << "Connect Error::" << GetLastError() << endl;
// return -1;
// } if ((sendto(sockfd, sendbuf, strlen(sendbuf), ,(struct sockaddr*)&server_addr,sizeof(struct sockaddr_in))) != strlen(sendbuf))//发送数据
{
cout << "Send Error::" << GetLastError() << endl;
return -;
} ZeroMemory(&client_addr,sizeof(client_addr));
ZeroMemory(recvbuf, sizeof(recvbuf));
while (true)
{
int len=sizeof(struct sockaddr_in);
int num = recvfrom(sockfd, recvbuf, sizeof(recvbuf), ,(struct sockaddr*)&client_addr,&len);//获取数据
if (num < )
{
cout << "Recv Error::" << GetLastError() << endl;
return -;
}
else
{
cout << recvbuf << endl;
break;
}
} closesocket(sockfd);//终止通信并释放套接字
WSACleanup(); system("pause"); return ;
}

udpserver.cpp

 #include<iostream>
#include<winsock2.h>
// #include<string.h>
// #include<unistd.h> #pragma comment(lib, "ws2_32") using namespace std; #define BUFSIZE 512
#define PORT 4140
#define MAXLISTEN 128 /*error report*/
static void bail(const char *on_what){
fputs(strerror(errno), stderr);
fputs(": ", stderr);
fputs(on_what, stderr);
fputc('\n', stderr);
exit();
} int main()
{
int sockfd;//server fd
// int port;
int newfd;//connect fd
WSADATA ws;
struct sockaddr_in server_addr;
struct sockaddr_in client_addr; char reqbuf[BUFSIZE]; // signal(SIGINT,my_handler); //init windows socket
if(WSAStartup(MAKEWORD(,),&ws)!=)
{
cout << "Init Windows Socket Failed::" << GetLastError() << endl;
exit(-);
} /*create server socket*/
if((sockfd=socket(AF_INET,SOCK_DGRAM,))<)//创建套接字描述符
{
fprintf(stderr,"Socket error %s\n",strerror(errno));
exit(-);
} /*ready for server addr*/
ZeroMemory(&server_addr,sizeof(server_addr));
server_addr.sin_family=AF_INET;
server_addr.sin_addr.S_un.S_addr=htonl(INADDR_ANY);
server_addr.sin_port=htons(PORT); /*bind socket addr*/
if((bind(sockfd,(struct sockaddr*)&server_addr,sizeof(server_addr)))==INVALID_SOCKET)//将ip和port绑定到套接字上
{
fprintf(stderr,"Bind error %s\n",strerror(errno));
exit(-);
} /*server main while*/
// while(true)
// {
int size;
size=sizeof(struct sockaddr_in);
memset(&client_addr,,sizeof(client_addr)); /*recv data from client*/
if((recvfrom(sockfd,reqbuf,sizeof(reqbuf),,(struct sockaddr*)&client_addr,&size))<)//获取数据
{
fprintf(stderr,"Recvfrom error %s\n",strerror(errno));
exit(-);
}
cout<<reqbuf<<endl; /*send data to client*/
char *sendbuf=(char*)"hello,this is server.";
if((sendto(sockfd,sendbuf,strlen(sendbuf),,(struct sockaddr*)&client_addr,size))!=strlen(sendbuf))//发送数据
{
fprintf(stderr,"Sendto error %s\n",strerror(errno));
exit(-);
} // } /*close server fd*/
closesocket(sockfd);//终止通信并释放套接字
WSACleanup(); cout<<"exit"<<endl; return ;
}

参考:

基于Linux平台实现的流式套接字客户端服务器端代码

基于linux或windows平台上的c/s简单通信的更多相关文章

  1. Windows平台上Caffe的训练与学习方法(以数据库CIFAR-10为例)

    Windows平台上Caffe的训练与学习方法(以数据库CIFAR-10为例) 在完成winodws平台上的caffe环境的搭建之后,亟待掌握的就是如何在caffe中进行训练与学习,下面将进行简单的介 ...

  2. 基于linux或windows的c/s的循环服务器求一元二次方程的根

    在linux和windows上实现 c/s模式 socket循环服务器求解一元二次方程的根 ax^2+bx+c=0 根据上式,客户端发送a,b,c给服务器,返回求解的根 暂未考虑非法数据等问题 lin ...

  3. nginx 在windows平台上对asp.net做反向代理

    代理服务器 当客户机向站点提出请求时,请求将转到代理服务器.然后,代理服务器通过防火墙中的特定通路,将客户机的请求发送到内容服务器.内容服务器再通过该通道将结果回传给代理服务器.代理服务器将检索到的信 ...

  4. windows平台上MongoDB安装配置

    我按照原文方法操作,无法连接mongod服务,可能哪里出了问题. 以下是小页的教程:https://www.cnblogs.com/littlepage/p/10992336.html  视频参考: ...

  5. Windows平台上C++开发内存泄漏检查方法

    充分的利用调试工具可以非常方便地避免内存泄漏问题. 这里介绍两种方法,互为补充,第一种是VC编译器提供的方法,第二种是专用的内存泄漏检查工具Memmory Validator.这两种方法的基本原理是一 ...

  6. windows平台上用python 远程线程注入,执行shellcode

    // 转自: https://blog.csdn.net/Jailman/article/details/77573990import sys import psutil import ctypes ...

  7. Windows平台上的pip安装

    写在前面 pip 是 Python 的包管理工具,在 Python 开发中必不可少.作为一名python菜鸟,本文在踩坑无数的基础上尽可能详细地解释pip的安装过程.在安装之前需要明确两点: 1.pi ...

  8. windows平台下 c/c++进行http通信的教训

    由于需要使用c++开发一个桌面应用软件,需要用到http请求进行通讯,也是本人第一次进行网络相关的开发工作,遇到了不少坑. 由于是在windows下开发和使用的应用软件,自然而然想到了调用Window ...

  9. 基于node的tcp客户端和服务端的简单通信

    1.简单介绍下TCP/IP TCP/IP是互联网相关协议的集合,分为以下四层:应用层.传输层.网络层.数据链路层. 分成四层的好处是,假如只有一层,某个地方需要改变设计时,就必须把所有整体替换掉,而分 ...

随机推荐

  1. Journal of Proteome Research | iHPDM: In Silico Human Proteome Digestion Map with Proteolytic Peptide Analysis and Graphical Visualizations(iHPDM: 人类蛋白质组理论酶解图谱的水解肽段分析和可视化展示)| (解读人:邓亚美)

    文献名:iHPDM: In Silico Human Proteome Digestion Map with Proteolytic Peptide Analysis and Graphical Vi ...

  2. 关于git 远程仓库账户密码错误的问题

    主要是电脑凭证把第一次输入的账户密码记录了下来,在控制面板->用户账户->凭据管理器里, 选择windows凭证, 你会找到git:凭据,直接删掉或者更改都可以! 对应的Git的凭证,删除 ...

  3. 初步了解HTTP协议

    1.HTTP简介 全称:Hyper Text  Transfer Protocol,中文名:超文本传输协议. 功能:HTTP是客户端浏览器或其他程序与web服务器之间的应用层通信协议. 特点:a.支持 ...

  4. JavaScript----简介及基础语法

    ##JavaScript *概念:一门客户端脚本语言 *运行在客户端浏览器中的.每一个浏览器都有JavaScript的解析引擎. *脚本语言:不需要编译,直接就可以被浏览器解析执行. *功能: *可以 ...

  5. 【干货】Keras学习资源汇总

    目录: Keras简介 Keras学习手册 Keras学习视频 Keras代码案例 Keras&NLP Keras&CV Keras项目 一.Keras简介 Keras是Python中 ...

  6. Python第七章-面向对象

    面向对象编程基础 一.面向对象概念 1.1 什么是面向过程 ​ 就是分析出解决问题所需要的步骤,然后用函数把这些步骤一步一步实现,使用的时候一个一个依次调用就可以了. ​ 生活中的的例子举例. 1.2 ...

  7. php 设置允许跨域请求

    php 服务端代码 <?php header('Content-Type: text/html;charset=utf-8'); header('Access-Control-Allow-Ori ...

  8. PTA-7-20 表达式转换(中缀转后缀,带括号,负数,小数转换)

    本题考点:中缀表达式转后缀表达式. 难点: 带有小数的数字 数字可能带有正负号 题目描述: 算术表达式有前缀表示法.中缀表示法和后缀表示法等形式.日常使用的算术表达式是采用中缀表示法,即二元运算符位于 ...

  9. 初始化一个vue项目

    1.安装node 端开发框架和环境都是需要 Node.js ,先安装node.js开发环境,vue的运行是要依赖于node的npm的管理工具来实现,下载https://nodejs.org/en/,安 ...

  10. pycharm 2.7 快捷键

    提示 CTRL Q: 在参数列表位置,显示可以输入的所有参数 CTRL Q: 查看选中方法的文档字符串 阅读 CTRL -: 折叠当前代码 CTRL +: 展开当前代码 CTRL SHIFT -: 折 ...