javascript函数--第一章(概述及本质)

1.函数的基本语法:

function functionName(arg0, arg1, ... argN) {
statements
}

(1)return:
如果函数不包含return 语句,只执行函数体内语句,并返回undefined
如下代码:

<html>
<head>
<title>正常方法</title>
<script type="text/javascript">
function print(msg)
{
document.write(msg,"<br/>");
}
</script>
</head>
<body>
<script type="text/javascript">
alert(print("没有return"));//输出undefined
</script>
</body>
</html>


(2)另一个重要概念是,与在 Java 中一样,函数在执行过 return 语句后立即停止代码。因此,return 语句后的代码都不会被执行。

2.javascript中函数的重载

<html>
<head>
<title>函数重载</title>
<script type="text/javascript">
function print(msg){//函数1
document.write(msg,"<br/>");
}

function print(){//函数2
alert("first parameter:" + arguments[0]);
}
</script>
</head>
<body>
<script type="text/javascript">
print("正常方法");
</script>
</body>
</html>

在以上的代码中,或许你会认为
print("正常方法");

因为java,c++中就是这样的,调用的是函数1,但事实上调用的是函数2,为什么呢,因为在javascript中函数名事实是上是对象的引用(这个以下我们会讲到),函数事实上是一个完整的对象,函数名则只是对这个对象的引用.
所以事实上print这个引用在声明函数2时,转而引用了函数2这个对象
所以这种形式并非是对函数进行重载

那么你或许会反对这个说法,你会说
print("正常方法");

有一个实际参数而函数2声明时并没有声明参数,怎么调用呢?
[color=red]
事实上是javascript会将所有的参数都封装到特殊对象arguments中去
[/color]
所以虽然函数2的声明中没有指定形式参数,但是在函数定义中依照arguments[0],arguments[1],arguments[2]...的顺序来取得函数2调用中的各个实际参数

3.为什么说函数是一个完整的对象,而函数名是这个对象的引用
(对于函数的定义方式有哪些,可以参看
[url]http://silentjesse.iteye.com/blog/970193[/url])
记得下面这个函数吗?


function sayHi(sName, sMessage) {
alert("Hello " + sName + sMessage);
}

还可以这样定义它:

var sayHi = new Function("sName", "sMessage", "alert(\"Hello \" + sName + sMessage);");

[color=red]
而Function是一个类,所以new Function(.....)事实上就是定义了一个对象
虽然由于字符串的关系,这种形式写起来有些困难,但有助于理解函数只不过是一种引用类型,它们的行为与用 Function 类明确创建的函数行为是相同的。
[/color]
所以说函数事实上是一个对象
为什么说函数名是对这个函数对象的引用,下面这个例子可以看得更清楚

var doAdd = new Function("iNum", "alert(iNum + 20)");
doAdd = new Function("iNum", "alert(iNum + 10)");
doAdd(10);

这个例子可以更明白的说明,函数名doAdd是一个引用了...
观察这段代码,很显然,doAdd 的值被改成了指向不同对象的指针。函数名只是指向函数对象的引用值,行为就像其他对象一样。
既然是引用,那么当然可以为这个对象再声明一个引用了
如下:

var doAdd = new Function("iNum", "alert(iNum + 10)");
var alsodoAdd = doAdd;
doAdd(10); //输出 "20"
alsodoAdd(10); //输出 "20"



既然如果名只是指向函数的引用,那么可以把函数作为参数传递给另一个函数吗?回答是肯定的!
如下:

function callAnotherFunc(fnFunction, vArgument) {
fnFunction(vArgument);
}

var doAdd = new Function("iNum", "alert(iNum + 10)");

callAnotherFunc(doAdd, 10); //输出 "20"

[color=red]
所有函数都应看作 Function 类的实例。[/color]

4.如前所述,函数名属于引用类型,所以它们也有属性和方法
ECMAScript 定义的属性 length 声明了函数[color=red]期望[/color]的参数个数。
如下:
function doAdd(iNum) {
alert(iNum + 10);
}

function sayHi() {
alert("Hi");
}

alert(doAdd.length); //输出 "1"
alert(sayHi.length); //输出 "0"

Function 对象也有与所有对象共享的 valueOf() 方法和 toString() 方法。这两个方法返回的都是函数的源代码,在调试时尤其有用.

[color=red]以后我们将function定义出来的变量称之为function实体
注意不是函数,函数之是他的功能之一.
也将之称之为Function对象(因为所有的function实体都是通过Function new出来的),注意Function对象的F是大写的

也只有Function对象才能使用关键字new来生成一个对象(重中之重)
[/color]
深度学习是机器学习的一个子领域,它基于人工神经网络的研究,特别是利用多层次的神经网络来进行学习和模式识别。深度学习模型能够学习数据的高层次特征,这些特征对于图像和语音识别、自然语言处理、医学图像分析等应用至关重要。以下是深度学习的一些关键概念和组成部分: 1. **神经网络(Neural Networks)**:深度学习的基础是人工神经网络,它是由多个层组成的网络结构,包括输入层、隐藏层和输出层。每个层由多个神经元组成,神经元之间通过权重连接。 2. **前馈神经网络(Feedforward Neural Networks)**:这是最常见的神经网络类型,信息从输入层流向隐藏层,最终到达输出层。 3. **卷积神经网络(Convolutional Neural Networks, CNNs)**:这种网络特别适合处理具有网格结构的数据,如图像。它们使用卷积层来提取图像的特征。 4. **循环神经网络(Recurrent Neural Networks, RNNs)**:这种网络能够处理序列数据,如时间序列或自然语言,因为它们具有记忆功能,能够捕捉数据中的时间依赖性。 5. **长短期记忆网络(Long Short-Term Memory, LSTM)**:LSTM 是一种特殊的 RNN,它能够学习长期依赖关系,非常适合复杂的序列预测任务。 6. **生成对抗网络(Generative Adversarial Networks, GANs)**:由两个网络组成,一个生成器和一个判别器,它们相互竞争,生成器生成数据,判别器评估数据的真实性。 7. **深度学习框架**:如 TensorFlow、Keras、PyTorch 等,这些框架提供了构建、训练和部署深度学习模型的工具和库。 8. **激活函数(Activation Functions)**:如 ReLU、Sigmoid、Tanh 等,它们在神经网络中用于添加非线性,使得网络能够学习复杂的函数。 9. **损失函数(Loss Functions)**:用于评估模型的预测与真实值之间的差异,常见的损失函数包括均方误差(MSE)、交叉熵(Cross-Entropy)等。 10. **优化算法(Optimization Algorithms)**:如梯度下降(Gradient Descent)、随机梯度下降(SGD)、Adam 等,用于更新网络权重,以最小化损失函数。 11. **正则化(Regularization)**:技术如 Dropout、L1/L2 正则化等,用于防止模型过拟合。 12. **迁移学习(Transfer Learning)**:利用在一个任务上训练好的模型来提高另一个相关任务的性能。 深度学习在许多领域都取得了显著的成就,但它也面临着一些挑战,如对大量数据的依赖、模型的解释性差、计算资源消耗大等。研究人员正在不断探索新的方法来解决这些问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值