- ioctlsocket()函数
Great_Blue_sea
windows编程socketcmdwindowspascalstream通讯
简述:控制套接口的模式。#includeintPASCALFARioctlsocket(SOCKETs,longcmd,u_longFAR*argp);s:一个标识套接口的描述字。cmd:对套接口s的操作命令。argp:指向cmd命令所带参数的指针。注释:本函数可用于任一状态的任一套接口。它用于获取与套接口相关的操作参数,而与具体协议或通讯子系统无关。支持下列命令:FIONBIO:允许或禁止套接口
- RTSPSERVER 遇到的函数
狗狗狗乖乖
音视频入门服务器运维音视频网络tcp/ip视频编解码
ioctlsocket◆I/O操作函数:主要用于获取与套接字相关的操作参数。intioctlsocket(SOCKETs,longcmd,u_longFAR*argp);s为I/O操作的套接字。cmd为对套接字的操作命令。argp为命令所带参数的指针。常见的命令://确定套接字自动读入的数据量FIONBIO:允许或禁止套接口s的非阻塞模式。argp指向一个无符号长整型。如允许非阻塞模式则非零,如禁
- socket网络编程中设置socket选项的ioctlsocket、setsockopt和WSAIoctl函数的使用(附源码)
dvlinker
C/C++技术分享socket网络编程socket选项ioctlsocketsetsockoptWSAIoctl源码
VC++常用功能开发汇总(专栏文章列表,欢迎订阅,持续更新...)https://blog.csdn.net/chenlycly/article/details/124272585C++软件异常排查从入门到精通系列教程(专栏文章列表,欢迎订阅,持续更新...)https://blog.csdn.net/chenlycly/article/details/125529931C++软件分析工具从入门到
- VS,C++ 中error LNK2001: 无法解析的外部符号 __imp__socket@12
GreenHandBruce
VSC++win32工程
errorLNK2001:无法解析的外部符号__imp__WSAStartup@8errorLNK2001:无法解析的外部符号__imp__socket@12errorLNK2001:无法解析的外部符号__imp__ioctlsocket@12errorLNK2001:无法解析的外部符号__imp__htons@4errorLNK2001:无法解析的外部符号__imp__inet_addr@4er
- VC++ socket编程中设置socket选项的ioctlsocket、setsockopt和WSAIoctl函数的使用(附源码)
dvlinker
VC++常用功能代码封装socket选项ioctlsocketsetsockoptWSAIoctl
在socket编程中,我们时常要设置socket套接字相关选项,设置不同的选项要调用的函数可能是不一样的,比如ioctlsocket、setsockopt和WSAIoctl函数。这三个函数很容易混淆,今天我们就来讲讲这几个函数主要是用来设置哪些选项的。1、ioctrlsocket函数ioctlsocket函数主要是用来设置或取消非阻塞套接字的。将套接字设置为非阻塞式套接字后,connect、sen
- WinSock Select模型
努力的桃之助
项目地址1.WinSock套接字有阻塞模式和非阻塞模式两种,可用ioctlsocket函数设置,cmd使用FIONBIO,0为阻塞。阻塞socket,又被称为锁定状态的socket。非阻塞socket,又被称为非锁定状态的socket。当调用一个WindowsAPI时,API的调用会耗费一定的CPU时间。当一个操作完成之后才返回到用户态,称其为阻塞,反之,则为非阻塞。2.WinSock套接字IO模
- Socket 学习总结
三省于身
Socket
接下来要总结的是TCPsocket通信socket分为阻塞式和非阻塞式的,下面一个个介绍。socket默认是阻塞式的,你需要手动设置非阻塞属性,才能达到非阻塞。windows下面使用如下函数设置非阻塞ioctlsocket(SockClient,FIONBIO,&flag)//flag==0代表阻塞flag==1代表的是非阻塞linux使用如下函数设置非阻塞fcntl(m_sock,F_SETFL
- 我常用的 socket connect 代码,主要是为了记录非阻塞问题
ExperiencesOfCode
网络技术C++socketstructnullstream网络
SOCKETconnectToS(){inte=0;structtimevaltimeout;fd_setr;SOCKETs=socket(AF_INET,SOCK_STREAM,0);//设置非阻塞方式连接unsignedlongul1=1;e=ioctlsocket(s,FIONBIO,(unsignedlong*)&ul1);if(e==SOCKET_ERROR){fprintf(stder
- 网络小记:SOCKET
玉子烧
网络
SOCKET1、::ioctlsocket(handle,FIONBIO,&arg)问:异步和同步是不是用ioctlsocket(s,FIONBIO,&ulBlocking);就可以设置。设置成功后recv,send也是异步的?答:准确的讲不是的.是否同步还是异步看你初使化Socket时就自动生成了.如果你用WSAStartup()初使化,那么就是同步的.如果你用WSAAsyncSelect初使化
- WebSphere MQ 问题和变通方法
yangf1275
与WebSphereMQ相关的问题和变通方法包括如下内容:问题:创建队列管理器时出错。Amqerr*.log文件中的错误如下:AMQ9213:AcommunicationserrorforTCP/IPoccurred.解释:通信中出现意外的错误。操作:来自TCP/IP(ioctlsocket)的返回码调用是10038(X'2736')。记录这些值,并告诉系统管理员。变通方法:10038返回码指明,
- socket连接服务器立即返回,不用三次握手
weixin_30414245
因为默认用socket的connect去连接需要三次握手,时间比较长,所以为了提高效率,有一种方法可以解决:unsignedlongiMode=1;fd_setWrite,Err;ioctlsocket(sock,FIONBIO,&iMode);//先将socket设置为非阻塞的,connect(sock,(structsockaddr*)addr,sizeof(addr));//然后去连接,它会
- 大侠们帮忙看一下,为什么我一到recv()就卡住了呢?
weixin_33755557
2019独角兽企业重金招聘Python工程师标准>>>调用recv,如果对方没有数据过来就阻塞住了。只有下面情况才会返回:a.对方向你发送了数据;b.对方关闭了连接。建议用异步socket或同步非阻塞socket,用select确定何时数据到达。.非常感谢~~现在我是移植到windows上,select不能用吧,再就是我用如下的方法设置非阻塞对吧,flags=1;ioctlsocket(svr_c
- ioctlsocket()
weixin_33728708
ioctlsocket()是控制套接口的模式。外文名ioctlsocket()含义控制套接口的模式头文件#include性质函数目录1简述:2注释:▪FIONBIO:▪FIONREAD:▪SIOCATMARK:3兼容性:4返回值:5参见:6使用方法:简述:编辑控制套接口的模式。#includeintPASCALFARioctlsocket(SOCKETs,longcmd,u_longFAR*arg
- Socket 开发头文件及库文件
jEAmIng1012
Socket
#include"Socket.h"#include"GetProfileSet.h"#include#include#include#include#include1>Socket.obj:errorLNK2001:无法解析的外部符号__imp__WSAGetLastError@01>Socket.obj:errorLNK2001:无法解析的外部符号__imp__ioctlsocket@121>
- ioctl函数
遥望未来_cheerup
网络编程
ioctl函数用于在套接字上控制套接字的I/O行为,同时获取与套接字挂起的I/O操作的有关信息。1)第一个ioctl函数是ioctlsocket,其起源于Winsock1规范,其定义如下:intioctlsocket(SOCKETs,longcmd,u_longFAR*argp;);s:为要进行I/O操作的套接字描述符。cmd:一个预定义的标志,用在将执行的I/O控制命令上。argp:为一个指针,
- ioctlsocket函数全面解析
H-KING
网络编程深入研究网络编程
说明:这篇博客算不得是原创,是我那里切一块这里剪一块凑来的。先看看MSDN标准解释intioctlsocket(SOCKETs,longcmd,u_longFAR*argp);Parameterss[in]Descriptoridentifyingasocket.cmd[in]Commandtoperformonthesockets.argp[in,out]Pointertoaparameterf
- 非阻塞模式的设置、设置socket为非阻塞模式 解决connect阻塞问题
dadalan
intiMode=1;//0:阻塞ioctlsocket(socketc,FIONBIO,(u_longFAR*)&iMode);//非阻塞设置rs=recvfrom(socketc,rbuf,sizeof(rbuf),0,(SOCKADDR*)&addr,&len);intioctlsocket(SOCKETs,longcmd,u_longFAR*argp);s[in]Adescriptorid
- ioctl() fcntl() setsockopt() ioctlsocket() 用法
Richard__Lee
intioctl(intd,intrequest,...);后续是否有参数根据第二个参数request的需要来决定。ioctl用于硬件设备I/O通道控制,控制命令与参数都与设备高度相关,通常也与系统高度相关。intfcntl(intfd,intcmd,.../*arg*/);后续是否有参数根据第二个参数cmd的需要来决定。这点两者相同。操作控制的对象是:文件描述符。ioctl()是底层的系统调用(
- socket超时设置 之 ioctlsocket 函数全面解析
cs_zyx
C++和HTTP
先看看MSDN标准解释intioctlsocket(SOCKETs,longcmd,u_longFAR*argp);Parameterss[in]Descriptoridentifyingasocket.cmd[in]Commandtoperformonthesockets.argp[in,out]Pointertoaparameterforcmd.ReturnValuesUponsuccessf
- TCPIP设置为非阻塞、发送延时、缓冲区大小等
男
网络编程
在TCPIP网络编程中,需要根据项目需要设置信息。1.设置为非阻塞模式,即想在listen,send,rev函数立即返回,而不是阻塞在那里,在bind之前调用unsignedlongon_windows=1;intiRet=ioctlsocket(m_sock,FIONBIO,&on_windows);if(iRet!=NO_ERROR)//shejn2017/11/1418:56:29设置为非阻
- lwIP TCP/IP 协议栈笔记之十八: Socket接口编程
专业游手好闲
TCP/IP嵌入式开发LWIP
目录1.Socket概述2.LwIP中的socket3.SocketAPI3.1socket()3.2bind()3.3connect()3.4listen()3.5accept()3.6read()、recv()、recvfrom()3.7sendto()3.8send()3.9write()3.10close()3.11ioctl()、ioctlsocket()3.12setsockopt()
- ioctl 设置非阻塞SOCKET函数
Timmy_zhou
windows方法:u_longmode=0;ioctlsocket(s,FIONBIO,&mode);控制为阻塞方式。u_longmode=1;ioctlsocket(s,FIONBIO,&mode);控制为非阻塞方式。setsockopt()简述:设置套接口的选项。#includeintPASCALFARsetsockopt(SOCKETs,intlevel,intoptname,constc
- C/C++网络编程在windows和linux中将socket设置为阻塞和非阻塞
夏曹俊
socket网络编程阻塞C/C++
C/C++网络编程在windows和linux中将socket设置为阻塞和非阻塞在socket编程中,对于socket的读写默认都是阻塞的,但有的情况我们需要将其设置为非阻塞,比如做多路复用,或者通过select实现连接超时等功能,将socket设置为非阻塞,在windows和linux中的接口有所不同,在windows中使用ioctlsocket函数,在linux中使用fcntl函数,下面我们做
- SETSOCKOPT IOCTLSOCKET 设置非阻塞SOCKET函数
lichao19881026
1,ioctlsocket()#include ThisfunctioncontrolstheI/Omodeofasocket.int ioctlsocket(
SOCKET s,
long cmd,
u_long FAR* argp
); Parameters s[in]Descriptoridentifyingasocket.cmd[in]Commandtoperformonsoc
- ioctlsocket
服务器
控制套接口的模式。#includeintPASCALFARioctlsocket(SOCKETs,longcmd,u_longFAR*argp);s:一个标识套接口的描述字。cmd:对套接口s的操作命令。argp:指向cmd命令所带参数的指针。注释:本函数可用于任一状态的任一套接口。它用于获取与套接口相关的操作参数,而与具体协议或通讯子系统无关。支持下列命令:FIONBIO:允许或禁止套接口s的非
- 关于accept 返回的socket的阻塞属性
emilio563
网络编程
测试结果返回的这个socket也是阻塞的,同其他socket默认形式相同。(xp,vs08)recv函数一直卡在那。当手动设置后,即可:newconnection=accept(listeningSocket,(SOCKADDR*)&clientAddr,&len);u_longulFlag=1;ioctlsocket(newconnection,FIONBIO,&ulFlag);//过后recv
- ioctlsocket()
zzyoucan
ioctlsocket()是控制套接口的模式。外文名ioctlsocket()含 义控制套接口的模式头文件#include性 质函数目录1 简述:2 注释:▪ FIONBIO:▪ FIONREAD:▪ SIOCATMARK:3 兼容性:4 返回值:5 参见:6 使用方法:简述:编辑控制套接口的模式。#includeintPASCALFARioctlsocket( SOCKET s,lo
- 套接字模式
凡尘网络
I/O模型6种:阻塞模型,选择模型,WSAAsyncSelect模型,WSAEventSelect模型,重叠模型,完成端口模型阻塞模式:执行IO的winsock调用一直到操作完成才返回好处:使用简单,当处理多个套接字连接时,必须创建多个线程。典型的一个连接使用一个线程非阻塞模式下:winsock函数会立即返回调用ioctlsocket函数显示让套接字工作在非阻塞模式下:u_longul=1;
S
- winsock ioctlsocket() 用法
socket
ioctlsocket() 用法
◆I/O操作函数:主要用于获取与套接字相关的操作参数。 int ioctlsocket(SOCKET s, long cmd, u_long FAR * arg
- winsock setsockopt详解
set
浅析:setsockopt()
1,ioctlsocket()
#include <winsock.h>
This function controls the I/O mode of a socket.
int ioctlsocket(
SOCKET s,
long cmd,
u_long FAR* argp
);
- 关于旗正规则引擎规则中的上传和下载问题
何必如此
文件下载压缩jsp文件上传
文件的上传下载都是数据流的输入输出,大致流程都是一样的。
一、文件打包下载
1.文件写入压缩包
string mainPath="D:\upload\"; 下载路径
string tmpfileName=jar.zip; &n
- 【Spark九十九】Spark Streaming的batch interval时间内的数据流转源码分析
bit1129
Stream
以如下代码为例(SocketInputDStream):
Spark Streaming从Socket读取数据的代码是在SocketReceiver的receive方法中,撇开异常情况不谈(Receiver有重连机制,restart方法,默认情况下在Receiver挂了之后,间隔两秒钟重新建立Socket连接),读取到的数据通过调用store(textRead)方法进行存储。数据
- spark master web ui 端口8080被占用解决方法
daizj
8080端口占用sparkmaster web ui
spark master web ui 默认端口为8080,当系统有其它程序也在使用该接口时,启动master时也不会报错,spark自己会改用其它端口,自动端口号加1,但为了可以控制到指定的端口,我们可以自行设置,修改方法:
1、cd SPARK_HOME/sbin
2、vi start-master.sh
3、定位到下面部分
- oracle_执行计划_谓词信息和数据获取
周凡杨
oracle执行计划
oracle_执行计划_谓词信息和数据获取(上)
一:简要说明
在查看执行计划的信息中,经常会看到两个谓词filter和access,它们的区别是什么,理解了这两个词对我们解读Oracle的执行计划信息会有所帮助。
简单说,执行计划如果显示是access,就表示这个谓词条件的值将会影响数据的访问路径(表还是索引),而filter表示谓词条件的值并不会影响数据访问路径,只起到
- spring中datasource配置
g21121
dataSource
datasource配置有很多种,我介绍的一种是采用c3p0的,它的百科地址是:
http://baike.baidu.com/view/920062.htm
<!-- spring加载资源文件 -->
<bean name="propertiesConfig"
class="org.springframework.b
- web报表工具FineReport使用中遇到的常见报错及解决办法(三)
老A不折腾
finereportFAQ报表软件
这里写点抛砖引玉,希望大家能把自己整理的问题及解决方法晾出来,Mark一下,利人利己。
出现问题先搜一下文档上有没有,再看看度娘有没有,再看看论坛有没有。有报错要看日志。下面简单罗列下常见的问题,大多文档上都有提到的。
1、repeated column width is largerthan paper width:
这个看这段话应该是很好理解的。比如做的模板页面宽度只能放
- mysql 用户管理
墙头上一根草
linuxmysqluser
1.新建用户 //登录MYSQL@>mysql -u root -p@>密码//创建用户mysql> insert into mysql.user(Host,User,Password) values(‘localhost’,'jeecn’,password(‘jeecn’));//刷新系统权限表mysql>flush privileges;这样就创建了一个名为:
- 关于使用Spring导致c3p0数据库死锁问题
aijuans
springSpring 入门Spring 实例Spring3Spring 教程
这个问题我实在是为整个 springsource 的员工蒙羞
如果大家使用 spring 控制事务,使用 Open Session In View 模式,
com.mchange.v2.resourcepool.TimeoutException: A client timed out while waiting to acquire a resource from com.mchange.
- 百度词库联想
annan211
百度
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>RunJS</title&g
- int数据与byte之间的相互转换实现代码
百合不是茶
位移int转bytebyte转int基本数据类型的实现
在BMP文件和文件压缩时需要用到的int与byte转换,现将理解的贴出来;
主要是要理解;位移等概念 http://baihe747.iteye.com/blog/2078029
int转byte;
byte转int;
/**
* 字节转成int,int转成字节
* @author Administrator
*
- 简单模拟实现数据库连接池
bijian1013
javathreadjava多线程简单模拟实现数据库连接池
简单模拟实现数据库连接池
实例1:
package com.bijian.thread;
public class DB {
//private static final int MAX_COUNT = 10;
private static final DB instance = new DB();
private int count = 0;
private i
- 一种基于Weblogic容器的鉴权设计
bijian1013
javaweblogic
服务器对请求的鉴权可以在请求头中加Authorization之类的key,将用户名、密码保存到此key对应的value中,当然对于用户名、密码这种高机密的信息,应该对其进行加砂加密等,最简单的方法如下:
String vuser_id = "weblogic";
String vuse
- 【RPC框架Hessian二】Hessian 对象序列化和反序列化
bit1129
hessian
任何一个对象从一个JVM传输到另一个JVM,都要经过序列化为二进制数据(或者字符串等其他格式,比如JSON),然后在反序列化为Java对象,这最后都是通过二进制的数据在不同的JVM之间传输(一般是通过Socket和二进制的数据传输),本文定义一个比较符合工作中。
1. 定义三个POJO
Person类
package com.tom.hes
- 【Hadoop十四】Hadoop提供的脚本的功能
bit1129
hadoop
1. hadoop-daemon.sh
1.1 启动HDFS
./hadoop-daemon.sh start namenode
./hadoop-daemon.sh start datanode
通过这种逐步启动的方式,比start-all.sh方式少了一个SecondaryNameNode进程,这不影响Hadoop的使用,其实在 Hadoop2.0中,SecondaryNa
- 中国互联网走在“灰度”上
ronin47
管理 灰度
中国互联网走在“灰度”上(转)
文/孕峰
第一次听说灰度这个词,是任正非说新型管理者所需要的素质。第二次听说是来自马化腾。似乎其他人包括马云也用不同的语言说过类似的意思。
灰度这个词所包含的意义和视野是广远的。要理解这个词,可能同样要用“灰度”的心态。灰度的反面,是规规矩矩,清清楚楚,泾渭分明,严谨条理,是决不妥协,不转弯,认死理。黑白分明不是灰度,像彩虹那样
- java-51-输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字。
bylijinnan
java
public class PrintMatrixClockwisely {
/**
* Q51.输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字。
例如:如果输入如下矩阵:
1 2 3 4
5 6 7 8
9
- mongoDB 用户管理
开窍的石头
mongoDB用户管理
1:添加用户
第一次设置用户需要进入admin数据库下设置超级用户(use admin)
db.addUsr({user:'useName',pwd:'111111',roles:[readWrite,dbAdmin]});
第一个参数用户的名字
第二个参数
- [游戏与生活]玩暗黑破坏神3的一些问题
comsci
生活
暗黑破坏神3是有史以来最让人激动的游戏。。。。但是有几个问题需要我们注意
玩这个游戏的时间,每天不要超过一个小时,且每次玩游戏最好在白天
结束游戏之后,最好在太阳下面来晒一下身上的暗黑气息,让自己恢复人的生气
&nb
- java 二维数组如何存入数据库
cuiyadll
java
using System;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Xml;
using System.Xml.Serialization;
using System.IO;
namespace WindowsFormsApplication1
{
- 本地事务和全局事务Local Transaction and Global Transaction(JTA)
darrenzhu
javaspringlocalglobaltransaction
Configuring Spring and JTA without full Java EE
http://spring.io/blog/2011/08/15/configuring-spring-and-jta-without-full-java-ee/
Spring doc -Transaction Management
http://docs.spring.io/spri
- Linux命令之alias - 设置命令的别名,让 Linux 命令更简练
dcj3sjt126com
linuxalias
用途说明
设置命令的别名。在linux系统中如果命令太长又不符合用户的习惯,那么我们可以为它指定一个别名。虽然可以为命令建立“链接”解决长文件名的问 题,但对于带命令行参数的命令,链接就无能为力了。而指定别名则可以解决此类所有问题【1】。常用别名来简化ssh登录【见示例三】,使长命令变短,使常 用的长命令行变短,强制执行命令时询问等。
常用参数
格式:alias
格式:ali
- yii2 restful web服务[格式响应]
dcj3sjt126com
PHPyii2
响应格式
当处理一个 RESTful API 请求时, 一个应用程序通常需要如下步骤 来处理响应格式:
确定可能影响响应格式的各种因素, 例如媒介类型, 语言, 版本, 等等。 这个过程也被称为 content negotiation。
资源对象转换为数组, 如在 Resources 部分中所描述的。 通过 [[yii\rest\Serializer]]
- MongoDB索引调优(2)——[十]
eksliang
mongodbMongoDB索引优化
转载请出自出处:http://eksliang.iteye.com/blog/2178555 一、概述
上一篇文档中也说明了,MongoDB的索引几乎与关系型数据库的索引一模一样,优化关系型数据库的技巧通用适合MongoDB,所有这里只讲MongoDB需要注意的地方 二、索引内嵌文档
可以在嵌套文档的键上建立索引,方式与正常
- 当滑动到顶部和底部时,实现Item的分离效果的ListView
gundumw100
android
拉动ListView,Item之间的间距会变大,释放后恢复原样;
package cn.tangdada.tangbang.widget;
import android.annotation.TargetApi;
import android.content.Context;
import android.content.res.TypedArray;
import andr
- 程序员用HTML5制作的爱心树表白动画
ini
JavaScriptjqueryWebhtml5css
体验效果:http://keleyi.com/keleyi/phtml/html5/31.htmHTML代码如下:
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml"><head><meta charset="UTF-8" >
<ti
- 预装windows 8 系统GPT模式的ThinkPad T440改装64位 windows 7旗舰版
kakajw
ThinkPad预装改装windows 7windows 8
该教程具有普遍参考性,特别适用于联想的机器,其他品牌机器的处理过程也大同小异。
该教程是个人多次尝试和总结的结果,实用性强,推荐给需要的人!
缘由
小弟最近入手笔记本ThinkPad T440,但是特别不能习惯笔记本出厂预装的Windows 8系统,而且厂商自作聪明地预装了一堆没用的应用软件,消耗不少的系统资源(本本的内存为4G,系统启动完成时,物理内存占用比
- Nginx学习笔记
mcj8089
nginx
一、安装nginx 1、在nginx官方网站下载一个包,下载地址是:
http://nginx.org/download/nginx-1.4.2.tar.gz
2、WinSCP(ftp上传工
- mongodb 聚合查询每天论坛链接点击次数
qiaolevip
每天进步一点点学习永无止境mongodb纵观千象
/* 18 */
{
"_id" : ObjectId("5596414cbe4d73a327e50274"),
"msgType" : "text",
"sendTime" : ISODate("2015-07-03T08:01:16.000Z"
- java术语(PO/POJO/VO/BO/DAO/DTO)
Luob.
DAOPOJODTOpoVO BO
PO(persistant object) 持久对象
在o/r 映射的时候出现的概念,如果没有o/r映射,就没有这个概念存在了.通常对应数据模型(数据库),本身还有部分业务逻辑的处理.可以看成是与数据库中的表相映射的java对象.最简单的PO就是对应数据库中某个表中的一条记录,多个记录可以用PO的集合.PO中应该不包含任何对数据库的操作.
VO(value object) 值对象
通
- 算法复杂度
Wuaner
Algorithm
Time Complexity & Big-O:
http://stackoverflow.com/questions/487258/plain-english-explanation-of-big-o
http://bigocheatsheet.com/
http://www.sitepoint.com/time-complexity-algorithms/