A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© AllenQin 初级黑马   /  2018-12-26 08:48  /  548 人查看  /  0 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

基础知识掌握得牢固,能够让我们游刃有余的应对面试,找到更好的工作。
但是真的想要学会java,还是需要多敲代码。
1.网络编程(客服端与服务器C/S,浏览器与服务器B/S)
2.TCP:三次握手,安全,不易丢包。
UDP:速度快,容易丢包。
3.网络编程三要素:协议、IP地址、端口号。
4.端口号:是一个逻辑端口,当我们打开网络软件时,操作系统会为网络软件分配一个随机的端口号,或者网络软件在打开的时候会向系统要指定的端口号。
5.客服端和服务器端使用IO流对象(字节流对象)通信。
6.服务器端必须明确两件事情:
多个客服端同时和服务器进行交互,服务器必须明确和那个客户端进行的交互,在服务器端有一个方法,叫accept客服端获取到请求的客户端对象。
多个客户端同时和服务器进行交互,就需要使用多个IO流对象。
1.函数式接口:有且仅有一个抽象方法的接口。
2.“语法糖”是指使用更加方便,但是原理不变的代码语法。
3. @FunctionalInterface用于注解函数式接口。
4.Lambda表达式会延迟执行,可以提升性能,避免性能浪费。
1.Stream流,用于解决单列集合循环遍历的弊端。
2.所有的 Collection 集合都可以通过 stream 默认方法获取流
3.forEach方法中有一个消费型接口,会将流中的每一个元素进行处理。
4.filter方法可以将一个流转换为一个子流,可以对流进行筛选处理。
5.Stream流属于管道流,只能被消费(使用)一次
6.limit 方法可以对流进行截取,只取用前n个。
skip 方法可以跳过前几个元素,获取一个截取之后的新流
1.Junit使用:白盒测试
定义一个测试类(测试用例)
建议:
测试类名:被测试的类名Test                CalculatorTest
包名:xxx.xxx.xx.test                cn.itcast.test
定义测试方法:可以独立运行
建议:
方法名:test测试的方法名                testAdd()  
返回值:void
参数列表:空参
给方法加@Test
导入junit依赖环境
判定结果:
红色:失败
绿色:成功
一般我们会使用断言操作来处理结果
Assert.assertEquals(期望的结果,运算的结果);
注:
@Before:
修饰的方法会在测试方法之前被自动执行
@After:
修饰的方法会在测试方法执行之后自动被执行
2.反射->框架的设计灵魂
框架:半成品软件。可以在框架的基础上进行软件开发,简化编码
反射:将类的各个组成部分封装为其他对象,这就是反射机制
3.getClassLoader()  获取class文件相对路径
1.JavaWeb:使用Java语言开发互联网项目。
简单理解:使用Java语言开发网站
2.数据库的英文单词: DataBase 简称 : DB
是用于存储和管理数据的仓库。
3. 数据库的特点:
        持久化存储数据的。其实数据库就是一个文件系统
        方便存储和管理数据
        使用了统一的方式操作数据库 -- SQL
4.常见的数据库软件:Qracle、MySQL、DB2、SQLServer
5.打开mysql:cmd--> services.msc 打开服务的窗口
使用管理员打开cmd
net start mysql : 启动mysql的服务
net stop mysql:关闭mysql服务
6.SQL通用语法
                SQL 语句可以单行或多行书写,以分号结尾。
                可使用空格和缩进来增强语句的可读性。
                MySQL 数据库的 SQL 语句不区分大小写,关键字建议使用大写。
                3 种注释
                * 单行注释: -- 注释内容 或 # 注释内容(mysql 特有)
                * 多行注释: /* 注释 */
7.操作数据库、表
        操作数据库:CRUD
                C(Create):创建
                        * 创建数据库:
                                * create database 数据库名称;
                        * 创建数据库,判断不存在,再创建:
                                * create database if not exists 数据库名称;
                        * 创建数据库,并指定字符集
                                * create database 数据库名称 character set 字符集名;

                        * 练习: 创建db4数据库,判断是否存在,并制定字符集为gbk
                                * create database if not exists db4 character set gbk;
        R(Retrieve):查询
                        * 查询所有数据库的名称:
                                * show databases;
                        * 查询某个数据库的字符集:查询某个数据库的创建语句
                                * show create database 数据库名称;




        U(Update):修改
                        * 修改数据库的字符集
                                * alter database 数据库名称 character set 字符集名称;
        D(Delete):删除
                        * 删除数据库
                                * drop database 数据库名称;
                        * 判断数据库存在,存在再删除
                                * drop database if exists 数据库名称;
        使用数据库
                        * 查询当前正在使用的数据库名称
                                * select database();
                        * 使用数据库
                                * use 数据库名称;
8.操作表
                C(Create):创建
                语法:
                                create table 表名(
                                        列名1 数据类型1,
                                        列名2 数据类型2,
                                        ....
                                        列名n 数据类型n
                                );
                                * 注意:最后一列,不需要加逗号(,)
                                * 数据库类型:
                                int:整数类型
                                                * age int,
                                double:小数类型
                                                * score double(5,2)
                                date:日期,只包含年月日,yyyy-MM-dd
                                datetime:日期,包含年月日时分秒         yyyy-MM-dd HH:mm:ss
                                timestamp:时间错类型        包含年月日时分秒        yyyy-MM-ddHH:mm:ss       
                                                * 如果将来不给这个字段赋值,或赋值为null,则默认使用当前的系统时间,来自动赋值

                                varchar:字符串
                                                * name varchar(20):姓名最大20个字符
                                                * zhangsan 8个字符  张三 2个字符
                               

                        * 创建表
                                create table student(
                                        id int,
                                        name varchar(32),
                                        age int ,
                                        score double(4,1),
                                        birthday date,
                                        insert_time timestamp
                                );
                        * 复制表:
                                * create table 表名 like 被复制的表名;                 
                 R(Retrieve):查询
                        * 查询某个数据库中所有的表名称
                                * show tables;
                        * 查询表结构
                                * desc 表名;
                 U(Update):修改
                        1. 修改表名
                                alter table 表名 rename to 新的表名;
                        2. 修改表的字符集
                                alter table 表名 character set 字符集名称;
                        3. 添加一列
                                alter table 表名 add 列名 数据类型;
                        4. 修改列名称 类型
                                alter table 表 名 change 列名 新列别 新数据类型;
                                alter table 表名 modify 列名 新数据类型;
                        5. 删除列
                                alter table 表名 drop 列名;
                D(Delete):删除
                        * drop table 表名;
                        * drop table  if exists 表名 ;
public class TCP {
    public static void main(String[] args) throws IOException {
        ServerSocket ss1 = new ServerSocket(8888);
        ServerSocket ss2 = new ServerSocket(9527);
        while (true) {
            Socket so1 = ss1.accept();
            Socket so2 = ss2.accept();
            InputStream is1 = so1.getInputStream();
            byte[] bytes1 = new byte[1024];
            int len1 = is1.read(bytes1);
            String s1 = new String(bytes1, 0, len1);
            System.out.println(s1);
            OutputStream os2 = so2.getOutputStream();
            os2.write(s1.getBytes());
            os2.flush();
            InputStream is2 = so2.getInputStream();
            byte[] bytes2 = new byte[1024];
            OutputStream os1 = so1.getOutputStream();
            int len2 = is2.read(bytes2);
            String s2 = new String(bytes2, 0, len2);
            System.out.println(s2);
            os1.write(s2.getBytes());
            so1.close();
            so2.close();
        }
        /*ss1.close();
        ss2.close();*/
    }
}
public class KC {
    public static void main(String[] args) throws IOException {

        while (true) {
            Socket so = new Socket("localhost", 8888);
            OutputStream os = so.getOutputStream();
            Scanner sc = new Scanner(System.in);
            os.write(sc.next().getBytes());
            InputStream is = so.getInputStream();
            byte[] bytes = new byte[1024];
            int len = is.read(bytes);
            System.out.println(new String(bytes, 0, len));
            so.close();
        }
    }
}
public class KC2 {
    public static void main(String[] args) throws IOException {
        while (true) {
            Socket so = new Socket("localhost", 9527);
            InputStream is = so.getInputStream();
            byte[] bytes = new byte[1024];
            int len = is.read(bytes);
            System.out.println(new String(bytes, 0, len));
            OutputStream os = so.getOutputStream();
            Scanner sc = new Scanner(System.in);
            os.write(sc.next().getBytes());
            so.close();
        }
    }
}

0 个回复

您需要登录后才可以回帖 登录 | 加入黑马