udp怎么实现客户端对客户端收发消息

我在做一个udp的聊天程序,我能做到客户端与服务端的收发消息,但是怎么实现客户端对客户端的收发?
图片说明
我想过用服务端来进行转发,但是这工程量也太大了吧,求高手指点

5个回答

服务器端就用来处理客户端登陆,客户端要同时实现服务端功能用于客户端之间的通信,通信的端口和ip在登陆到公共服务器时上传。客户端登陆后,从公共服务器拿到好友的ip和端口后,直接和好友通信。

这种实现的问题是如果客户端在内网通过路由器上网的,那么可能会直接连接不上,需要路由器上配置端口映射将内部通信端口暴露出来。

服务器将客户端的IP和端口号传递给对方,然后客户端根据IP和端口号,直接向客户端发送消息,服务器就是在建立连接,转发客户端的信息后就不管了,后面的消息,客户端就自己直接和客户端建立通信(UDP不用连接的方式。。。)

每个 客户端 连接到 服务端的时候 都会留下 ip 地址信息 当有新的客户端连接到 服务端的时候 就会拉取之前 连接到 服务端的客户端 ip 列表

有了ip 地址列表 就可以 通过 udp 直接给 其他客户端发送信息 而不用通过服务端 中转

你的这个需求涉及到内网穿透,可以参考一下C#实现P2P之UDP穿透NAT原理讲解
也可以看看类QQ(P2P)聊天系统的原理与C#实现这个是否有帮助。

udp是无连接协议,受NAT地址转换影响较大,建议采用TCP和UDP双协议实现,这样会好些。

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
c# UDP组网 客户端发送接收

需要组网 网段 255.255.0.22 端口号 2031 我这是客户端 需要发送和接收数据 现在自己写的代码 服务器接收不到数据 用网络调试助手调试 服务器可以接收 表示网络连通的 各位大神 帮忙看看 很着急 第一次做UDP组网 组网部分全部代码如下: UdpClient ZuBoClient; IPEndPoint ZuBoIp; int zuboPort = 2031; ZuBoClient = new UdpClient(zuboPort); ZuBoIp = new IPEndPoint(IPAddress.Parse("225.255.0.22"), 2031); ZuBoClient.JoinMulticastGroup(IPAddress.Parse("225.255.0.22")); ZuBoClient.Send(aliveBuf, aliveBuf.Length, ZuBoIp); alivebuf是所发数据

C# UDP通讯,外网客户端向内网服务器发送数据接受不到

内网发送接收消息没问题,外网路由器做了UDP映射,客户端发送数据,能在内网PC电脑上抓包出来,但是服务器接收不到这个消息 private void freeDNS_Server_Load(object sender, EventArgs e) { receiveClient = new UdpClient(port); Thread myThread = new Thread(ReceiveData); myThread.IsBackground = true; myThread.Start(); } //在后台运行的接收线程 private void ReceiveData() { //在本机指定的端口接收 UdpState udpState = new UdpState(); udpState.ipEndPoint = null; udpState.udpClient = receiveClient; //接收从远程主机发送过来的信息; IAsyncResult ar = udpState.udpClient.BeginReceive(ReceiveUdpClientCallback, udpState); ar.AsyncWaitHandle.WaitOne(); MessageBox.Show("线程结束"); } //接收信息回调方法 void ReceiveUdpClientCallback(IAsyncResult ar) { try { UdpClient u = (UdpClient)((UdpState)(ar.AsyncState)).udpClient; IPEndPoint remote = (IPEndPoint)((UdpState)(ar.AsyncState)).ipEndPoint; Byte[] receiveBytes = u.EndReceive(ar, ref remote); string str = Encoding.UTF8.GetString(receiveBytes, 0, receiveBytes.Length); AddItem(listBox_freeDNS_Server, string.Format("来自{0}:{1}", remote, str)); ReceiveData();//继续接受数据 } catch (Exception ex) { AddItem(listBox_freeDNS_Server, string.Format("错误信息{0}", ex.ToString())); } } delegate void AddListBoxItemCallback(string text); private void AddListBoxItem(string text) { //如果listBoxReceive被不同的线程访问则通过委托处理; if (listBox_freeDNS_Server.InvokeRequired) { this.Invoke(listBoxCallback, text); } else { listBox_freeDNS_Server.Items.Add(text); listBox_freeDNS_Server.SelectedIndex = listBox_freeDNS_Server.Items.Count - 1; listBox_freeDNS_Server.ClearSelected(); } }

[求助]使用SocketAsyncEventArgs制作UDP的异步发送问题

我用SocketAsyncEventArgs做了一个UDP的程序 服务器和客户端都在本地:收发没问题 服务器在公网,客户端在内网: 1:客户端发服务器,服务器收不到 2:使用其它工具测试,向服务器发送数据,数据器能收到数据,并且能够成功的返回数据到内网 但是我服务器和客户端都用的同一个类,发送用的是相同的代码,为什么客户端发送就不行,服务器发送就成功,简直诡异到不行 求有经验的大神分析分析原因

C++ udp多线程socket实现一个server多个client间的通信

http://blog.csdn.net/chw1989/article/details/7453217 链接如上,想知道这篇文章里面提到的 能进行多机测试,但是运行的时候只能1为client,2为server并且不能实现循环处理数据,要想实现那些功能该怎么改

netty客户端向远程服务端发送数据包

首先,感谢每一位来关注的IT前辈,真诚希望您提出宝贵的意见。 我需要的效果: 1.客户端与服务端长连接TCP通信; 2.客户端通过自定义解码器,解析服务端返回的数据包; 3.客户端在服务端返回连接结果后,发送登录请求数据包,需要对数据自定义编码器解析; 4.因为是长连接,服务不能断,还需要发送登陆请求,以及其他验证消息。很重要。 **数据包结构:** 1.固定包头2字节; 2.消息体,全部为文本(ASCII码),汉字是GB2312编码。 3.固定包尾2字节; 我目前代码: public class TCPClient { public void connect(int port,String host)throws Exception{ //网络事件处理线程组 EventLoopGroup group=new NioEventLoopGroup(); //配置客户端启动类 Bootstrap b=new Bootstrap(); b.group(group).channel(NioSocketChannel.class) .option(ChannelOption.TCP_NODELAY, true)//设置封包 使用一次 大数据的写操作,而不是多次小数据的写操作 .handler(new ChannelInitializer<SocketChannel>() { @Override protected void initChannel(SocketChannel ch) throws Exception { ch.pipeline().addLast("decoder",new DealMsg()); //设置自定义解码器 ch.pipeline().addLast("encoder",new MsgEncode()); //设置自定义编码器 ch.pipeline().addLast(new TCPClientHandler()); //设置客户端网络IO处理器 } }); //连接服务器 同步等待成功 ChannelFuture f = b.connect(new InetSocketAddress(host,port)); //同步等待客户端通道关闭 // f.channel().closeFuture().sync(); //不关闭会发生阻塞 Channel channel = f.sync().channel(); Scanner scanner = new Scanner(System.in); while(true){ System.out.println("请输入"); CarData carData = new CarData(); String line = scanner.nextLine(); carData.setBody(line); //发送请求 channel.writeAndFlush(carData); } //释放线程组资源 // group.shutdownGracefully(); } } public class TCPClientHandler extends ChannelHandlerAdapter { @Override public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception { System.out.println("通信异常!!"); cause.printStackTrace(); } @Override public void channelActive(ChannelHandlerContext ctx) throws Exception { System.out.println("链接服务端成功!"); } @Override public void channelInactive(ChannelHandlerContext ctx) throws Exception { System.out.println("退出链接!!"); } @Override public void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception { System.out.println("接受服务器数据:【 "+msg); } @Override public void channelReadComplete(ChannelHandlerContext ctx) throws Exception { ctx.channel().writeAndFlush("数据读取完成!"); } }

客户端与服务器通信,数据包应该怎样设计

客户端与服务端通信,服务器接受客户端的网络请求,根据收到的数据做出回应,数据包应该怎样设置比较好。 下面是我设计的一个数据包,但当进行注册操作的时候,有个手机号的信息,用char数组,但不知道该怎么设计, 在结构中再增加一个char数组又觉得没必要,只是在注册的时候用到。还是应该分开设计数据包。 head[0] = 1 登陆状态操作 2 操作请求 3 游戏数据 head[1] = 1 登陆 2 下线 3 注册 1 聊天 2 添加好友 3 删除好友 1.迷宫游戏 2.其他游戏 account= 账号 账号 账号 buf= 密码 目标账号 游戏数据 struct Data { int head[2]; //消息类型 char account[20]; //账号 char buf[1024]; //数据 }; 现在在学习中,所以不太懂,感谢各位大大帮助

用socket编写的客户端和服务端,客户端可以通过服务端的域名发送消息吗

本来要做GPRS通信模块发送命令到服务器端,服务器端根据命令做出反应,如果命令有需要还要返回数据到Gprs模块。网上搜怎么做,都是说用sokect做,我需要的是GPRS模块通过服务器的域名发送消息到服务端。

同时接收多个udp时丢包

udp广播,多个客户端同时回馈。广播端接收反馈数据会出现丢包。在android上测试,好的手机丢包情况明显改善。请教下有没有好的解决方案彻底解决。

别人用UDP进行数据传输,我只需监听端口进行数据接收,需要用到消息中间件吗。

用到消息中间件的话,是不是只用消费的模块,但是这样要怎么把数据先存到消息队列里呢。还是我自己拿到数据后,自己当producer把数据再放到消息队列,然后再按顺序消费。

java用udp进行服务器通信,做聊天程序

java用udp进行服务器通信,做聊天程序,怎么将接收方的信息,放在发送内容里面来完成。tcp模式可以用序列化方式来完成,udp用什么方法,必须用正则方法,来找出接收方信息吗。

如何获取主机中所有进程的udp连接的具体信息(远程IP:Port 收发字节数)

我知道getudptable这个api能获取到一些udp的信息,但是只能获取本地的IP:Port,没法获取远程的,以及收发字节(流量),大神帮我!感激不尽!类似IPRadar(IP雷达)软件的这种功能!

java udp 监听和发送数据同一个端口..

现在项目有一个需求.. 举例..给一个设备使用udp通过服务器的8001端口发送数据, 数据发送完成之后会有返回的信息,也是通过8001端口.. 我在代码里先开启了监听8001端口 然后再发送数据...结果.端口冲突..使用两个线程 也是冲突.. 求大神指导..给个思路

如何用本机测试UDP数据的发送与接收,最好有完整的测试代码,谢谢!

如何用本机测试UDP数据的发送与接收,网上找了几个都不行,希望各位大神帮助一下哈,不胜感激!

使用python实现rtsp客户端遇见的setup消息发送的问题

使用python实现rtsp客户端的setup消息发送时返回状态码为503;现在不知如何解决,遂请求帮助。有偿+wx:ww1194609610(10rmb) ``` import socket from urllib.parse import urlparse config_dict = { 'cseq': 2, 'user_agent': 'LibVLC/3.0.2 (LIVE555 Streaming Media v2016.11.28)', 'timeout': 3, 'recvbite': 4096, 'res_status': '200 OK', 'rtsp_status': 'flase' } clientports=[60784, 60785] def options_get(url): ''' options请求检测 url: rtsp流地址 return: options请求相应 ''' url = urlparse(url) host = url.netloc hostname = url.hostname path = url.path port = url.port str_options = 'OPTIONS rtsp://' + str(host) + \ path + ' RTSP/1.0\r\n' str_options += 'CSeq: ' + str(config_dict['cseq']) + '\r\n' str_options += 'User-Agent: ' + config_dict['user_agent'] + '\r\n' str_options += '\r\n' print(str_options) client = socket.socket(socket.AF_INET, socket.SOCK_STREAM) client.settimeout(config_dict['timeout']) client.connect((hostname, port)) client.send(str_options.encode()) d = client.recv(config_dict['recvbite']) return d def describe_get(url): ''' describe请求检测 url: rtsp流地址 return: describe请求相应 ''' url = urlparse(url) host = url.netloc hostname = url.hostname path = url.path port = url.port str_describe = 'DESCRIBE rtsp://' + str(host) + \ path + ' RTSP/1.0\r\n' str_describe += 'CSeq: ' + str(config_dict['cseq'] + 1) + '\r\n' str_describe += 'User-Agent: ' + config_dict['user_agent'] + '\r\n' str_describe += '\r\n' client = socket.socket(socket.AF_INET, socket.SOCK_STREAM) client.settimeout(config_dict['timeout']) client.connect((hostname, port)) client.send(str_describe.encode()) d = client.recv(config_dict['recvbite']) return d def setup_get(url): ''' setup请求检测 url: rtsp流地址 return: setup请求相应 ''' url = urlparse(url) host = url.netloc hostname = url.hostname path = url.path port = url.port str_setup = 'SETUP rtsp://' + str(host) + path + '/' + 'streamid=0' + ' RTSP/1.0\r\n' str_setup += 'CSeq: ' + str(config_dict['cseq'] + 2) + '\r\n' str_setup += 'User-Agent: ' + config_dict['user_agent'] + '\r\n' # config_dict['user_agent'] str_setup += 'Transport: RTP/AVP;unicast;client_port=61740-61741\r\n\r\n' str_setup += '\r\n' client = socket.socket(socket.AF_INET, socket.SOCK_STREAM) client.settimeout(config_dict['timeout']) client.connect((hostname, port)) client.send(str_setup.encode()) d = client.recv(config_dict['recvbite']) return d def teardown_get(url): ''' teardown请求检测 url: rtsp流地址 return: teardown请求相应 ''' url = urlparse(url) host = url.netloc hostname = url.hostname path = url.path port = url.port str_teardown = 'TEARDOWN rtsp://' + str(host) + path + ' RTSP/1.0\r\n' str_teardown += 'CSeq: ' + str(config_dict['cseq'] + 4) + '\r\n' str_teardown += 'User-Agent: ' + config_dict['user_agent'] + '\r\n' str_teardown += '\r\n' print(str_teardown) client = socket.socket(socket.AF_INET, socket.SOCK_STREAM) client.settimeout(config_dict['timeout']) client.connect((hostname, port)) client.send(str_teardown.encode()) d = client.recv(config_dict['recvbite']) return d def send_main(url): try: str_options = str(options_get(url)) print(str_options) if config_dict['res_status'] in str_options: str_des = str(describe_get(url)) print(str_des) if config_dict['res_status'] in str_des: str_setup = str(setup_get(url)) str_teardown = str(teardown_get(url)) print(str_setup) print(str_teardown) if config_dict['res_status'] in str_teardown: config_dict['rtsp_status'] = 'true' return True except Exception: return False else: return False print(send_main('rtsp://192.168.10.214:554/live/av0')) ``` 上方为我的代码。 b'RTSP/1.0 503 Service Unavailable\r\nCSeq: 4\r\nDate: Thu, 01 Jan 1970 07:11:16 GMT\r\n\r\n' 此段消息为setup请求的返回信息,我看过rtsp的相关文档,说describe请求返回的sdp信息,客户端再分析该SDP描述,并为会话中的每一个流发送一个RTSP建立命令( SETUP)。这个我没搞懂,也不知道如何写,这里进行请教一下。 下面是我的一次正常的rtsp交互信息。 ``` OPTIONS rtsp://192.168.10.214:554/live/av0 RTSP/1.0 CSeq: 2 User-Agent: LibVLC/3.0.5 (LIVE555 Streaming Media v2016.11.28) RTSP/1.0 200 OK CSeq: 2 Public: OPTIONS, DESCRIBE, SETUP, TEARDOWN, PLAY, PAUSE DESCRIBE rtsp://192.168.10.214:554/live/av0 RTSP/1.0 CSeq: 3 User-Agent: LibVLC/3.0.5 (LIVE555 Streaming Media v2016.11.28) Accept: application/sdp RTSP/1.0 200 OK CSeq: 3 Date: Thu, 01 Jan 1970 07:05:17 GMT Content-Base: rtsp://192.168.10.214:554/live/av0/ Content-Type: application/sdp Content-Length: 315 v=0 o=- 0 0 IN IP4 127.0.0.1 s=No Title c=IN IP4 0.0.0.0 t=0 0 a=tool:libavformat 55.12.100 m=video 0 RTP/AVP 96 a=rtpmap:96 H264/90000 a=fmtp:96 packetization-mode=1; sprop-parameter-sets=Z2QAKq2EAQwgCGEAQwgCGEAQwgCEK1A8ARPyzcBAQFAAAAMAEAAAAwPIQA==,aO48sA==; profile-level-id=64002A a=control:streamid=0 SETUP rtsp://192.168.10.214:554/live/av0/streamid=0 RTSP/1.0 CSeq: 4 User-Agent: LibVLC/3.0.5 (LIVE555 Streaming Media v2016.11.28) Transport: RTP/AVP;unicast;client_port=61740-61741 RTSP/1.0 200 OK CSeq: 4 Date: Thu, 01 Jan 1970 07:05:17 GMT Session: 093634014dba841b Transport: RTP/AVP/UDP;unicast;client_port=61740-61741;server_port=20006-20007 PLAY rtsp://192.168.10.214:554/live/av0/ RTSP/1.0 CSeq: 5 User-Agent: LibVLC/3.0.5 (LIVE555 Streaming Media v2016.11.28) Session: 093634014dba841b Range: npt=0.000- RTSP/1.0 200 OK CSeq: 5 Date: Thu, 01 Jan 1970 07:05:17 GMT Session: 093634014dba841b TEARDOWN rtsp://192.168.10.214:554/live/av0/ RTSP/1.0 CSeq: 6 User-Agent: LibVLC/3.0.5 (LIVE555 Streaming Media v2016.11.28) Session: 093634014dba841b RTSP/1.0 200 OK CSeq: 6 Date: Thu, 01 Jan 1970 07:05:21 GMT Session: 093634014dba841b ```

Java UDP接收到数据包的时间

请问各位大神,Java中如何获取UDP服务端接收到数据包时的时间,或者如何检测客户端固定时间内有没有发送消息

局域网组播同时收发的问题

我现在做的一个项目时局域网有多台设备,其中指定8台设备都能获取一个数据的同时在发给其他7台设备,然后取8个数值的平均值。所以我准备采取组播的方法。 我现在感觉有两个方法,一个是采取服务器-客户端的形式。以其中一个为服务器其他7个上报给它然后服务器在组播给其他设备。 另一种是将这8台设备都注册广播地址,然后设备获取数值后分发给其他7个设备。同时加一个接收广播地址的回调。但这个没有尝试过,不知道可行性怎么样。 希望网友们不吝赐教^_^(没C币了,不能悬赏了-_-) 还有一个问题,如果我将子网掩码配置后,一台设备用广播的形式上报数据,局域网所有的设备都能收到还是局域网内和这台设备相同网段的设备才能收到?

QT5中 socket 与 多线程的问题(聊天程序)

大家好 我在用QT5写一个聊天程序 用的是c/c++的封装的socket函数(QT封装的UDP不知道为什么不能正常发包) 问题是这样的: 有两个窗口 1. MainWindow 类的 login,程序启动首先显示它 2. Dialog 类的 chat, 要求登陆成功后才显示它 这两个窗口在main中QApplication a 和 a.exec()之间创建。 login窗口其中一个button点击后可以向服务器发送一个登陆请求,那么,如何 接收这个请求呢?我目前的做法是同样将这个button connect了一个receive函数, 不过只接受一个包,这样实现真的很丑,而且无法做到持续监听(这是chat窗口中的 关键) 我尝试用了c++11的thread来写多线程,传入一个窗口的指针,但好像不允许在子线程里调用窗口类实例的show()之类的函数,报错了(这点也是我很想知道的,类中定义的public成员函数可以在子线程中调用,但是不能调用诸如show(), close()之类的函数) 我刚学QT没多久,参考的很多QT聊天程序都是用QT封装的socket,但是这边用不了,如果一定要用c/c++封装的 有什么好的解决办法来实现吗?

C++中使用Socket通信,在服务器端,如何实现接收数据和发送数据在不同的线程中

创建一个接收socket数据的线程,从port口接收数据后,再传入内部处理线程; 在内部处理线程执行结束后,再做成回复消息,想通过另一个线程,向接收数据的port口发送消息。 上面的设计,怎么使用另一个线程向port口发送消息呢?我实现的发送失败。

java开发聊天系统的问题(毕业设计)

我打算用Java编写一个类似QQ的软件,包括PC的客户端,网站,服务器端,同时还有手机的wap网站和java版,我已经设计了一段时间,现开始从底层编写代码,用Hibernate和Spring对MySQL数据库的表和操作进行封装;通讯采用队列的方式,无论是服务器还是客户端,有收发两个队列进行控制,发送和接收的都是Message对象。登陆之后有一个tcp连接始终与服务器保持连接,直到离线或退出,其余的消息采用UDP的方式进行通讯,我将客户端的请求都封装在不同的Request类中,比如OnlineRequest,服务器端的回复都封装在不同的但相对应的Response的类中,比如OnlineResponse,同时有处理相应Request和Response的类,比如OnlineRequestMgr,OnlineResponseMgr等,Request和Response分别是不同的抽象类,但都继承自Message接口,通讯类Communication负责初始化TCP连接和收发UDP包,将UDP包中的Message放入相应的队列。一般来说Request由Response对其进行确认,但对于特殊情况,比如由服务器直接发起的Response,比如被添加好友时的确认信息,需要有一个MessageACK类来对其确认。这些协议的加载和处理都是动态的,只要有相应的class文件就可以自动加载并处理,这样可扩充性就比较好。在安全方面,我想的是在用户建立TCP连接后,先将用户的IP地址和TCP端口号记录下来,然后再根据之后发送的UDP包:LoginRequest,将UDP端口也记录下来,这样就完成了用户ID与IP地址,TCP,UDP端口的绑定,服务器将拒绝为同一个ID但其余信息不同的主机提供服务。目前底层的设计和代码编写就到这里,我想问的问题是:我的思路有没有比较严重的问题,目前聊天系统的整体架构是什么?我编写的协议的思路是否正确,可行?我感觉服务器端的压力会比较大,主要是接受连接,解析Request和查询数据库,有没有提高效率的方法?如果网站需要用到这些底层组件,应该怎么复用,采用EJB吗?Hibernate是轻量级的数据库持久层框架,能承受多少压力?对于聊天系统应该考虑的安全问题,有什么好的建议?Java对于开发语音和视频的支持怎么样,能否达到QQ的水平?另外要说明的是我并非开发商用软件,编写这个软件的目的是为了学习,本人还是在校学生,对Java很感兴趣^_^。希望大家不吝赐教

在中国程序员是青春饭吗?

今年,我也32了 ,为了不给大家误导,咨询了猎头、圈内好友,以及年过35岁的几位老程序员……舍了老脸去揭人家伤疤……希望能给大家以帮助,记得帮我点赞哦。 目录: 你以为的人生 一次又一次的伤害 猎头界的真相 如何应对互联网行业的「中年危机」 一、你以为的人生 刚入行时,拿着傲人的工资,想着好好干,以为我们的人生是这样的: 等真到了那一天,你会发现,你的人生很可能是这样的: ...

Java校招入职华为,半年后我跑路了

何来 我,一个双非本科弟弟,有幸在 19 届的秋招中得到前东家华为(以下简称 hw)的赏识,当时秋招签订就业协议,说是入了某 java bg,之后一系列组织架构调整原因等等让人无法理解的神操作,最终毕业前夕,被通知调往其他 bg 做嵌入式开发(纯 C 语言)。 由于已至于校招末尾,之前拿到的其他 offer 又无法再收回,一时感到无力回天,只得默默接受。 毕业后,直接入职开始了嵌入式苦旅,由于从未...

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

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

@程序员:GitHub这个项目快薅羊毛

今天下午在朋友圈看到很多人都在发github的羊毛,一时没明白是怎么回事。 后来上百度搜索了一下,原来真有这回事,毕竟资源主义的羊毛不少啊,1000刀刷爆了朋友圈!不知道你们的朋友圈有没有看到类似的消息。 这到底是啥情况? 微软开发者平台GitHub 的一个区块链项目 Handshake ,搞了一个招募新会员的活动,面向GitHub 上前 25万名开发者派送 4,246.99 HNS币,大约价...

再不跳槽,应届毕业生拿的都比我多了!

跳槽几乎是每个人职业生涯的一部分,很多HR说“三年两跳”已经是一个跳槽频繁与否的阈值了,可为什么市面上有很多程序员不到一年就跳槽呢?他们不担心影响履历吗? PayScale之前发布的**《员工最短任期公司排行榜》中,两家码农大厂Amazon和Google**,以1年和1.1年的员工任期中位数分列第二、第四名。 PayScale:员工最短任期公司排行榜 意外的是,任期中位数极小的这两家公司,薪资...

我以为我学懂了数据结构,直到看了这个导图才发现,我错了

数据结构与算法思维导图

技术大佬:我去,你写的 switch 语句也太老土了吧

昨天早上通过远程的方式 review 了两名新来同事的代码,大部分代码都写得很漂亮,严谨的同时注释也很到位,这令我非常满意。但当我看到他们当中有一个人写的 switch 语句时,还是忍不住破口大骂:“我擦,小王,你丫写的 switch 语句也太老土了吧!” 来看看小王写的代码吧,看完不要骂我装逼啊。 private static String createPlayer(PlayerTypes p...

华为初面+综合面试(Java技术面)附上面试题

华为面试整体流程大致分为笔试,性格测试,面试,综合面试,回学校等结果。笔试来说,华为的难度较中等,选择题难度和网易腾讯差不多。最后的代码题,相比下来就简单很多,一共3道题目,前2题很容易就AC,题目已经记不太清楚,不过难度确实不大。最后一题最后提交的代码过了75%的样例,一直没有发现剩下的25%可能存在什么坑。 笔试部分太久远,我就不怎么回忆了。直接将面试。 面试 如果说腾讯的面试是挥金如土...

和黑客斗争的 6 天!

互联网公司工作,很难避免不和黑客们打交道,我呆过的两家互联网公司,几乎每月每天每分钟都有黑客在公司网站上扫描。有的是寻找 Sql 注入的缺口,有的是寻找线上服务器可能存在的漏洞,大部分都...

讲一个程序员如何副业月赚三万的真实故事

loonggg读完需要3分钟速读仅需 1 分钟大家好,我是你们的校长。我之前讲过,这年头,只要肯动脑,肯行动,程序员凭借自己的技术,赚钱的方式还是有很多种的。仅仅靠在公司出卖自己的劳动时...

win10暴力查看wifi密码

刚才邻居打了个电话说:喂小灰,你家wifi的密码是多少,我怎么连不上了。 我。。。 我也忘了哎,就找到了一个好办法,分享给大家: 第一种情况:已经连接上的wifi,怎么知道密码? 打开:控制面板\网络和 Internet\网络连接 然后右击wifi连接的无线网卡,选择状态 然后像下图一样: 第二种情况:前提是我不知道啊,但是我以前知道密码。 此时可以利用dos命令了 1、利用netsh wlan...

上班一个月,后悔当初着急入职的选择了

最近有个老铁,告诉我说,上班一个月,后悔当初着急入职现在公司了。他之前在美图做手机研发,今年美图那边今年也有一波组织优化调整,他是其中一个,在协商离职后,当时捉急找工作上班,因为有房贷供着,不能没有收入来源。所以匆忙选了一家公司,实际上是一个大型外包公司,主要派遣给其他手机厂商做外包项目。**当时承诺待遇还不错,所以就立马入职去上班了。但是后面入职后,发现薪酬待遇这块并不是HR所说那样,那个HR自...

女程序员,为什么比男程序员少???

昨天看到一档综艺节目,讨论了两个话题:(1)中国学生的数学成绩,平均下来看,会比国外好?为什么?(2)男生的数学成绩,平均下来看,会比女生好?为什么?同时,我又联想到了一个技术圈经常讨...

总结了 150 余个神奇网站,你不来瞅瞅吗?

原博客再更新,可能就没了,之后将持续更新本篇博客。

副业收入是我做程序媛的3倍,工作外的B面人生是怎样的?

提到“程序员”,多数人脑海里首先想到的大约是:为人木讷、薪水超高、工作枯燥…… 然而,当离开工作岗位,撕去层层标签,脱下“程序员”这身外套,有的人生动又有趣,马上展现出了完全不同的A/B面人生! 不论是简单的爱好,还是正经的副业,他们都干得同样出色。偶尔,还能和程序员的特质结合,产生奇妙的“化学反应”。 @Charlotte:平日素颜示人,周末美妆博主 大家都以为程序媛也个个不修边幅,但我们也许...

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

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

如果你是老板,你会不会踢了这样的员工?

有个好朋友ZS,是技术总监,昨天问我:“有一个老下属,跟了我很多年,做事勤勤恳恳,主动性也很好。但随着公司的发展,他的进步速度,跟不上团队的步伐了,有点...

我入职阿里后,才知道原来简历这么写

私下里,有不少读者问我:“二哥,如何才能写出一份专业的技术简历呢?我总感觉自己写的简历太烂了,所以投了无数份,都石沉大海了。”说实话,我自己好多年没有写过简历了,但我认识的一个同行,他在阿里,给我说了一些他当年写简历的方法论,我感觉太牛逼了,实在是忍不住,就分享了出来,希望能够帮助到你。 01、简历的本质 作为简历的撰写者,你必须要搞清楚一点,简历的本质是什么,它就是为了来销售你的价值主张的。往深...

程序员写出这样的代码,能不挨骂吗?

当你换槽填坑时,面对一个新的环境。能够快速熟练,上手实现业务需求是关键。但是,哪些因素会影响你快速上手呢?是原有代码写的不够好?还是注释写的不够好?昨夜...

!大部分程序员只会写3年代码

如果世界上都是这种不思进取的软件公司,那别说大部分程序员只会写 3 年代码,恐怕就没有程序员这种职业。

离职半年了,老东家又发 offer,回不回?

有小伙伴问松哥这个问题,他在上海某公司,在离职了几个月后,前公司的领导联系到他,希望他能够返聘回去,他很纠结要不要回去? 俗话说好马不吃回头草,但是这个小伙伴既然感到纠结了,我觉得至少说明了两个问题:1.曾经的公司还不错;2.现在的日子也不是很如意。否则应该就不会纠结了。 老实说,松哥之前也有过类似的经历,今天就来和小伙伴们聊聊回头草到底吃不吃。 首先一个基本观点,就是离职了也没必要和老东家弄的苦...

HTTP与HTTPS的区别

面试官问HTTP与HTTPS的区别,我这样回答让他竖起大拇指!

男生更看重女生的身材脸蛋,还是思想?

往往,我们看不进去大段大段的逻辑。深刻的哲理,往往短而精悍,一阵见血。问:产品经理挺漂亮的,有点心动,但不知道合不合得来。男生更看重女生的身材脸蛋,还是...

程序员为什么千万不要瞎努力?

本文作者用对比非常鲜明的两个开发团队的故事,讲解了敏捷开发之道 —— 如果你的团队缺乏统一标准的环境,那么即使勤劳努力,不仅会极其耗时而且成果甚微,使用...

为什么程序员做外包会被瞧不起?

二哥,有个事想询问下您的意见,您觉得应届生值得去外包吗?公司虽然挺大的,中xx,但待遇感觉挺低,马上要报到,挺纠结的。

当HR压你价,说你只值7K,你该怎么回答?

当HR压你价,说你只值7K时,你可以流畅地回答,记住,是流畅,不能犹豫。 礼貌地说:“7K是吗?了解了。嗯~其实我对贵司的面试官印象很好。只不过,现在我的手头上已经有一份11K的offer。来面试,主要也是自己对贵司挺有兴趣的,所以过来看看……”(未完) 这段话主要是陪HR互诈的同时,从公司兴趣,公司职员印象上,都给予对方正面的肯定,既能提升HR的好感度,又能让谈判气氛融洽,为后面的发挥留足空间。...

面试:第十六章:Java中级开发(16k)

HashMap底层实现原理,红黑树,B+树,B树的结构原理 Spring的AOP和IOC是什么?它们常见的使用场景有哪些?Spring事务,事务的属性,传播行为,数据库隔离级别 Spring和SpringMVC,MyBatis以及SpringBoot的注解分别有哪些?SpringMVC的工作原理,SpringBoot框架的优点,MyBatis框架的优点 SpringCould组件有哪些,他们...

面试阿里p7,被按在地上摩擦,鬼知道我经历了什么?

面试阿里p7被问到的问题(当时我只知道第一个):@Conditional是做什么的?@Conditional多个条件是什么逻辑关系?条件判断在什么时候执...

终于懂了TCP和UDP协议区别

终于懂了TCP和UDP协议区别

Python爬虫,高清美图我全都要(彼岸桌面壁纸)

爬取彼岸桌面网站较为简单,用到了requests、lxml、Beautiful Soup4

立即提问
相关内容推荐