python TCP服务端接受数据时recv函数非阻塞究竟如何实现? 15C

这是TCP服务端代码:

import socket
import threading

s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.bind(('127.0.0.1', 9998))
s.listen(5)
print('Waiting for connection')


def tcplink(sock, addr):
    print('Accept new connection from %s:%s...' % addr)
    sock.send(b'Welcome!')
    buffer = []
    while True:      #接受数据时就卡在这里了
        d = sock.recv(1024)
        if not d:
            break 
        else:
            buffer.append(d)
    sock.send('get it!'.encode('utf-8'))
    print((b''.join(buffer)).decode('utf-8'))
    sock.close()
    print('Connection from %s:%s closed.' % addr)

while True:
    sock, addr = s.accept()
    t = threading.Thread(target=tcplink, args=(sock, addr))
    t.start()

客户端代码:

import socket

s = socket.socket(socket.AF_INET,socket.SOCK_STREAM) 

s.send(b'nihao')
buffer = []
while True:
    d = s.recv(1024)
    if not d:
        break
    else:
        buffer.append(d)
data = b''.join(buffer)
s.close()

print(data.decode('utf-8'))

上网查了很多方式比如settimeout,MSG_DONTWAIT,都失败了,如何修改代码才能正常接受数据呢?求详细一点的说明,谢谢!

1个回答

我翻到一个写好的代码 你客户端 没有连接
服务端 :
import socket
import time

s = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
s.bind(("localhost",5555))
s.listen(5)#最大连接5 监听
print("服务器已经运行。。。")
def tcp(sock,addr):
print("接受新的连接请求:",addr)
while True:
data = sock.recv(1024)
time.sleep(1)
if not data or data.decode()=="quit":
break
sock.send(data.decode("utf-8").upper().encode())
sock.close()
print("关闭%s的连接" % addr)
while True:
sock,addr = s.accept()#等待接受
tcp(sock,addr)
#这里是等待下一个连接
客户端:
s = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
s.connect(("localhost",5555))
while True:
data = input("输入你要发送的数据:")
s.send(data.encode())
if data=="quit":
break
print(s.recv(1024).decode("utf-8"))

s.close()

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
winsocket send函数和recv函数分别设置为阻塞和非阻塞

在winsocket中能不能分别把send函数和recv函数一个设置成阻塞一个设置成非阻塞状态而互不影响。还是说他们的阻塞状态统一由同一个socket来设定。此外,能不能预先知道send所对应的缓冲区的可用大小(不是缓冲区大小),或者说有什么办法可以知道这个socket已经从网口发送出去的数据大小。

TCP服务端接收数据问题

VB的TCP数据在接收时,如果客户端发过来的数据差不多在同一时刻怎么办啊?我现在就遇到这样的问题,导致接收的数据老是错误。由于我的服务端只是被动接收数据,没办法控制客户端发送数据的时间,请教高人求处理,谢谢。 如果在同时只处理任何一个客户端的数据都没有问题。 Private Sub TcpServer_DataArrival(index As Integer, ByVal bytesTotal As Long) Dim i As Integer 'Dim j As Integer Dim RData As String Dim Recv() As Byte TcpServer(index).GetData Recv(), vbByte If UBound(Recv()) > 0 Then For i = 0 To UBound(Recv()) RData = RData & CStr(add_zero(Hex(Recv(i)), 2)) Next i End If If Len(RData) < 4 Then Exit Sub If Left(RData, 6) = "FA0101" And TcpServer(index).Tag <> "" Then '数据处理 RData = Right(RData, Len(RData) - 6) Text2.Text = RData Select Case Mid(TcpServer(index).Tag, 13, 2) Case "DS" Call Data_do(RData, "DS", "10", index) Case "CO" Call Data_do(RData, "CO", "01", index) Case "GU" End Select End If End Sub 或者使用多线程来处理这个的话该怎么实现?

windows socket编程客户端怎么使用recv函数接受服务器发送的大数据

我写了个客户端接受服务器的数据,用recv接收,当缓冲区的大小小于发送的数据的大小后 要怎么处理recv函数,本人刚开始学习socket编程,还望大神们赐教啊!!!!!

LWIP下,TCP接收数据过程中插拔网线,sock未非阻塞状态,但RECV堵塞

各位大神。。。帮帮我呗。。。我特别困惑 我在STM32F2系列下用select方式开发TCP服务端,每个服务端可以接收多个链接, 我每个链接都设置成了非阻塞模式,在TCP通讯过程中反复插拔网线,偶尔会出现SELECT任务被挂起的情况,我加了mark,在recv前的mark = recv后mark+1,然后任务被挂起。。。。请帮帮我

服务端 用WSASEND发送数据 客户端RECV成功了 为什么服务端还没有收到IOCP完成通知

# 服务端 用WSASEND发送数据 客户端RECV成功了 为什么服务端还没有收到IOCP完成通知 只有等客户端closesocket 服务端才完全收到所有WSASEND通知 真奇怪

TCP、UDP通信:recv和recvfrom同时阻塞

当客户端登录时,创建一个线程接收服务器的消息(比如,密码错误时,服务器会发送消息告知客户端密码错误)。 DWORD Client_Thread() { .... recv(); //接收服务器的消息,如密码是否正确,或者某一个客户端的地址和端口号等 .... } 服务器为每一个客户端创建一个线程(该线程可以判断密码是否正确)。 DWORD Server_Thread() { ... recv(); //接收客户端的消息,如账号和密码,请求朋友的地址和端口号 ... ... send(); //发送相关信息给客户端,如朋友的地址和端口号 ... } 现在的情况是,客户端如果想跟他的其中一个好友聊天,那么就向服务器发送消息, 要求服务器返回该好友的ip地址和端口号,同时客户端又新建一个线程接收好友的信息。 DWORD Chat_Thread() { while(1) { revcfrom(); //接收好友的信息 } } 客户端发送消息给好友使用UDP协议。 void Send() { ... sendto(); //发送信息给好友 } 现在的问题是,客户端的Cient_Thread线程函数中的recv和Chat_Thread线程函数中的recvfrom同时处于阻塞状态。 当朋友发送信息时,recv收到了信息,而recvfrom没有收到。 我想要的是recvfrom收到,recv不接收。有什么办法可以实现这样的功能吗?或者怎样改?谢谢!!!!

关于recv()和send()函数

比如说,先用send()函数发了一段数据,然后用send()发了另一段数据,另一端,也分别用了两个recv()接收,那这两段数据是不是一定会被正确接收,第一个recv()接收第一段数据,第二个recv()接收第二段数据,还是第一个可能会收到第二个的一部分,或第二个也可能受到第一个的一部分呢?

关于windows下socket编程的recv函数

Talk is cheap,show me the code. do{ # memset(buf, 0, BUFSIZ); # strLen = recv(reads.fd_array[i], buf, BUFSIZ - 1, 0); if (strLen == 0 || strLen == -1){ FD_CLR(reads.fd_array[i], &reads); closesocket(cpyReads.fd_array[i]); printf("closed client:%d \n", cpyReads.fd_array[i]); } else{ printf("From %d : %s", cpyReads.fd_array[i], buf); //send(reads.fd_array[i], buf, strLen, 0); } # } while (strLen==BUFSIZ-1); 我设置的BUFSIZ 是10 我在调用recv函数来取客户端发过来的数据时,如果收到的数据长度大于我设置的缓冲大小也就是BUFSIZ 比如发过来的是10个字符 , 那么do while 循环会循环两次,如果我发送过来的正好是9个字符 , 为啥只循环了一次呢。我调试看到 strLen 明明等于BUFSIZ-1 的 , 于是在上面的memset处加的断点,才知道确实是循环了两次, 可是执行到 recv函数的时候 整个循环直接跳出来了,不太明白这里,求大神讲解一下,站等。。。

SOCKET SEND后等待服务器返回RECV卡死

我程序里有一个一直运行着的RECV,还有一个SEND后的RECV,一直运行着的RECV能接受到数据 SEND后等待服务器返回就会卡死 NetSocket *netSocket = (NetSocket *)lparam; //SOCKET socketTCP = (SOCKET)lparam; int loop = 0; char bufRecv[MAX_PACKET]; char tempBuf[4096]; unsigned char* backData = new unsigned char[3036]; while (1){ int flag = recv(netSocket->pThis->socketTCP, bufRecv, strlen(bufRecv)+1, 0); //int flag = recv(socketTCP, bufRecv, strlen(bufRecv) + 1, 0); if (flag > 0){ int temp12 = strlen(bufRecv); for (int i = 0; i<MAX_PACKET; i++){ tempBuf[i] = bufRecv[i]; } while (temp12>MAX_PACKET){ loop++; flag = recv(netSocket->pThis->socketTCP, bufRecv, MAX_PACKET, 0); //flag = recv(socketTCP, bufRecv, MAX_PACKET, 0); //temp12 = strlen(bufRecv) - MAX_PACKET*loop; temp12 = strlen(bufRecv); for (int i = 0; i < flag; i++){ tempBuf[i + MAX_PACKET*loop] = bufRecv[i]; } } //backData = (unsigned char*)tempBuf; string backStr = "recv data from server "; backStr += tempBuf; //backData = new unsigned char[3036]; int i = 0; for (i = 0; i < backStr.length(); i++){ backData[i] = backStr[i]; } backData[i] = '\0'; //netSocket->pThis->index = netSocket->pThis->findIndexNum(backData); } } return 0; 这个可以接受到服务器的回应 result = send(socketTCP, (const char*)(char*)(sByte+offset), size, 0); if (result < 0){ DWORD a = GetLastError(); ResumeThread(recvThread); ReleaseMutex(hMutex); return result; } Sleep(100); //等待服务器响应 int loop = 0; char bufRecv[MAX_PACKET]; char tempBuf[4096]; int flag = recv(socketTCP, bufRecv, sizeof(bufRecv), 0); if (flag < 0){ DWORD a = GetLastError(); ResumeThread(recvThread); ReleaseMutex(hMutex); return flag; } 这个就卡死了

非阻塞模式下转发数据丢失问题

写了一个tcp代理,用epoll+ 非阻塞调用来增加请求量 现在遇到一个问题 tc p代理转发http请求,数据是正常的,某些图片加载不出来; 转发https小数据也是正常的,但是网页数据量大的话网页就加载不出来;这是什么原因的,有什么解决办法吗

macos 中 python tcp客户端下载文件

在mac系统中 用vs code 编写了 tpc客户端下载文件,但是在vs code直接运行 程序能够正常运行但没有能下载到文件,而在系统终端内运行程序,则可以正常 下载文件。为什么会这样,代码如下: ```python import socket def main(): # 1. 创建套接字 tcp_socket = socket.socket(socket.AF_INET,socket.SOCK_STREAM) # 2. 获取服务器的ip port dest_ip = input("请输入下载服务器的ip:") dest_port = int(input("请输入下载服务器的port:")) # 3. 链接服务器 tcp_socket.connect((dest_ip,dest_port)) # 4. 获取下载的文件名字 download_file_name = input("请输入要下载的文件名:") # 5. 将文件名字发送到服务器 tcp_socket.send(download_file_name.encode("utf-8")) # 6. 接收文件中的数据 recv_data = tcp_socket.recv(1024) print(recv_data.decode("gbk")) # 7. 保存接收的数据到一个文件中 with open("附件" + download_file_name,"wb") as f: f.write(recv_data) print("download succussful!") # 8. 关闭套接字 tcp_socket.close() if __name__ == "__main__": main() ```

完成端口,接收数据不完全,recv返回0

一个项目,使用完成端口,SOCKET的套接字。recv函数返回0。 具体问题是这样的,我能接收大部分数据,但是每次都少了1436个比特。我看了一下,是因为recv返回0。 然后,我看到网上说这个函数,说是连接被关闭了。我又在发送端发送完了之后,调用shutdown,而不是用的closesocket。 接收端部分代码: while (true) { RtlZeroMemory(fileBuf, DATA_BUFSIZE); nlen = recv(perHandleData->socket, fileBuf, DATA_BUFSIZE, 0); fileInfo->file.Write(fileBuf, nlen); fileCount += nlen; if (fileCount >= fileInfo->dwFileSize||nIndex>=10) { break; } if (nlen == 0) { nIndex++; } } ``` ``` 我发送端用的是循环发送,接收端用的是循环接收。接收端跳出有两种情况,全部接受和recv返回了0。其实只要recv返回了一次0的话,就可以直接跳出循环的了。我这里还是用的十次。 而发送端并没有closesocket,只是调用shutdown停止发送。 请问,我接受不全,是什么原因啊?我看到网上说的另一种情况是:recv函数在等待协议接收数据时网络中断了。 具体是什么原因我也不清楚。请哪位大牛帮帮忙! 分不多,麻烦啦

python服务端已写,对应怎么写java客户端?

以下是python服务端的代码: ``` import SocketServer import traceback class ServerHandler(SocketServer.StreamRequestHandler): def handle(self): addr = self.request.getpeername() print("client connect,address:",addr) #self.wfile.write("this is server") #self.request.send("this is server") while True: try: #data = self.rfile.readline()strip() data = self.request.recv(1024) print(data) except: traceback.print_exc() break server = SocketServer.ThreadingTCPServer(('',6000),ServerHandler) server.serve_forever() ```

SOCKET RECV函数卡死,TIMER线程挂起的时候消息队列会保存吗

有两个RECV,一个在SEND里面,一个在另外一个线程里面 recv(netSocket->pThis->socketTCP, bufRecv, strlen(bufRecv)+1, 0); send主线程中 int flag = recv(socketTCP, bufRecv, MAX_PACKET, 0); int temp12 = strlen(bufRecv); 主线程中的RECV会卡死直到收到TIEMR事件(另外一个线程调用的)

TCP 非阻塞套接字 发送文件数据会丢失

用以下函数将套接字设置为非阻塞套接字 bool setSockNoBlock(SOCKET s) { bool flg=true; if (::ioctlsocket(s, FIONBIO, (unsigned long *)&flg)==0) { cout<<"socket"<<s<<"已设置为非阻塞模式!"<<endl; return true; } return false; } 发送文件代码: bool sendFile(SOCKET s,char *fileName) { CWGFILE wgSendFile; char buf[WG_MAX_TCPBUF]; ZeroMemory(buf,WG_MAX_TCPBUF); int len=0; int fileLen=0; int count=0; double timeCount; CTimer t; if (wgSendFile.WG_FileOpen(fileName,WG_FILE_READ)) { t.Start(); while((len=wgSendFile.WG_FileRead(buf))>0) { fileLen+=len; send(s,buf,len,0); /*Sleep(1);*/ // cout<<count<<":"<<len<<" "; count++; if (fileLen == wgSendFile.WG_FileLen()) { timeCount = t.End(); cout<<"发送时间:"<<(double)(timeCount/1000.0)<<"S"<<endl; cout<<"发送速度:"<<(double)(fileLen/1024.0/1024.0)/(timeCount/1000.0)<<"M/S"<<endl; return wgSendFile.WG_FileClose(), true; } ZeroMemory(buf,WG_MAX_TCPBUF); } } return false; } 接收数据方代码: do { nRet = recv(sockClient,buf,WG_MAX_TCPBUF,0); if (nRet>0) { len+=nRet; wgRecvFile.WG_FileWrite(buf,nRet); ZeroMemory(buf,WG_MAX_TCPBUF); //cout<<count<<":"<<nRet<<" "; count ++; if (len == 941473792 )//本应该接收的数据长度 { cout<<"\n接受终于完了!"<<endl; break; } } if (nRet==0) { cout<<"\n服务器断开了,共接收数据:"<<len<<endl; break; } } while (nRet!=0);

安卓 和python 服务端通信,安卓收不到服务端返回

用安卓和python的服务端通过socket进行通信, server端可以接收信息,但无法返回到安卓。 安卓 ``` try{ //port number 8888 Socket s1=new Socket(ipAdress,8883); OutputStream os=s1.getOutputStream(); DataOutputStream dos=new DataOutputStream(os); dos.writeUTF(etxtUserName.getText().toString() + " " + etxtPassword.getText().toString());// send usr_name and pwd to server //wait new Handler().postDelayed(new Runnable(){ public void run() { //execute the task } }, 1000); dos.flush(); s1.shutdownOutput(); // InputStream is=s1.getInputStream(); DataInputStream dis=new DataInputStream(is); String getStr=dis.readUTF();//YES or NO //String getStr = "YES"; if(getStr.equals("YES")){ intent.setClass(LogInActivity.this, personalActivity.class); LogInActivity.this.startActivity(intent); ``` python server ``` import socket # 导入 socket 模块 from time import ctime import time port = 8883 # 设置端口 host = socket.gethostname() # 获取本地主机名 BUFSIZE = 1024 tcp_socket = socket.socket() # 创建 socket 对象 tcp_socket.bind((host, port)) # 绑定端口 tcp_socket.listen(5) # 等待客户端连接 while True: tcpcli_socket, addr = tcp_socket.accept() # 建立客户端连接。 print ('连接地址:', addr) #c.send('we are top 1 group') data = tcpcli_socket.recv(BUFSIZE) print (data) tcpcli_socket.send("YES".encode('utf-8')) print ('done') tcpcli_socket.close() # 关闭连接 ``` 报错信息 ``` W/System.err: java.io.EOFException at java.io.DataInputStream.readFully(DataInputStream.java:200) at java.io.DataInputStream.readUTF(DataInputStream.java:606) at java.io.DataInputStream.readUTF(DataInputStream.java:561) at com.example.tianmingyang.carpool.LogInActivity$MyButtonOnClickListener.onClick(LogInActivity.java:78) at android.view.View.performClick(View.java:6294) ```

python用socket解析数据包的问题

用python做个抓包工具,下面有写代码不明白,请老师指点一下. ``` while True: packet = s.recvfrom(65565) packet = packet[0] ip_header = packet[0:20] iph = unpack('!BBHHHBBH4s4s' , ip_header) version_ihl = iph[0] version = version_ihl >> 4 ihl = version_ihl & 0xF iph_length = ihl * 4 ttl = iph[5] protocol = iph[6] s_addr = socket.inet_ntoa(iph[8]); d_addr = socket.inet_ntoa(iph[9]); ``` 问题1:这里面的iph = unpack('!BBHHHBBH4s4s' , ip_header)是什么意思,必须是BBHHHBBH4s4s吗? 问题2:version = version_ihl >> 4是什么意思? '>>'是什么符号? 问题3:ihl = version_ihl & 0xF是什么意思? 问题4:s_addr = socket.inet_ntoa(iph[8])是转换ip的吗? 本人初学python,没有分数,请各位老师不吝赐教,万分感激.

python raw socket构造packet后能send,但是recv不了?

s = socket.socket(socket.AF_INET, socket.SOCK_RAW, socket.IPPROTO_RAW) # IP Header ipobj = IP(src_host, dst_host) iph = ipobj.pack() # TCP Header tcpobj = TCP(1234, 80) tcpobj.data_length = len(data) # Used in pseudo header tcph = tcpobj.pack(ipobj.source, ipobj.destination) # Injection packet = iph + tcph + data #构造好的packet s.sendto(packet,(dst_host,80)) #s.connect((dst_host,80))不管是用send()还是sendto()都能发出去 response=s.recvfrom(1024)[0][0:] #但是就是卡在这儿了,一直没有收到信息,不管是用recv()还是recvfrom() #response=s.recv(1024) if response: ip = ipobj.unpack(response) response = response[ip.ihl:] tcp = tcpobj.unpack(response) print "IP Header:", ip.list print "TCP Header:", tcp.list 问题就是:构造的packet能够发出去,但是就是recv()没有收到任何信息,就一直卡在那里,加个settimeout的话,全部都是超时。我是想写个tcp syn扫描的。 参考代码的网址是:http://www.freebuf.com/articles/network/41127.html https://github.com/OffensivePython/Pinject/blob/master/pinject.py

C++ socket 客户端recv不到数据

#include <sys/types.h> #include <sys/socket.h>/* for socket() and bind() */ #include <stdio.h>/* for printf() and fprintf() */ #include <arpa/inet.h>/* for sockaddr_in and inet_ntoa() */ #include <unistd.h>/* for close() */ #include <string.h> /* for memset() */ #include <stdlib.h>/* for atoi() */ #include "Msg.h" #include "queue" #include "pack.h" #include "analysis.h" /////////////// using namespace std; #define MYPORT 7000 #define SERVER_IP "127.0.0.1" #define BUFFER_SIZE 1024 int sock_cli;//client文件描述符 void* recvMess(void* ptr) { unsigned char recvbuf[BUFFER_SIZE]; while (1){ memset(recvbuf,0x00, sizeof(recvbuf)); cout<<"ready recv"<<endl; int len = recv(sock_cli,recvbuf, sizeof(recvbuf),0); if(len == -1){ cout << " client -1 recv error" << endl; } else if (len == 0){ cout << "clent 0 recv over" << endl; } else { cout << len << endl; } } int main() { ///定义sockfd //sock_cli = socket(AF_INET,SOCK_STREAM,0); sock_cli = socket(AF_INET,SOCK_STREAM ,IPPROTO_TCP); if(sock_cli <0){ cout << "socket creatation failed!" << endl; return -1; } ///定义sockaddr_in struct sockaddr_in servaddr; memset(&servaddr, 0, sizeof(servaddr)); servaddr.sin_family = AF_INET; servaddr.sin_port = htons(MYPORT); ///服务器端口 servaddr.sin_addr.s_addr = inet_addr(SERVER_IP); ///服务器ip if (connect(sock_cli, (struct sockaddr *)&servaddr, sizeof(servaddr)) < 0) { perror("connect"); exit(1); } pthread_t recv_szMessage_thread; int recv_szMessage_thread_flag = pthread_create(& recv_szMessage_thread,NULL,recvMess,NULL); if ( recv_szMessage_thread_flag !=0){ cout<< "client create recv thread failed"<<endl; } pthread_detach( recv_szMessage_thread); while(1){ } close(sock_cli); return 0; }

定量遥感中文版 梁顺林著 范闻捷译

这是梁顺林的定量遥感的中文版,由范闻捷等翻译的,是电子版PDF,解决了大家看英文费时费事的问题,希望大家下载看看,一定会有帮助的

Java 最常见的 200+ 面试题:面试必备

这份面试清单是从我 2015 年做了 TeamLeader 之后开始收集的,一方面是给公司招聘用,另一方面是想用它来挖掘在 Java 技术栈中,还有那些知识点是我不知道的,我想找到这些技术盲点,然后修复它,以此来提高自己的技术水平。虽然我是从 2009 年就开始参加编程工作了,但我依旧觉得自己现在要学的东西很多,并且学习这些知识,让我很有成就感和满足感,那所以何乐而不为呢? 说回面试的事,这份面试...

机器学习初学者必会的案例精讲

通过六个实际的编码项目,带领同学入门人工智能。这些项目涉及机器学习(回归,分类,聚类),深度学习(神经网络),底层数学算法,Weka数据挖掘,利用Git开源项目实战等。

远程工具,免费

远程工具,免费

java jdk 8 帮助文档 中文 文档 chm 谷歌翻译

JDK1.8 API 中文谷歌翻译版 java帮助文档 JDK API java 帮助文档 谷歌翻译 JDK1.8 API 中文 谷歌翻译版 java帮助文档 Java最新帮助文档 本帮助文档是使用谷

csma/ca和csma/cd的matlab仿真源代码带有详细的注释

csma/ca和csma/cd的matlab仿真源代码带有详细的注释,载波侦听,随意设置节点数,带有炫酷的图形展示效果。

Java基础知识面试题(2020最新版)

文章目录Java概述何为编程什么是Javajdk1.5之后的三大版本JVM、JRE和JDK的关系什么是跨平台性?原理是什么Java语言有哪些特点什么是字节码?采用字节码的最大好处是什么什么是Java程序的主类?应用程序和小程序的主类有何不同?Java应用程序与小程序之间有那些差别?Java和C++的区别Oracle JDK 和 OpenJDK 的对比基础语法数据类型Java有哪些数据类型switc...

软件测试入门、SQL、性能测试、测试管理工具

软件测试2小时入门,让您快速了解软件测试基本知识,有系统的了解; SQL一小时,让您快速理解和掌握SQL基本语法 jmeter性能测试 ,让您快速了解主流来源性能测试工具jmeter 测试管理工具-禅道,让您快速学会禅道的使用,学会测试项目、用例、缺陷的管理、

pokemmo的资源

pokemmo必须的4个rom 分别为绿宝石 火红 心金 黑白 还有汉化补丁 资源不错哦 记得下载

三个项目玩转深度学习(附1G源码)

从事大数据与人工智能开发与实践约十年,钱老师亲自见证了大数据行业的发展与人工智能的从冷到热。事实证明,计算机技术的发展,算力突破,海量数据,机器人技术等,开启了第四次工业革命的序章。深度学习图像分类一直是人工智能的经典任务,是智慧零售、安防、无人驾驶等机器视觉应用领域的核心技术之一,掌握图像分类技术是机器视觉学习的重中之重。针对现有线上学习的特点与实际需求,我们开发了人工智能案例实战系列课程。打造:以项目案例实践为驱动的课程学习方式,覆盖了智能零售,智慧交通等常见领域,通过基础学习、项目案例实践、社群答疑,三维立体的方式,打造最好的学习效果。

无线通信中的智能天线:IS-95和第3代CDMA应用_.pdf

无线通信中的智能天线:IS-95和第3代CDMA应用_.pdf

设计模式(JAVA语言实现)--20种设计模式附带源码

课程亮点: 课程培训详细的笔记以及实例代码,让学员开始掌握设计模式知识点 课程内容: 工厂模式、桥接模式、组合模式、装饰器模式、外观模式、享元模式、原型模型、代理模式、单例模式、适配器模式 策略模式、模板方法模式、观察者模式、迭代器模式、责任链模式、命令模式、备忘录模式、状态模式、访问者模式 课程特色: 笔记设计模式,用笔记串连所有知识点,让学员从一点一滴积累,学习过程无压力 笔记标题采用关键字标识法,帮助学员更加容易记住知识点 笔记以超链接形式让知识点关联起来,形式知识体系 采用先概念后实例再应用方式,知识点深入浅出 提供授课内容笔记作为课后复习以及工作备查工具 部分图表(电脑PC端查看):

Java8零基础入门视频教程

这门课程基于主流的java8平台,由浅入深的详细讲解了java SE的开发技术,可以使java方向的入门学员,快速扎实的掌握java开发技术!

玩转Linux:常用命令实例指南

人工智能、物联网、大数据时代,Linux正有着一统天下的趋势,几乎每个程序员岗位,都要求掌握Linux。本课程零基础也能轻松入门。 本课程以简洁易懂的语言手把手教你系统掌握日常所需的Linux知识,每个知识点都会配合案例实战让你融汇贯通。课程通俗易懂,简洁流畅,适合0基础以及对Linux掌握不熟练的人学习; 【限时福利】 1)购课后按提示添加小助手,进答疑群,还可获得价值300元的编程大礼包! 2)本月购买此套餐加入老师答疑交流群,可参加老师的免费分享活动,学习最新技术项目经验。 --------------------------------------------------------------- 29元=掌握Linux必修知识+社群答疑+讲师社群分享会+700元编程礼包。 &nbsp;

极简JAVA学习营第四期(报名以后加助教微信:eduxy-1)

想学好JAVA必须要报两万的培训班吗? Java大神勿入 如果你: 零基础想学JAVA却不知道从何入手 看了一堆书和视频却还是连JAVA的环境都搭建不起来 囊中羞涩面对两万起的JAVA培训班不忍直视 在职没有每天大块的时间专门学习JAVA 那么恭喜你找到组织了,在这里有: 1. 一群志同道合立志学好JAVA的同学一起学习讨论JAVA 2. 灵活机动的学习时间完成特定学习任务+每日编程实战练习 3. 热心助人的助教和讲师及时帮你解决问题,不按时完成作业小心助教老师的家访哦 上一张图看看前辈的感悟: &nbsp; &nbsp; 大家一定迫不及待想知道什么是极简JAVA学习营了吧,下面就来给大家说道说道: 什么是极简JAVA学习营? 1. 针对Java小白或者初级Java学习者; 2. 利用9天时间,每天1个小时时间; 3.通过 每日作业 / 组队PK / 助教答疑 / 实战编程 / 项目答辩 / 社群讨论 / 趣味知识抢答等方式让学员爱上学习编程 , 最终实现能独立开发一个基于控制台的‘库存管理系统’ 的学习模式 极简JAVA学习营是怎么学习的? &nbsp; 如何报名? 只要购买了极简JAVA一:JAVA入门就算报名成功! &nbsp;本期为第四期极简JAVA学习营,我们来看看往期学员的学习状态: 作业看这里~ &nbsp; 助教的作业报告是不是很专业 不交作业打屁屁 助教答疑是不是很用心 &nbsp; 有奖抢答大家玩的很嗨啊 &nbsp; &nbsp; 项目答辩终于开始啦 &nbsp; 优秀者的获奖感言 &nbsp; 这是答辩项目的效果 &nbsp; &nbsp; 这么细致的服务,这么好的氛围,这样的学习效果,需要多少钱呢? 不要1999,不要199,不要99,只要9.9 是的你没听错,只要9.9以上所有就都属于你了 如果你: 1、&nbsp;想学JAVA没有基础 2、&nbsp;想学JAVA没有整块的时间 3、&nbsp;想学JAVA没有足够的预算 还等什么?赶紧报名吧,抓紧抢位,本期只招300人,错过只有等时间待定的下一期了 &nbsp; 报名请加小助手微信:eduxy-1 &nbsp; &nbsp;

Python数据清洗实战入门

本次课程主要以真实的电商数据为基础,通过Python详细的介绍了数据分析中的数据清洗阶段各种技巧和方法。

董付国老师Python全栈学习优惠套餐

购买套餐的朋友可以关注微信公众号“Python小屋”,上传付款截图,然后领取董老师任意图书1本。

linux下利用/proc进行进程树的打印

在linux下利用c语言实现的进程树的打印,主要通过/proc下的目录中的进程文件,获取status中的进程信息内容,然后利用递归实现进程树的打印

MySQL数据库面试题(2020最新版)

文章目录数据库基础知识为什么要使用数据库什么是SQL?什么是MySQL?数据库三大范式是什么mysql有关权限的表都有哪几个MySQL的binlog有有几种录入格式?分别有什么区别?数据类型mysql有哪些数据类型引擎MySQL存储引擎MyISAM与InnoDB区别MyISAM索引与InnoDB索引的区别?InnoDB引擎的4大特性存储引擎选择索引什么是索引?索引有哪些优缺点?索引使用场景(重点)...

HoloLens2开发入门教程

本课程为HoloLens2开发入门教程,讲解部署开发环境,安装VS2019,Unity版本,Windows SDK,创建Unity项目,讲解如何使用MRTK,编辑器模拟手势交互,打包VS工程并编译部署应用到HoloLens上等。

150讲轻松搞定Python网络爬虫

【为什么学爬虫?】 &nbsp; &nbsp; &nbsp; &nbsp;1、爬虫入手容易,但是深入较难,如何写出高效率的爬虫,如何写出灵活性高可扩展的爬虫都是一项技术活。另外在爬虫过程中,经常容易遇到被反爬虫,比如字体反爬、IP识别、验证码等,如何层层攻克难点拿到想要的数据,这门课程,你都能学到! &nbsp; &nbsp; &nbsp; &nbsp;2、如果是作为一个其他行业的开发者,比如app开发,web开发,学习爬虫能让你加强对技术的认知,能够开发出更加安全的软件和网站 【课程设计】 一个完整的爬虫程序,无论大小,总体来说可以分成三个步骤,分别是: 网络请求:模拟浏览器的行为从网上抓取数据。 数据解析:将请求下来的数据进行过滤,提取我们想要的数据。 数据存储:将提取到的数据存储到硬盘或者内存中。比如用mysql数据库或者redis等。 那么本课程也是按照这几个步骤循序渐进的进行讲解,带领学生完整的掌握每个步骤的技术。另外,因为爬虫的多样性,在爬取的过程中可能会发生被反爬、效率低下等。因此我们又增加了两个章节用来提高爬虫程序的灵活性,分别是: 爬虫进阶:包括IP代理,多线程爬虫,图形验证码识别、JS加密解密、动态网页爬虫、字体反爬识别等。 Scrapy和分布式爬虫:Scrapy框架、Scrapy-redis组件、分布式爬虫等。 通过爬虫进阶的知识点我们能应付大量的反爬网站,而Scrapy框架作为一个专业的爬虫框架,使用他可以快速提高我们编写爬虫程序的效率和速度。另外如果一台机器不能满足你的需求,我们可以用分布式爬虫让多台机器帮助你快速爬取数据。 &nbsp; 从基础爬虫到商业化应用爬虫,本套课程满足您的所有需求! 【课程服务】 专属付费社群+每周三讨论会+1v1答疑

MySQL 8.0.19安装教程(windows 64位)

话不多说直接开干 目录 1-先去官网下载点击的MySQL的下载​ 2-配置初始化的my.ini文件的文件 3-初始化MySQL 4-安装MySQL服务 + 启动MySQL 服务 5-连接MySQL + 修改密码 先去官网下载点击的MySQL的下载 下载完成后解压 解压完是这个样子 配置初始化的my.ini文件的文件 ...

Python数据挖掘简易入门

&nbsp; &nbsp; &nbsp; &nbsp; 本课程为Python数据挖掘方向的入门课程,课程主要以真实数据为基础,详细介绍数据挖掘入门的流程和使用Python实现pandas与numpy在数据挖掘方向的运用,并深入学习如何运用scikit-learn调用常用的数据挖掘算法解决数据挖掘问题,为进一步深入学习数据挖掘打下扎实的基础。

深度学习原理+项目实战+算法详解+主流框架(套餐)

深度学习系列课程从深度学习基础知识点开始讲解一步步进入神经网络的世界再到卷积和递归神经网络,详解各大经典网络架构。实战部分选择当下最火爆深度学习框架PyTorch与Tensorflow/Keras,全程实战演示框架核心使用与建模方法。项目实战部分选择计算机视觉与自然语言处理领域经典项目,从零开始详解算法原理,debug模式逐行代码解读。适合准备就业和转行的同学们加入学习! 建议按照下列课程顺序来进行学习 (1)掌握深度学习必备经典网络架构 (2)深度框架实战方法 (3)计算机视觉与自然语言处理项目实战。(按照课程排列顺序即可)

网络工程师小白入门--【思科CCNA、华为HCNA等网络工程师认证】

本课程适合CCNA或HCNA网络小白同志,高手请绕道,可以直接学习进价课程。通过本预科课程的学习,为学习网络工程师、思科CCNA、华为HCNA这些认证打下坚实的基础! 重要!思科认证2020年2月24日起,已启用新版认证和考试,包括题库都会更新,由于疫情原因,请关注官网和本地考点信息。题库网络上很容易下载到。

Ubuntu18.04安装教程

Ubuntu18.04.1安装一、准备工作1.下载Ubuntu18.04.1 LTS2.制作U盘启动盘3.准备 Ubuntu18.04.1 的硬盘空间二、安装Ubuntu18.04.1三、安装后的一些工作1.安装输入法2.更换软件源四、双系统如何卸载Ubuntu18.04.1新的改变功能快捷键合理的创建标题,有助于目录的生成如何改变文本的样式插入链接与图片如何插入一段漂亮的代码片生成一个适合你的列...

sql语句 异常 Err] 1064 - You have an error in your SQL syntax; check the manual that corresponds to your

在我们开发的工程中,有时候会报 [Err] 1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ------ 这种异常 不用多想,肯定是我们的sql语句出现问题,下面...

西南交通大学新秀杯数学建模试题

题目比较难,如果符合大家的口味欢迎大家下载哈,提高你的思维想象能力

Windows版YOLOv4目标检测实战:训练自己的数据集

课程演示环境:Windows10; cuda 10.2; cudnn7.6.5; Python3.7; VisualStudio2019; OpenCV3.4 需要学习ubuntu系统上YOLOv4的同学请前往:《YOLOv4目标检测实战:训练自己的数据集》 课程链接:https://edu.csdn.net/course/detail/28745 YOLOv4来了!速度和精度双提升! 与 YOLOv3 相比,新版本的 AP (精度)和 FPS (每秒帧率)分别提高了 10% 和 12%。 YOLO系列是基于深度学习的端到端实时目标检测方法。本课程将手把手地教大家使用labelImg标注和使用YOLOv4训练自己的数据集。课程实战分为两个项目:单目标检测(足球目标检测)和多目标检测(足球和梅西同时检测)。 本课程的YOLOv4使用AlexyAB/darknet,在Windows系统上做项目演示。包括:安装软件环境、安装YOLOv4、标注自己的数据集、整理自己的数据集、修改配置文件、训练自己的数据集、测试训练出的网络模型、性能统计(mAP计算)和先验框聚类分析。还将介绍改善YOLOv4目标检测性能的技巧。 除本课程《Windows版YOLOv4目标检测实战:训练自己的数据集》外,本人将推出有关YOLOv4目标检测的系列课程。请持续关注该系列的其它视频课程,包括: 《Windows版YOLOv4目标检测实战:人脸口罩佩戴检测》 《Windows版YOLOv4目标检测实战:中国交通标志识别》 《Windows版YOLOv4目标检测:原理与源码解析》

Spring Boot -01- 快速入门篇(图文教程)

Spring Boot -01- 快速入门篇 今天开始不断整理 Spring Boot 2.0 版本学习笔记,大家可以在博客看到我的笔记,然后大家想看视频课程也可以到【慕课网】手机 app,去找【Spring Boot 2.0 深度实践】的课程,令人开心的是,课程完全免费! 什么是 Spring Boot? Spring Boot 是由 Pivotal 团队提供的全新框架。Spring Boot...

相关热词 c#框体中的退出函数 c# 按钮透明背景 c# idl 混编出错 c#在位置0处没有任何行 c# 循环给数组插入数据 c# 多线程死锁的例子 c# 钉钉读取员工排班 c# label 不显示 c#裁剪影像 c#工作进程更新ui
立即提问