zoukankan      html  css  js  c++  java
  • 0

    map在插入删除时,只是那个迭代器失效,其他迭代器无影响。

    unordered_map在插入删除时,大部分情况下,只是那个迭代器失效,其他迭代器无影响。但在rehash时所有迭代器都会失效

    map, set, multimap, and multiset

    上述四种容器采用红黑树实现,红黑树是平衡二叉树的一种。不同操作的时间复杂度近似为:
    插入: O(logN)

    查看:O(logN)

    删除:O(logN)

    hash_map, hash_set, hash_multimap, and hash_multiset
    上述四种容器采用哈希表实现,不同操作的时间复杂度为:
    插入:O(1),最坏情况O(N)。

    查看:O(1),最坏情况O(N)。

    删除:O(1),最坏情况O(N)。
    ---------------------
    作者:zhc_24
    来源:CSDN
    原文:https://blog.csdn.net/zhc_24/article/details/80272437
    版权声明:本文为博主原创文章,转载请附上博文链接!

     红黑树虽然是复杂的,但它的最坏情况运行时间也是非常良好的,并且在实践中是高效的: 它可以在O(log n)时间内做查找,插入和删除,这里的n 是树中元素的数目。

    哈希表,二叉搜索树都有可能退化成一条链表,最坏情况O(N)。

    //很混乱,有的说hash比红黑树快,内存占用更少,有的说多。看数据

    实现一个vector?是1.5还是2倍,各有什么优缺点?
    1.5倍优势:可以重用之前分配但是释放的内存

    2倍劣势:每次申请的内存都不可以重用

    线程同步 

    互斥锁 mutex

    条件变量cond  wait signal 必须和一个互斥锁配合

    信号量 sem pv

    读写锁

    MSS就是TCP数据包每次能够传输的最大数据分段。为了达到最佳的传输效能TCP协议在建立连接的时候通常要协商双方的MSS值,这个值TCP协议在实现的时候往往用MTU值代替(需要减去IP数据包包头的大小20Bytes和TCP数据段的包头20Bytes)所以往往MSS为1460。通讯双方会根据双方提供的MSS值得最小值确定为这次连接的最大MSS值。

    inux下进程间通信的几种主要手段简介:

    1. 管道(Pipe)及有名管道(named pipe):管道可用于具有亲缘关系进程间的通信,有名管道克服了管道没有名字的限制,因此,除具有管道所具有的功能外,它还允许无亲缘关系进程间的通信;
    2. 信号(Signal):信号是比较复杂的通信方式,用于通知接受进程有某种事件发生,除了用于进程间通信外,进程还可以发送信号给进程本身;linux除了支持Unix早期信号语义函数sigal外,还支持语义符合Posix.1标准的信号函数sigaction(实际上,该函数是基于BSD的,BSD为了实现可靠信号机制,又能够统一对外接口,用sigaction函数重新实现了signal函数);
    3. 报文(Message)队列(消息队列):消息队列是消息的链接表,包括Posix消息队列system V消息队列。有足够权限的进程可以向队列中添加消息,被赋予读权限的进程则可以读走队列中的消息。消息队列克服了信号承载信息量少,管道只能承载无格式字节流以及缓冲区大小受限等缺点。
    4. 共享内存:使得多个进程可以访问同一块内存空间,是最快的可用IPC形式。是针对其他通信机制运行效率较低而设计的。往往与其它通信机制,如信号量结合使用,来达到进程间的同步及互斥。
    5. 信号量(semaphore):主要作为进程间以及同一进程不同线程之间的同步手段。
    6. 套接口(Socket):更为一般的进程间通信机制,可用于不同机器之间的进程间通信。起初是由Unix系统的BSD分支开发出来的,但现在一般可以移植到其它类Unix系统上:Linux和System V的变种都支持套接字。

    使用协程之所以不需要加锁不是因为所有的协程只在一个线程中运行,而是因为协程的非抢占式的特点。也就是说,使用协程的话,在没主动交出CPU之前都是不会被突然切换到其它协程上的。而线程是抢占式的,使用多线程你是不能确定你的线程什么时候被操作系统调度,什么时候被切换,因此需要用锁到实现一种“原子操作”的语义。

  • 相关阅读:
    hive日期转换函数2
    hive中的日期转换函数
    Oracle的字符连接函数 concat 和 || 的区别
    Oracle的去重函数 distinct
    Oracle之常用sql
    基于 Consul 的 Docker Swarm 服务发现
    Swift原理
    Mirantis OpenStack 8.0 版本
    vmare虚拟化解决方案
    docker网络解析
  • 原文地址:https://www.cnblogs.com/l2017/p/10700872.html
Copyright © 2011-2022 走看看