高级API(UDP连接Map集合Collection集合)

news/2024/5/18 11:52:17 标签: udp, 网络协议, 网络, eclipse

.UDP协议:

DatagramSocket---该对象可以代表接收端也可以代表发送端
DatagramPacket-----数据打包对象(数据报对象--将发送的内容通过该对象进行打包,在通过指定的方法将该对象进行传输)
    

1.通过DatagramSocket建立发送端对象
 *     2.准备数据
 *     3.通过DatagramPacket进行数据打包
 *     4.通过发送端对象调用发送内容的方法即可
 *     5.关闭资源

UDP协议详解(无连接)
 (1)将数据、源、目的封装成数据包,不需要建立连接

(2) 每个数据报的大小限制在64K内(以容器的形式进行发送)

(3) 发送不管对方是否准备好,接收方收到也不确认,故是不可靠的

(4) 可以广播发送

(5) 发送数据结束时无需释放资源,开销小,速度快

基本格式:

1.创建接受端&&发送端

DatagramSocket ds = new DatagramSocket(8989);

2.准备数据
        String content = "小花,今晚我们看个电影。";
3.创建数据报对象
        DatagramPacket dp = null;

4.通过发送端对象调用发送内容的方法即可

db=new DatagramPacket(buf, length, address, port)

        buf 发送的内容        content.getBytes()
        length 内容的大小        content.getBytes().length
        address  发送指定的接收端(IP地址)InetAddress.getByName("127.0.0.1")
        port 端口号        8989

5.接收&&发送的方法来激活

        ds.receive(dp);//接收
        ds.send(dp);//发送

关闭资源
        ds.close();

       
Collection集合:

ArrayList|LinkedList|Vector

List<String> list = new ArrayList<String>();

方法:

//        list.add("agds");
//        size()
//        clear
//        get
//        contains
//        isEmpty
//        remove

Map集合:

        双列集合就是一次可以加2个数据

        存储数据是以键值对的形式进行存储    

        键是唯一    值可以重复        

        常用的实现类  HashMap

List|Set
        List:有序   元素可重复

        Set:无序    唯一     

String key = next.getKey();//键

String Value=new.getValue;//值

1.创建一个Map集合
        Map map = new HashMap();

2.调用方法

新增
        map.put("杨过", "小笼包");
        map.put("彭勇", "翠花");
        map.put("老王", "熊妹");
        map.put("唐烨", "王寡妇");
        map.put("瑜伽", "王寡妇");
        //大小
       System.out.println(map.size());//5
       //clear清空
       map.clear();
      System.out.println(map.size());
       //判断集合是否为空
       System.out.println(map.isEmpty());

map集合调用entrySet方法将map集合中的键值对封装成Entry实体对象返回Set集合
        Set<Entry<String, String>> entrySet = map.entrySet();
        //set通过迭代器遍历
        Iterator<Entry<String, String>> iterator = entrySet.iterator();
        while(iterator.hasNext()) {
            Entry<String, String> next = iterator.next();
            System.out.println(next.getKey()+"--"+next.getValue());
        }
       


 

        
        


http://www.niftyadmin.cn/n/1830861.html

相关文章

oracle 日志组扩容,oracle 11g 更改日志组大小

1、创建新的日志组1.alter database add logfile group 4 (‘/u01/app/oracle/oradata/jian/redo04.log’) size 1024k;2.alter database add logfile group 5 (‘/u01/app/oracle/oradata/jian/redo05.log’) size 1024k;2、切换当前日志到新的日志组1.alter system switch lo…

pg_bulkload批量载入工具(初探)

2019独角兽企业重金招聘Python工程师标准>>> 安装&#xff1a; # tar -zxvf pg_bulkload-3.1.6.tar.gz # cd pg_bulkload-3.1.6 # . /home/postgres/.bash_profile # make # make install 引入扩展&#xff1a; $ psql psql (9.3.4) Type "help" for hel…

Oracle数据库(入门)

SYS----超级管理员 SYSTEM----普通管理员 SCOTT---最常见的普通用户&#xff08;使用率最高&#xff09; 默认密码&#xff1a;tiger 注意&#xff1a;第一次使用SCOTT用户&#xff0c;需要超级管理员解锁。 默认SCOTT是锁定。 开启前必须启动服务和监听 …

oracle创建只有查询,oracle创建新用户只有mes账户下四张表的查询权限

检测事业部动平衡需要查询mes系统中四张表的数据&#xff0c;需要为其创建dphuser账户&#xff0c;并赋予其只有查询权限&#xff01;具体步骤如下&#xff1a;1、以sys用户登录创建账户并赋予权限&#xff01;Sqlplus / as sysdbacreate user dphuser identified by 123456;gr…

SQL 建立临时表进行查询

SELECTmin (maxrank) as minofmaxrank FROM(SELECTmax(rank) as maxrankFROMtbl_core_staffWHEREst_ymd<now() ANDed_ymd>now() ANDstaff_cd in (,,,,,,,,,,,,,,,,,,)GROUP BYstaff_cd) t1这里是先从tbl_core_staff 表查询分组的最大值的rank 然后查询这个最大值rank组的…

Linux开机自动启动ORACLE设置

为什么80%的码农都做不了架构师&#xff1f;>>> 1.安装好Oracle数据库后: 执行 dbstart和dbshut会提示&#xff1a; [oracleoracle11g ~]$ dbstartORACLE_HOME_LISTNER is not SET, unable to auto-start Oracle Net Listener Usage: /u01/app/oracle/product/11.…

Oracle(数据管理)

1.sql语言&#xff1a;结构化查询语言 &#xff08;1&#xff09;数据定义语言: create(创建) alter(修改) drop(删除) &#xff08;2&#xff09;数据控制语言: grant(授权) revoke(撤销权限) &#xff08;3&#xff09;数据操控语言: insert(新增) d…

Oracle(内置函数)

1.转换函数 to_number to_char to_date #to_number 转换数值型 select to_number(1)1 from dual; #to_char 转换字符串型 select to_char(1) from dual; #to_date 转换日期 sysdate&#xff1a;获取系统时间 select to_char(sysdate,yyyy-mm-dd hh:mi:ss) from dual; 2.日期…