Java从入门到项目实战(全程视频版) PDF 扫描版

  • 更新时间:
  • 4255人关注
  • 点击下载

Java从入门到项目实战(全程视频版)》是一本关于Java相关的电子书资源,介绍了关于Java入门、Java项目实战方面的内容,本书是由水利水电出版社出版,格式为PDF,资源大小77 MB,李兴华编写,目前豆瓣、亚马逊、当当、京东等综合评分为:7.7分,一起来看下具体内容。

编辑推荐

(1)作者为活跃在培训市场一线的著名Java培训讲师,将其20年Java使用经验、15年Java培训经验进行梳理、总结,无论是初学者,还是有一定经验的Java程序员,本书均有较高的参考价值。
(2)全书录制了349集同步视频讲解,约86个学时,全部为作者亲自录制,有提醒,有注意,有经验,有技巧,跟着视频学Java,学习效率高。
(3)全书包括592个中小实例,并进行了详细的代码分析和注释,可使读者快速学习。
(4)全书包括大量的“提示”、“注意”、“答疑”等特色段落,将培训和实际开发中的经验、技巧、注意事项融入其中,既能活跃版面,吸引读者注意力,又能在潜移默化中学到知识。
(5) 本书配备PPT教学课件和教学大纲,方便教学和自学。
(6)本书还附赠大量的自测习题和综合测试题,可以检验学习成果。

内容简介

《Java从入门到项目实战(全程视频版)》是一本Java入门书,详细介绍了Java语言面向对象程序设计中的Java核心技术和编程技巧。全书分4篇共22章,其中第1篇为Java编程基础,介绍了Java历史、语言特点、开发环境、编程工具,程序基础概念,程序逻辑控制和方法等;第2篇为Java面向对象编程,介绍了类与对象、数组、String类、继承、抽象类与接口、类结构扩展、异常的捕获与处理、内部类;第3篇为Java应用编程,介绍了Eclipse开发工具、多线程编程、常用类库、I/O编程、反射机制、类集框架、网络编程、数据库编程;第4篇为Java底层编程,介绍了JUC并发编程和NIO编程。本书在知识点的介绍过程中辅以大量的图示,并配有大量的范例代码及详细的注释分析;另外本书还将Java教学与实战经验的知识点融入到“提示”“注意”“问答”等模块中,可让读者在学习过程中少走弯路,并快速掌握Java技术精髓,快速提高Java程序开发技能。
《Java从入门到项目实战(全程视频版)》还是一本视频教程,全书共配备了349集长达65小时的高清视频讲解,跟着视频学Java,高效、快捷。另外,本书还配套了丰富的教学资源,如实例源代码、教学PPT课件及教学大纲,方便教师教学和读者自学。

目录

  • 第一篇 Java编程基础
  • 第1章 走进Java的世界
  • 视频讲解:97分钟 共8集
  • 第2章 程序基础概念
  • 视频讲解:128分钟 共14集
  • 第3章 程序逻辑控制
  • 视频讲解:46分钟 共6集
  • 第4章 方法
  • 视频讲解:41分钟 共3集
  • 第二篇 Java面向对象编程
  • 第5章 类与对象
  • 视频讲解:254分钟 共24集
  • 第6章 数组
  • 视频讲解:192分钟 共17集
  • 第7章 String类
  • 视频讲解:152分钟 共17集
  • 第8章 继承
  • 视频讲解:217分钟 共23集
  • 第9章 抽象类与接口
  • 视频讲解:243分钟 共20集
  • 第10章 类结构扩展
  • 视频讲解:147分钟 共15集
  • 第11章 异常的捕获与处理
  • 视频讲解:74分钟 共10集
  • 第12章 内部类
  • 视频讲解:210分钟 共20集
  • 第三篇 Java应用编程
  • 第13章 Eclipse开发工具
  • 视频讲解:74分钟 共4集
  • 第14章 多线程编程
  • 视频讲解:237分钟 共24集
  • 第15章 常用类库
  • 视频讲解:582分钟 共44集
  • 第16章 I/O编程
  • 视频讲解:417分钟 共32集
  • 第17章 反射机制
  • 视频讲解:343分钟 共24集
  • 第18章 类集框架
  • 视频讲解:288分钟 共30集
  • 第19章 网络编程
  • 视频讲解:60分钟 共4集
  • 第20章 数据库编程
  • 视频讲解:112分钟 共10集
  • 第四篇 Java底层编程
  • 第21章 JUC并发编程
  • 第22章 NIO编程
展开阅读
精选笔记1:新手快速入门JavaScript装饰者模式与AOP

7小时11分钟前回答

什么是装饰者模式

当我们拍了一张照片准备发朋友圈时,许多小伙伴会选择给照片加上滤镜。同一张照片、不同的滤镜组合起来就会有不同的体验。这里实际上就应用了装饰者模式:是通过滤镜装饰了照片。在不改变对象(照片)的情况下动态的为其添加功能(滤镜)。

需要注意的是:由于 JavaScript 语言动态的特性,我们很容易就能改变某个对象(JavaScript 中函数是一等公民)。但是我们要尽量避免直接改写某个函数,这会导致代码的可维护性、可扩展性变差,甚至会污染其他业务。

什么是 AOP

想必大家对"餐前洗手、饭后漱口"都不陌生。这句标语其实就是 AOP 在生活中的例子:吃饭这个动作相当于切点,我们可以在这个切点前、后插入其它如洗手等动作。

AOP(Aspect-Oriented Programming):面向切面编程,是对 OOP 的补充。利用AOP可以对业务逻辑的各个部分进行隔离,也可以隔离业务无关的功能比如日志上报、异常处理等,从而使得业务逻辑各部分之间的耦合度降低,提高业务无关的功能的复用性,也就提高了开发的效率。

在 JavaScript 中,我们可以通过装饰者模式来实现 AOP,但是两者并不是一个维度的概念。 AOP 是一种编程范式,而装饰者是一种设计模式。

ES3 下装饰者的实现

了解了装饰者模式和 AOP 的概念之后,我们写一段能够兼容 ES3 的代码来实现装饰者模式:

// 原函数
var takePhoto =function(){
console.log('拍照片');
}
// 定义 aop 函数
var after=function( fn, afterfn ){ 
return function(){
let res = fn.apply( this, arguments ); 
afterfn.apply( this, arguments );
return res;
}
}
// 装饰函数
var addFilter=function(){
console.log('加滤镜');
}
// 用装饰函数装饰原函数
takePhoto=after(takePhoto,addFilter);
takePhoto();

这样我们就实现了抽离拍照与滤镜逻辑,如果以后需要自动上传功能,也可以通过aop函数after来添加。

ES5 下装饰者的实现

在 ES5 中引入了Object.defineProperty,我们可以更方便的给对象添加属性:

let takePhoto = function () {
console.log('拍照片');
}
// 给 takePhoto 添加属性 after
Object.defineProperty(takePhoto, 'after', {
writable: true,
value: function () {
console.log('加滤镜');
},
});
// 给 takePhoto 添加属性 before
Object.defineProperty(takePhoto, 'before', {
writable: true,
value: function () {
console.log('打开相机');
},
});
// 包装方法
let aop = function (fn) {
return function () {
fn.before()
fn()
fn.after()
}
}
takePhoto = aop(takePhoto)
takePhoto()

基于原型链和类的装饰者实现

我们知道,在 JavaScript 中,函数也好,类也好都有着自己的原型,通过原型链我们也能够很方便的动态扩展,以下是基于原型链的写法:

class Test {
takePhoto() {
console.log('拍照');
}
}
// after AOP
function after(target, action, fn) {
let old = target.prototype[action];
if (old) {
target.prototype[action] = function () {
let self = this;
fn.bind(self);
fn(handle);
}
}
}
// 用 AOP 函数修饰原函数
after(Test, 'takePhoto', () => {
console.log('添加滤镜');
});
let t = new Test();
t.takePhoto();

使用 ES7 修饰器实现装饰者

在 ES7 中引入了@decorator 修饰器的提案,参考阮一峰的文章。修饰器是一个函数,用来修改类的行为。目前Babel转码器已经支持。注意修饰器只能装饰类或者类属性、方法。三者的具体区别请参考 MDN Object.defineProperty ;而 TypeScript 的实现又有所不同:TypeScript Decorator。

接下来我们通过修饰器来实现对方法的装饰:

function after(target, key, desc) {
const { value } = desc;
desc.value = function (...args) {
let res = value.apply(this, args);
console.log('加滤镜')
return res;
}
return desc;
}
class Test{
@after
takePhoto(){
console.log('拍照')
}
}
let t = new Test()
t.takePhoto()

可以看到,使用修饰器的代码非常简洁明了。

场景:性能上报

装饰者模式可以应用在很多场景,典型的场景是记录某异步请求请求耗时的性能数据并上报:

function report(target, key, desc) {
const { value } = desc;
desc.value = async function (...args) {
let start = Date.now();
let res = await value.apply(this, args);
let millis = Date.now()-start;
// 上报代码
return res;
}
return desc;
}
class Test{
@report
getData(url){
// fetch 代码
}
}
let t = new Test()
t.getData()

这样使用@report修饰后的代码就会上报请求所消耗的时间。扩展或者修改report函数不会影响业务代码,反之亦然。

场景:异常处理

我们可以对原有代码进行简单的异常处理,而无需侵入式的修改:

function handleError(target, key, desc) {
const { value } = desc;
desc.value = async function (...args) {
let res;
try{
res = await value.apply(this, args);
}catch(err){
// 异常处理
logger.error(err)
}
return res;
}
return desc;
}
class Test{
@handleError
getData(url){
// fetch 代码
}
}
let t = new Test()
t.getData()

通过以上两个示例我们可以看到,修饰器的定义很简单,功能却非常强大。

小结

我们一步一步通过高阶函数、原型链、Object.defineProperty和@Decorator分别实现了装饰者模式。接下来在回顾一下:

  • 装饰者模式非常适合给业务代码附加非业务相关功能(如日志上报),就如同给照片加滤镜;
  • 装饰者模式非常适合无痛扩展别人的代码(你经常需要接手别人的项目吧)

有些朋友可能会觉得装饰者模式和 vue 的 mixin 机制很像,其实他们都是“开放-封闭原则”和“单一职责原则”的体现。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持码农之家。文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,

展开阅读

Java相关资源

学习笔记

6小时14分钟前回答

JavaScript的Vue.js库入门学习教程

Vue是一个小巧轻便的javascript库。它有一个简单易懂的API,能够让开发者在开发web应用的时候更加简易便捷。实际上,一直让Vue引以为豪的是它的便捷性、执行力、灵活性。 这篇教程的目的就是通过一些例子,让你能够概览一些基本的概念和特性。在接下来的其他教程里,你会学到Vue更多的有用的特性,从而用Vue搭建一个可扩展的项目。 MVVM 数据绑定 MVVM的本质是通过数据绑定链接View和Model,让数据的变化自动映射为视图的更新。Vue.js在数据绑定的API设计上借鉴了Angular的指令机制:用户可以通过具有特殊前缀的HTML 属性来实现数据绑定,也可以使用常见的花括号模板插值,或是在表单元素上使用双向绑……

12小时11分钟前回答

JavaScript的React框架中的JSX语法学习入门教程

什么是JSX? 在用React写组件的时候,通常会用到JSX语法,粗看上去,像是在Javascript代码里直接写起了XML标签,实质上这只是一个语法糖,每一个XML标签都会被JSX转换工具转换成纯Javascript代码,当然你想直接使用纯Javascript代码写也是可以的,只是利用JSX,组件的结构和组件之间的关系看上去更加清晰。 var MyComponent = React.createClass({/*...*……