首页
学习
活动
专区
圈层
工具
发布
    • 综合排序
    • 最热优先
    • 最新优先
    时间不限
  • 来自专栏Hank’s Blog

    4-2 R语言函数 apply

    #apply函数,沿着数组的某一维度处理数据 #例如将函数用于矩阵的行或列 #与for/while循环的效率相似,但只用一句话可以完成 #apply(参数):apply(数组,维度,函数/函数名) > x <- matrix(1:16,4,4) > x [,1] [,2] [,3] [,4] [1,] 1 5 9 13 [2,] 2 6 10 14 [3,] 3 7 11 15 [4,] 4 8 12 16 >

    68610发布于 2020-09-16
  • 来自专栏趣学算法

    数据结构 第4-2讲 双向链表

    数据结构第4-2讲双向链表 链表是线性表的链式存储方式,逻辑上相邻的数据在计算机内的存储位置不一定相邻,那么怎么表示逻辑上的相邻关系呢? 可以给每个元素附加一个指针域,指向下一个元素的存储位置。

    92440发布于 2018-09-13
  • 来自专栏Java

    试题 算法训练 4-2找公倍数

    试题 算法训练 4-2找公倍数 资源限制 内存限制:256.0MB C/C++时间限制:1.0s Java时间限制:3.0s Python时间限制:5.0s 问题描述   这里写问题描述。   

    22510编辑于 2025-01-21
  • 来自专栏sringboot

    x86汇编加载用户程序-4-2

    索引寄存器的端口号是 0x3d4,可以向它写入一个值,用来指定内部的某个寄存器。比如, 两个 8 位的光标寄存器,其索引值分别是 14(0x0e)和 15(0x0f),分别用于提供光标位置的高 8 位和低 8 位。 指定了寄存器之后,要对它进行读写,这可以通过数据端口 0x3d5 来进行。 高八位 和第八位里保存这光标的位置,显卡文本模式显示标准是25x80,这样算来,当光标在屏幕右下角时,该值为 25×80-1=1999

    96430编辑于 2021-12-06
  • 来自专栏博客专享

    【高薪程序员必看】万字长文拆解Java并发编程!(4-2):悲观锁底层原理与性能优化实战

    而悲观锁作为Java并发中最「简单粗暴」的解决方案,从JDK1.0时代的重量级锁⛓️,到如今JVM层级的锁升级优化⚡,其底层实现堪称一部高性能并发的发展史。 **​(偏向锁/轻量级锁的取舍智慧) ​** 高并发场景下如何规避锁的性能陷阱? 公平锁选择:ReentrantLock允许选择公平锁或者非公平锁.synchronized只有非公平锁 在公平锁模式下,等待时间最长的线程将优先获取锁的访问权限,按先入先得的方式,防止饥饿现象出现,但是会降低并发度 扩展学习 ​推荐书籍 《Java并发编程实战》 《并发编程的艺术》 ​实战项目 实现一个带性能统计的锁装饰器 对比不同锁在秒杀场景的表现 一句话总结 "悲观锁用性能换取安全,而真正的艺术在于找到那个平衡点

    19900编辑于 2025-05-20
  • 来自专栏育种数据分析之放飞自我

    笔记 | GWAS 操作流程4-2:LM模型+数值协变量

    上一篇,我们介绍了数量性状进行GWAS的一般线性模型分析的方法(笔记 | GWAS 操作流程4:LM模型assoc),这里我们考虑一下数字协变量,然后用R语言进行对比。

    1.5K20发布于 2020-05-26
  • 来自专栏cwl_Java

    C++编程之美-数学之趣(代码清单4-2)

    代码清单4-2 struct point { double x, y; }; double Product(point A, point B, point C) { return

    30730编辑于 2022-11-30
  • 来自专栏Android点滴积累

    IOS Widget(4-2):创建可配置小组件(动态修改配置数据)

      上一篇文章,讲解了如果通过配置修改小组件行为,只不过配置数据是写死的,本文将继续探索配置数据的高级用法,配置数据在小组件中动态创建的

    4.2K11发布于 2021-05-10
  • 来自专栏历史专栏

    【愚公系列】2021年12月 攻防世界-进阶题-MISC-072(4-2)

    文章目录 一、4-2 二、答题步骤 1.词频分析 总结 一、4-2 题目链接:https://adworld.xctf.org.cn/task/task_list?

    60220编辑于 2021-12-09
  • 来自专栏AI机器学习与深度学习算法

    机器学习入门 4-2 scikit-learn中的机器学习算法封装

    本系列是《玩转机器学习教程》一个整理的视频笔记。本小节主要介绍使用sklearn实现KNN算法。

    1.1K00发布于 2019-11-13
  • 来自专栏以终为始

    顺序表应用4-2:元素位置互换之逆置算法(数据改进)(SDUT 3663)

    一个长度为len(1<=len<=1000000)的顺序表,数据元素的类型为整型,将该表分成两半,前一半有m个元素,后一半有len-m个元素(1<=m<=len),设计一个时间复杂度为O(N)、空间复杂度为O(1)的算法,改变原来的顺序表,把顺序表中原来在前的m个元素放到表的后段,后len-m个元素放到表的前段。 注意:交换操作会有多次,每次交换都是在上次交换完成后的顺序表中进行。

    42010编辑于 2023-03-09
  • 来自专栏cloudskyme

    并发,又是并发

    对比串联执行和并发执行 ``` java? : 循环次数 并发执行时间 串联执行时间 一百万 2ms 4ms 十万 2ms 2ms 一万 1ms 0ms 通过数据的对比我们可以看出。 在一万以下的循环次数时,串联的执行速度比并发的执行速度块。是因为线程上下文切换导致额外的开销。 死锁与活锁的区别,死锁与饥饿的区别? 这种划分是使用并发度获得的,它是 ConcurrentHashMap 类构造函数的一个可选参数,默认值为 16,这样在多线程情况下就能避免争用。 同时加入了更多的辅助变量来提高并发度,具体内容还是查看源码吧。 volatile 变量和 atomic 变量有什么不同?

    1.6K41发布于 2020-06-15
  • 来自专栏look Java

    😀 Java并发 - (并发基础)

    Java并发 - (并发基础) 1、什么是共享资源 堆是被所有线程共享的一块内存区域。在虚拟机启动时创建。此内存区域的唯一目的就是存放对象实例 Java中几乎所有的对象实例都在这里分配内存。 如下图: 2、并发编程的难点 原子性问题 操作系统做任务切换(CPU切换),可以发生在任何一条CPU指令执行完成后; CPU能保证的原子操作是指令级别的,而不是高级语言的操作符(例如:n++)。 为了提高性能,编译器和处理器常常会对指令做重排序; 重排序不会影响单线程的执行结果,但是在并发情况下,可能会出现诡异的BUG。 参考地址:https://zhuanlan.zhihu.com/p/298448987 3、JMM 并发编程的关键目标 并发编程需要处理两个关键问题,即线程之间如何通信和同步。 并发编程的内存模型 共有两种并发编程模型:共享内存模型、消息传递模型,Java采用的是前者。

    59410编辑于 2023-12-07
  • 来自专栏ReganYue's Blog

    Go并发之CSP并发模型、协程并发

    Go并发之CSP并发模型、协程并发 什么是CSP并发模型 CSP 即通信顺序进程、交谈循序程序,又被译为交换消息的循序程序(communicating sequential processes),它是一种用来描述并发性系统之间进行交互的模型 但是容易出现死锁的情况,且未给予直接的并行支持,并行需要建立在并发的基础之上。 在CSP模型里面,进程间需要经过一种被称为管道来进行通信。 通过管道能够实现百万级的并发。如果说线程是抢占式的,那么协程是协作式的。在协程里面,也是通过管道来调度的。 解放线程对CPU和内存的开销,线程是先占用CPU和内存后才调度,而协程是通过通信发送信号来调度,协程全是通过管道,由于协程的消耗比线程小很多,所以能够实现百万并发。 8G内存的电脑,用JAVA,C来做并发,差不多也就千级并发,而用GO语言,通过管道可以让并发能力得到很大提升。

    1.2K10发布于 2021-09-16
  • 来自专栏ImportSource

    并发编程-并发的简史

    1.1.A(Very)Brief History of Concurrency 并发的简史 在很久以前,计算机没有操作系统;他们只执行一个程序,从头到尾的执行,并且这个程序直接访问机器的所有资源。 线程还提供了一个自然的分解模式,这种模式可以充分的利用多处理器系统中的硬件的并发性。 在同一个program中的多个线程可以被并行的调度到多个cpu上。

    1.2K70发布于 2018-04-03
  • 来自专栏蛋蛋编程手记

    并发map并发设计演进

    concurrentHashMap的底层指导思想之前有提过,就是通过细化锁的粒度来优化并发情况下的锁冲突从而实现高性能的。这种思想在很多设计中都能看到,比如Innodb的行级锁概念。 jdk1.8之前,并发map通过引入segment来细化锁的粒度,就是把原本的数组分到多个不同的段里,每个段单独管理自己的数组,段与段之间不冲突,即使数组扩容也是段内部的数组扩容。 segment长度默认是16,可以构造时指定,后面不会变化,所以并发度主要还是看segment的个数了。 数据越多并发冲突的概率越大 jdk1.8废弃了segment的概念,锁粒度更加的细化,直接给数组的链首或树根元素加锁。只要没有hash冲突就没有并发冲突。数据多了,数组会扩容,并发冲突的概率并没有变大

    53920编辑于 2022-07-27
  • 来自专栏全栈程序员必看

    Jmeter并发测试_并发测试

    jmeter并发测试报错 请大神给指点一下是因为什么报错,并发循环1-5次的时候不会报错,循环多次就开始报错了。 版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。

    1.7K30编辑于 2022-11-11
  • 来自专栏数据云团

    并发篇-python并发通信

    使用多线程实现并发服务器与使用多进程实现并发服务器 ? python支持的并发分为多线程并发和多进程并发还有异步IO。 多进程并发即运行多个独立的程序,优势在于并发处理的任务都由操作系统管理,不足之处在于程序与各进程之间的通信和数据共享不方便; 多线程并发则由程序员管理并发处理的任务,这种并发方式可以方便地在线程间共享数据 对于计算密集型程序,多进程并发优于多线程并发。 对于多进程并发,python支持两种实现方式 一种是采用进程安全的数据结构:multiprocessing.JoinableQueue,这种数据结构自己管理“加锁”的过程,程序员无需担心“死锁”的问题;

    1.3K10发布于 2019-07-18
  • 来自专栏产品优化

    Java 并发编程·Java 并发

    Java 并发 线程状态转换 新建(New) 创建后尚未启动。 可运行(Runnable) 可能正在运行,也可能正在等待 CPU 时间片。 它是 JUC 并发包中的核心基础组件。 CountDownLatch 用来控制一个或者多个线程等待多个线程。 以下代码模拟了对某个服务的并发请求,每次只能有 3 个客户端同时访问,请求总数为 10。 在 Java 内存模型中,允许编译器和处理器对指令进行重排序,重排序过程不会影响到单线程程序的执行,却会影响到多线程并发执行的正确性。 互斥同步属于一种悲观的并发策略,总是认为只要不去做正确的同步措施,那就肯定会出现问题。

    3.4K32编辑于 2022-12-01
  • 来自专栏别先生

    Java并发编程与高并发之线程并发容器

    可以使用此程序进行并发测试。 34 // 线程池调度的时候加上并发控制。给定一个值代表运行的并发数目。 35 // 3代表并发的数目,控制台打印一次执行三次。 34 // 线程池调度的时候加上并发控制。给定一个值代表运行的并发数目。 35 // 3代表并发的数目,一次获取3个许可,控制台每次打印1个。 35 // 线程池调度的时候加上并发控制。给定一个值代表运行的并发数目。 36 // 3代表并发的数目,一次获取3个许可,控制台每次打印1个。 36 // 线程池调度的时候加上并发控制。给定一个值代表运行的并发数目。 37 // 3代表并发的数目,一次获取3个许可,控制台每次打印1个。

    1.9K20发布于 2020-02-18
领券