谈谈如何运用经典性条件反射理论培养学生良好的行为习惯

谈谈如何运用经典性条件反射理论培养学生良好的行为习惯,第1张

如果我们能够好好的把握这个度,不在泛滥盲目的应用这个定律,而是重视培养学生的主观能动性,做到: 1.教学方法应能激发学生的兴趣和积极性。 例如,在学习新的课文时,我建议采用下面的步骤进行教学:课前制作好课件──展示课件(激发学生兴趣)──讨论回答文章的问题(调动他们的主动性、积极性、探讨思维能力)──用课件展示来总结学习要点、过程及要求(使内容变得生动活泼,学生易于接受和掌握知识)──举例示范 *** 作(使学生对学习内容有更深的了解)──布置任务,要求每人完成一份学习报告(使他们主观能动地参与到学习当中去,进一步加强知识内容的掌握)。 2要恰当地运用强化手段,将快乐事件作为学习任务的无条件刺激,以帮助学生克服窘境、摆脱考试焦虑等。 例如,许多学生可能不喜欢外语,因为他们将外语与要求在课堂上大声翻译句子这样不愉快的经验联系了起来。在课堂上被提问难题引起了焦虑,学生形成了对外语恐惧的条件作用,可能泛化到他们对其他课程或学校机构的恐惧,以致在其他学校经验中发生类似的学习过程。教师可以将快乐事件作为学习任务的无条件刺激。教师让学生在群体竞争与合作中学习,或者创造一个舒适的读书角,或者提供温暖、舒适的课堂环境,使学生产生温馨的感觉,并将这种感觉泛化到学习活动中。 3教育实践中可以有意识地通过训练来建立条件反射,以改变身体的反应,从而养成良好的习惯,或消除不良的嗜好。 反射性成程序性学习记忆,又称内隐性学习记忆,也就是技巧性或运动性学习记忆,它与习惯的养成和适应性反应有关,学会以后不再需要意识的参与,而是一连串的自动化动作。例如.学习d钢琴或学习打字,口是一开始需要用脑考虑和用眼睛看琴键或字盘.一日学会以后就转为程序性的自动化 *** 作,而日常常保持终生不忘。反复训练对这类学习记忆特别重要,反复训练可以增强相关神经通路上的突触可塑性和有关神经元的兴奋性,从而易化了一连串动作相关肌肉群的活动,舞蹈、体 *** 、杂技等项日的学习训练过程也都属于这一类。

反射的结构基础为反射弧,包括五个基本环节:感受器、传入神经、神经中枢、传出神经和效应器。

反射是一种自然现象,表现为受刺激物对刺激物的逆反应。反射的外延宽泛。物理学领域是指声波、光波或其他电磁波遇到别的媒质分界面而部分仍在原物质中传播的现象;生物学领域里反射是在中枢神经系统参与下,机体对内外环境刺激所作出的规律性反应。

计算机领域中反射是提供封装程序集、模块和类型的对象;电子领域中就是在传输线上的回波。研究反射产生机制,把握反射规律,有利于人类更好的利用反射进行各种相关工作。其应用领域是相当广泛的。

单细胞动物神经系统对刺激的反应都由原生质来完成。腔肠动物开始有神经细胞,并形成网状,但无中枢和外周之分,当受到刺激时则引起全身反应。环节动物和节肢动物具有链状神经系统,咽部背侧一对神经节特别大,有人也把它叫做脑,这些动物有完整的反射弧,对内、外环境的刺激开始有了简单的反射活动。

脊椎动物的中枢神经系统的前端为真正脑,后端为脊髓;外周神经由脑神经和脊神经组成,其中哺乳动物出现了高度发展的大脑皮层。在高等动物以至人类,大脑皮层已成为控制整个机体活动的高级部位。中枢神经系统各结构在功能上有高级与低级之分,低级中枢可完成一些基本的、简单的反射,在高级中枢调节下反射则更加复杂而完善。

运行时类型识别(Run-timeTypeIdentification,RTTI)主要有两种方式,一种是我们在编译时和运行时已经知道了所有的类型,另外一种是功能强大的“反射”机制。

要理解RTTI在Java中的工作原理,首先必须知道类型信息在运行时是如何表示的,这项工作是由“Class对象”完成的,它包含了与类有关的信息。类是程序的重要组成部分,每个类都有一个Class对象,每当编写并编译了一个新类就会产生一个Class对象,它被保存在一个同名的class文件中。在运行时,当我们想生成这个类的对象时,运行这个程序的Java虚拟机(JVM)会确认这个类的Class对象是否已经加载,如果尚未加载,JVM就会根据类名查找class文件,并将其载入,一旦这个类的Class对象被载入内存,它就被用来创建这个类的所有对象。一般的RTTI形式包括三种:

1传统的类型转换。如“(Apple)Fruit”,由RTTI确保类型转换的正确性,如果执行了一个错误的类型转换,就会抛出一个ClassCastException异常。

2通过Class对象来获取对象的类型。如

Classc=ClassforName(“Apple”);

Objecto=cnewInstance();

3通过关键字instanceof或ClassisInstance()方法来确定对象是否属于某个特定类型的实例,准确的说,应该是instanceof/ClassisInstance()可以用来确定对象是否属于某个特定类及其所有基类的实例,这和equals()/==不一样,它们用来比较两个对象是否属于同一个类的实例,没有考虑继承关系。

反射

如果不知道某个对象的类型,可以通过RTTI来获取,但前提是这个类型在编译时必须已知,这样才能使用RTTI来识别。即在编译时,编译器必须知道所有通过RTTI来处理的类。

使用反射机制可以不受这个限制,它主要应用于两种情况,第一个是“基于构件的编程”,在这种编程方式中,将使用某种基于快速应用开发(RAD)的应用构建工具来构建项目。这是现在最常见的可视化编程方法,通过代表不同组件的图标拖动到图板上来创建程序,然后设置构件的属性值来配置它们。这种配置要求构件都是可实例化的,并且要暴露其部分信息,使得程序员可以读取和设置构件的值。当处理GUI时间的构件时还必须暴露相关方法的细细,以便RAD环境帮助程序员覆盖这些处理事件的方法。在这里,就要用到反射的机制来检查可用的方法并返回方法名。Java通过JavaBeans提供了基于构件的编程架构。

第二种情况,在运行时获取类的信息的另外一个动机,就是希望能够提供在跨网络的远程平台上创建和运行对象的能力。这被成为远程调用(RMI),它允许一个Java程序将对象分步在多台机器上,昌平java培训认为这种分步能力将帮助开发人员执行一些需要进行大量计算的任务,充分利用计算机资源,提高运行速度。

经过多方面的资料搜集整理,写下了这篇文章,本文主要讲解java的反射和内省机制,希望对大家有点帮助,也希望大家提出不同的看法!

1)内省(Introspector)是 Java 语言对 Bean 类属性、事件的一种缺省处理方法。例如类 A 中有属性 name, 那我们可以通过 getName,setName 来得到其值或者设置新的值。通过 getName/setName 来访问 name 属性,这就是默认的规则。 Java 中提供了一套 API 用来访问某个属性的 getter/setter 方法,通过这些 API 可以使你不需要了解这个规则(但你最好还是要搞清楚),这些 API 存放于包 javabeans 中。

2)直接通过属性的描述器javabeansPropertyDescriptor类,来访问属性的getter/setter 方法;

相关代码:

public class Point {

private Integer x;

private Integer y;

public Point(Integer x, Integer y) {

super();

thisx = x;

thisy = y;

}

public Integer getX() {

return x;

}

public void setX(Integer x) {

thisx = x;

}

public Integer getY() {

return y;

}

public void setY(Integer y) {

thisy = y;

}

}

import javabeansPropertyDescriptor;

import javalangreflectMethod;

public class Reflect {

public static void main(String[] args) throws Exception {

Point point = new Point(2, 5);

String proName = "x";

getProperty(point, proName);

setProperty(point, proName);

}

private static void setProperty(Point point, String proName) throws Exception {

PropertyDescriptor proDescriptor = new PropertyDescriptor(proName, Pointclass);

Method methodSetX = proDescriptorgetWriteMethod();

methodSetXinvoke(point, 8);

Systemoutprintln(pointgetX());// 8

}

private static void getProperty(Point point, String proName) throws Exception {

PropertyDescriptor proDescriptor = new PropertyDescriptor(proName, Pointclass);

Method methodGetX = proDescriptorgetReadMethod();

Object objx = methodGetXinvoke(point);

Systemoutprintln(objx);// 2

}

}

3)通过类 Introspector 来获取某个对象的 BeanInfo 信息,然后通过 BeanInfo 来获取属性的描述器( PropertyDescriptor ),通过这个属性描述器就可以获取某个属性对应的 getter/setter 方法,然后我们就可以通过反射机制来调用这些方法。

相关代码:

把2中的getProperty()修改成如下形式:

private static void getProperty(Point point, String proName) throws Exception {

BeanInfo beanInfo = IntrospectorgetBeanInfo(pointgetClass());

PropertyDescriptor[] proDescriptors = beanInfogetPropertyDescriptors();

for(PropertyDescriptor prop: proDescriptors){

if(propgetName()equals(proName)){

Method methodGetx = propgetReadMethod();

Systemoutprintln(methodGetxinvoke(point));//8

break;

}

}

}

4)我们又通常把javabean的实例对象称之为值对象(Value Object),因为这些bean中通常只有一些信息字段和存储方法,没有功能性方法。一个JavaBean类可以不当JavaBean用,而当成普通类用。JavaBean实际就是一种规范,当一个类满足这个规范,这个类就能被其它特定的类调用。一个类被当作javaBean使用时,JavaBean的属性是根据方法名推断出来的,它根本看不到java类内部的成员变量(javabean的成员变量通常都是私有private的)。

5)除了反射用到的类需要引入外,内省需要引入的类如下所示,它们都属于javabeans包中的类,自己写程序的时候也不能忘了引入相应的包或者类。

import javabeansBeanInfo;

import javabeansIntrospectionException;

import javabeansIntrospector;

import javabeansPropertyDescriptor;

6)下面讲解一些开源的工具类Beanutils,需要额外下载的,commons-beanutilsjar,要使用它还必须导入commons-loggingjar包,不然会出异常;

相关代码一:

public static void main(String[] args) throws Exception {

Point point = new Point(2, 5);

String proName = "x";

BeanUtilssetProperty(point, proName, "8");

Systemoutprintln(pointgetX());// 8

Systemoutprintln(BeanUtilsgetProperty(point, proName));// 8

Systemoutprintln(BeanUtilsgetProperty(point, proName)getClass()getName());// javalangString

BeanUtilssetProperty(point, proName, 8);

Systemoutprintln(BeanUtilsgetProperty(point, proName)getClass()getName());// javalangString

}

//我们看到虽然属性x的类型是Integer,但是我们设置的时候无论是Integer还是String,BeanUtils的内部都是当成String来处理的。

相关代码二:

BeanUtils支持javabean属性的级联 *** 作;

public static void main(String[] args) throws Exception {

Point point = new Point(2, 5);//在point中加一个属性 private Date birth = new Date();并产生setter/getter方法

String proName = "birth";

Date date= new Date();

datesetTime(10000);

BeanUtilssetProperty(point, proName, date);

Systemoutprintln(BeanUtilsgetProperty(point, proName));

BeanUtilssetProperty(point, "birthtime", 10000);

Systemoutprintln(BeanUtilsgetProperty(point, "birthtime"));//10000

}

//之所以可以 BeanUtilssetProperty(point, "birthtime", 10000);这样写,那是因为Date类中有getTime()和setTime()方法,即Date类中相当于有time这个属性。

相关代码三:

BeanUtils和PropertyUtils对比:

public static void main(String[] args) throws Exception {

Point point = new Point(2, 5);

String proName = "x";

BeanUtilssetProperty(point, proName, "8");

Systemoutprintln(BeanUtilsgetProperty(point, proName));//8

Systemoutprintln(BeanUtilsgetProperty(point, proName)getClass()getName());//javalangString

// PropertyUtilssetProperty(point, proName, "8");//exception:argument type mismatch

PropertyUtilssetProperty(point, proName, 8);

Systemoutprintln(PropertyUtilsgetProperty(point, proName));//8

Systemoutprintln(PropertyUtilsgetProperty(point, proName)getClass()getName());//javalangInteger

}

//BeanUtils它以字符串的形式对javabean进行转换,而PropertyUtils是以原本的类型对javabean进行 *** 作。如果类型不对,就会有argument type mismatch异常。

6)理解了相应的原理,那些现成的工具用起来就会更舒服,如Beanutils与PropertyUtils工具。这两个工具设置属性的时候一个主要区别是PropertyUtilsgetPropety方法获得的属性值的类型为该属性本来的类型,而BeanUtilsgetProperty则是将该属性的值转换成字符串后才返回。

总结

Web 开发框架 Struts 中的 FormBean 就是通过内省机制来将表单中的数据映射到类的属性上,因此要求 FormBean 的每个属性要有 getter/setter 方法。但也并不总是这样,什么意思呢?就是说对一个 Bean 类来讲,我可以没有属性,但是只要有 getter/setter 方法中的其中一个,那么 Java 的内省机制就会认为存在一个属性,比如类中有方法 setMobile ,那么就认为存在一个 mobile 的属性。

将 Java 的反射以及内省应用到程序设计中去可以大大的提供程序的智能化和可扩展性。有很多项目都是采取这两种技术来实现其核心功能,例如我们前面提到的 Struts ,还有用于处理 XML 文件的 Digester 项目,其实应该说几乎所有的项目都或多或少的采用这两种技术。在实际应用过程中二者要相互结合方能发挥真正的智能化以及高度可扩展性。

以上就是关于谈谈如何运用经典性条件反射理论培养学生良好的行为习惯全部的内容,包括:谈谈如何运用经典性条件反射理论培养学生良好的行为习惯、反射的五个基本环节、JAVA反射机制原理等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zz/9274432.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-26
下一篇 2023-04-26

发表评论

登录后才能评论

评论列表(0条)

保存