基础知识掌握得牢固,能够让我们游刃有余的应对面试,找到更好的工作。
但是真的想要学会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();
}
}
} |
|