首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

深入理解TCP/IP协议的实现之accept(基于linux1.2.13)

我们解析分析tcp/ip协议的实现,这一篇讲一下accept,accept就是从已完成三次握手的连接队列里,摘下一个节点。我们可以了解到三次握手的实现和过程。很多同学都了解三次握手是什么,但是可能很少同学会深入思考或者看他的实现,众所周知,一个服务器启动的时候,会监听一个端口。其实就是新建了一个socket。那么如果有一个连接到来的时候,我们通过accept就能拿到这个新连接对应的socket。那么这个socket和监听的socket是不是同一个呢?其实socket分为监听型和通信型的。表面上,服务器用一个端口实现了多个连接,但是这个端口是用于监听的,底层用于和客户端通信的其实是另一个socket。所以每一个连接过来,负责监听的socket发现是一个建立连接的包(syn包),他就会生成一个新的socket与之通信(accept的时候返回的那个)。我们将会从代码中看到这个实现。 我们从accept函数开始,详细分析这个过程。

02
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    设计模式(二十四) 访问者模式

    访问者模式是一种行为设计模式,它定义了访问者访问一个对象的方法,并给不同的访问者提供不同的访问方式。访问者模式适用于需要在不修改对象结构的情况下向对象添加新功能或修改功能的情况。它通过将算法和对象结构分离来提高代码的可维护性和可重用性。访问者模式的关键在于定义一个访问者接口,该接口包含一个访问方法,该方法被调用时,将会访问指定的对象。对于每个对象,实现一个accept方法来处理访问者的访问。在访问者模式中,对象本身并不知道访问者的存在,而是通过访问者接口与访问者进行交互。访问者模式可以用于实现状态模式、观察者模式、模版方法模式等设计模式。

    06

    jdk8新特性之双冒号 :: 用法及详解

    jdk8的新特性有很多,最亮眼的当属函数式编程的语法糖,本文主要讲解下双冒号::的用法。 概念 类名::方法名,相当于对这个方法闭包的引用,类似js中的一个function。比如: Function<String,String> func = String::toUpperCase; (Function在java.util.function包下,也是jdk8新加入的类,同级目录下有很多函数式编程模型接口,比如Consumer/Predicate/Operator等) func相当于一个入参和出参都为String的函数,可以直接 func.apply("abc") 接收一个参数,返回一个结果("ABC")。也可以用于代替下面的Lambda表达式: List<String> l = Arrays.asList("a","b","c"); l.stream().map(s -> s.toUpperCase()); l.stream().map(func); 下面自定义一个函数式接口 public class MyConsumer<String> implements Consumer<String> { @Override public void accept(String s) { System.out.println(s); } } 下面这俩种写法等价: List<String> l = Arrays.asList("a","b","c"); l.forEach(new MyConsumer<>()); l.forEach(s -> System.out.println(s)); 但是,这种写法却不行,编译失败: l.forEach(MyConsumer::accept); 因为MyConsumer的accept方法不是静态的,如果想使用这个方法,需要一个实例,还需要一个入参,共俩个参数。而List.forEach中需要的是consumer类型,相当于s -> {...},只有一个参数。 下面详细分析双冒号使用的各种情况 新建一个类,里面声明四个代表各种情况的方法: public class DoubleColon { public static void printStr(String str) { System.out.println("printStr : " + str); } public void toUpper(){ System.out.println("toUpper : " + this.toString()); } public void toLower(String str){ System.out.println("toLower : " + str); } public int toInt(String str){ System.out.println("toInt : " + str); return 1; } } 把它们用::提取为函数,再使用: Consumer<String> printStrConsumer = DoubleColon::printStr; printStrConsumer.accept("printStrConsumer"); Consumer<DoubleColon> toUpperConsumer = DoubleColon::toUpper; toUpperConsumer.accept(new DoubleColon()); BiConsumer<DoubleColon,String> toLowerConsumer = DoubleColon::toLower; toLowerConsumer.accept(new DoubleColon(),"toLowerConsumer"); BiFunction<DoubleColon,String,Integer> toIntFunction = DoubleColon::toInt; int i = toIntFunction.apply(new DoubleColon(),"toInt"); 非静态方法的第一个参数为被调用的对象,后面是入参。静态方法因为jvm已有对象,直接接收入参。 再写一个方法使用提取出来的函数: public class TestBiConsumer { public void test(BiConsumer<DoubleColon,String> consumer){ System.out.println("do s

    01
    领券