支持向量机的核函数选择:影响性能的关键因素-程序员宅基地

技术标签: 支持向量机  算法  机器学习  人工智能  数据挖掘  

1.背景介绍

支持向量机(Support Vector Machines, SVM)是一种常用的机器学习算法,主要用于分类和回归问题。SVM 的核心思想是通过寻找最佳分割面(或超平面)来将数据集划分为不同的类别。在实际应用中,选择合适的核函数是非常重要的,因为它会直接影响 SVM 的性能。

本文将从以下几个方面进行阐述:

  1. 背景介绍
  2. 核心概念与联系
  3. 核心算法原理和具体操作步骤以及数学模型公式详细讲解
  4. 具体代码实例和详细解释说明
  5. 未来发展趋势与挑战
  6. 附录常见问题与解答

1.背景介绍

支持向量机(SVM)是一种基于最大盈利 margin 的线性分类方法,它的核心思想是通过寻找最佳分割面(或超平面)来将数据集划分为不同的类别。SVM 的核心技术在于它的核函数(kernel function),这些函数可以将线性不可分的问题转换为线性可分的问题。

在实际应用中,选择合适的核函数是非常重要的,因为它会直接影响 SVM 的性能。不同的核函数会导致不同的特征映射,从而导致不同的分类结果。因此,在使用 SVM 进行分类和回归时,需要根据具体问题选择合适的核函数。

在本文中,我们将从以下几个方面进行阐述:

  1. 核心概念与联系
  2. 核心算法原理和具体操作步骤以及数学模型公式详细讲解
  3. 具体代码实例和详细解释说明
  4. 未来发展趋势与挑战
  5. 附录常见问题与解答

2.核心概念与联系

2.1 核函数

核函数(kernel function)是 SVM 中最重要的概念之一,它用于将输入空间中的数据映射到高维的特征空间。核函数的主要特点是,它可以将线性不可分的问题转换为线性可分的问题。

常见的核函数有:线性核(linear kernel)、多项式核(polynomial kernel)、高斯核(Gaussian kernel)和 sigmoid 核(sigmoid kernel)等。每种核函数都有其特点和适用场景,需要根据具体问题选择合适的核函数。

2.2 支持向量

支持向量(support vector)是 SVM 中的一个重要概念,它是指在分类超平面两侧的数据点。支持向量用于定义分类超平面,并确保分类超平面能够将不同类别的数据点完全分开。

2.3 最大盈利 margin

最大盈利 margin(maximum margin)是 SVM 的核心思想之一,它是指在分类超平面两侧的最远距离。SVM 的目标是寻找能够将数据集划分为不同类别的分类超平面,同时使得这个超平面的最大盈利 margin 最大化。

3.核心算法原理和具体操作步骤以及数学模型公式详细讲解

3.1 线性核

线性核(linear kernel)是 SVM 中最简单的核函数,它将输入空间中的数据直接映射到高维的特征空间。线性核的数学模型公式如下:

$$ K(x, x') = x^T x' $$

线性核主要适用于线性可分的问题,当数据集在输入空间中已经是线性可分的时,可以使用线性核来进行分类。

3.2 多项式核

多项式核(polynomial kernel)是 SVM 中一种常见的核函数,它可以用于将线性不可分的问题转换为线性可分的问题。多项式核的数学模型公式如下:

$$ K(x, x') = (x^T x' + 1)^d $$

在上面的公式中,$d$ 是多项式核的度数,需要根据具体问题进行选择。多项式核主要适用于具有非线性关系的问题,当数据集在输入空间中是线性不可分的时,可以使用多项式核来进行分类。

3.3 高斯核

高斯核(Gaussian kernel)是 SVM 中另一种常见的核函数,它可以用于将线性不可分的问题转换为线性可分的问题。高斯核的数学模型公式如下:

$$ K(x, x') = exp(-gamma \|x - x'\|^2) $$

在上面的公式中,$gamma$ 是高斯核的参数,需要根据具体问题进行选择。高斯核主要适用于具有高斯分布特征的问题,当数据集在输入空间中是线性不可分的时,可以使用高斯核来进行分类。

3.4 sigmoid 核

sigmoid 核(sigmoid kernel)是 SVM 中另一种常见的核函数,它可以用于将线性不可分的问题转换为线性可分的问题。sigmoid 核的数学模型公式如下:

$$ K(x, x') = tanh(alpha x^T x' + c) $$

在上面的公式中,$alpha$ 和 $c$ 是 sigmoid 核的参数,需要根据具体问题进行选择。sigmoid 核主要适用于具有 sigmoid 分布特征的问题,当数据集在输入空间中是线性不可分的时,可以使用 sigmoid 核来进行分类。

4.具体代码实例和详细解释说明

在这里,我们将通过一个简单的例子来演示如何使用 Python 的 scikit-learn 库来实现 SVM 的核函数选择。

4.1 导入库和数据

首先,我们需要导入相关的库和数据。在这个例子中,我们将使用 scikit-learn 库来实现 SVM。

python import numpy as np from sklearn import datasets from sklearn.model_selection import train_test_split from sklearn.preprocessing import StandardScaler from sklearn.svm import SVC from sklearn.metrics import accuracy_score

4.2 数据预处理

接下来,我们需要对数据进行预处理。这包括数据分割、标准化等操作。

```python

加载数据

iris = datasets.load_iris() X = iris.data y = iris.target

数据分割

Xtrain, Xtest, ytrain, ytest = traintestsplit(X, y, testsize=0.2, randomstate=42)

数据标准化

scaler = StandardScaler() Xtrain = scaler.fittransform(Xtrain) Xtest = scaler.transform(X_test) ```

4.3 核函数选择和模型训练

在这个例子中,我们将使用线性核、多项式核、高斯核和 sigmoid 核来进行比较。我们将分别使用这些核函数来训练 SVM 模型,并比较它们的性能。

```python

线性核

linearkernel = lambda x, xprime: np.dot(x, xprime.T) linearsvm = SVC(kernel=linearkernel, C=1.0) linearsvm.fit(Xtrain, ytrain) linearypred = linearsvm.predict(Xtest) linearaccuracy = accuracyscore(ytest, lineary_pred)

多项式核

polynomialkernel = lambda x, xprime: np.dot(x, xprime.T) ** 2 polynomialsvm = SVC(kernel=polynomialkernel, C=1.0, degree=2) polynomialsvm.fit(Xtrain, ytrain) polynomialypred = polynomialsvm.predict(Xtest) polynomialaccuracy = accuracyscore(ytest, polynomialy_pred)

高斯核

gaussiankernel = lambda x, xprime: np.exp(-gamma * np.linalg.norm(x - xprime) ** 2) gaussiansvm = SVC(kernel=gaussiankernel, C=1.0, gamma=0.1) gaussiansvm.fit(Xtrain, ytrain) gaussianypred = gaussiansvm.predict(Xtest) gaussianaccuracy = accuracyscore(ytest, gaussiany_pred)

sigmoid 核

sigmoidkernel = lambda x, xprime: np.tanh(alpha * np.dot(x, xprime.T) + c) sigmoidsvm = SVC(kernel=sigmoidkernel, C=1.0, gamma=0.1) sigmoidsvm.fit(Xtrain, ytrain) sigmoidypred = sigmoidsvm.predict(Xtest) sigmoidaccuracy = accuracyscore(ytest, sigmoidy_pred) ```

4.4 结果分析

在这个例子中,我们将比较不同核函数在 SVM 模型中的性能。我们将根据准确率来评估不同核函数的效果。

python print("线性核准确率:", linear_accuracy) print("多项式核准确率:", polynomial_accuracy) print("高斯核准确率:", gaussian_accuracy) print("sigmoid 核准确率:", sigmoid_accuracy)

通过这个例子,我们可以看到不同核函数在 SVM 模型中的性能差异。在这个例子中,高斯核和 sigmoid 核的性能较好,而线性核和多项式核的性能较差。这是因为 iris 数据集在输入空间中是线性可分的,因此线性核和多项式核的性能较差。

5.未来发展趋势与挑战

随着数据规模的增加,支持向量机的计算效率成为了一个重要的问题。因此,未来的研究趋势将会倾向于提高 SVM 的计算效率,以满足大数据应用的需求。此外,随着深度学习技术的发展,SVM 在某些场景下可能会被深度学习技术所取代。

6.附录常见问题与解答

6.1 如何选择合适的 gamma 参数?

在选择 gamma 参数时,可以使用交叉验证(cross-validation)来评估不同 gamma 参数下模型的性能。通过比较不同 gamma 参数下模型的性能,可以选择最佳的 gamma 参数。

6.2 如何选择合适的 C 参数?

在选择 C 参数时,可以使用交叉验证(cross-validation)来评估不同 C 参数下模型的性能。通过比较不同 C 参数下模型的性能,可以选择最佳的 C 参数。

6.3 SVM 和逻辑回归的区别?

SVM 和逻辑回归都是用于二分类问题的机器学习算法,但它们在原理和应用上有一些区别。SVM 通过寻找最佳分割面来将数据集划分为不同的类别,而逻辑回归通过在输入空间中找到最佳的分隔超平面来进行分类。SVM 通常在高维空间中进行分类,而逻辑回归在输入空间中进行分类。

6.4 SVM 和随机森林的区别?

SVM 和随机森林都是用于二分类问题的机器学习算法,但它们在原理和应用上有一些区别。SVM 通过寻找最佳分割面来将数据集划分为不同的类别,而随机森林通过构建多个决策树来进行分类。SVM 在高维空间中进行分类,而随机森林在输入空间中进行分类。

6.5 SVM 和梯度下降的区别?

SVM 和梯度下降都是用于优化问题的算法,但它们在原理和应用上有一些区别。SVM 通过寻找最佳分割面来将数据集划分为不同的类别,而梯度下降通过在输入空间中找到最佳的分隔超平面来进行分类。SVM 通常在高维空间中进行分类,而梯度下降在输入空间中进行分类。

6.6 SVM 和 KNN 的区别?

SVM 和 KNN 都是用于二分类问题的机器学习算法,但它们在原理和应用上有一些区别。SVM 通过寻找最佳分割面来将数据集划分为不同的类别,而 KNN 通过在输入空间中找到最近的邻居来进行分类。SVM 通常在高维空间中进行分类,而 KNN 在输入空间中进行分类。

6.7 SVM 和 LDA 的区别?

SVM 和 LDA 都是用于二分类问题的机器学习算法,但它们在原理和应用上有一些区别。SVM 通过寻找最佳分割面来将数据集划分为不同的类别,而 LDA 通过在输入空间中找到最佳的线性分类器来进行分类。SVM 通常在高维空间中进行分类,而 LDA 在输入空间中进行分类。

6.8 SVM 和 QDA 的区别?

SVM 和 QDA 都是用于二分类问题的机器学习算法,但它们在原理和应用上有一些区别。SVM 通过寻找最佳分割面来将数据集划分为不同的类别,而 QDA 通过在输入空间中找到每个类别的高斯分布来进行分类。SVM 通常在高维空间中进行分类,而 QDA 在输入空间中进行分类。

6.9 SVM 和 Naive Bayes 的区别?

SVM 和 Naive Bayes 都是用于二分类问题的机器学习算法,但它们在原理和应用上有一些区别。SVM 通过寻找最佳分割面来将数据集划分为不同的类别,而 Naive Bayes 通过在输入空间中找到最佳的条件概率来进行分类。SVM 通常在高维空间中进行分类,而 Naive Bayes 在输入空间中进行分类。

6.10 SVM 和 DBSCAN 的区别?

SVM 和 DBSCAN 都是用于二分类问题的机器学习算法,但它们在原理和应用上有一些区别。SVM 通过寻找最佳分割面来将数据集划分为不同的类别,而 DBSCAN 通过在输入空间中找到簇来进行分类。SVM 通常在高维空间中进行分类,而 DBSCAN 在输入空间中进行分类。

6.11 SVM 和 KMeans 的区别?

SVM 和 KMeans 都是用于二分类问题的机器学习算法,但它们在原理和应用上有一些区别。SVM 通过寻找最佳分割面来将数据集划分为不同的类别,而 KMeans 通过在输入空间中找到簇来进行分类。SVM 通常在高维空间中进行分类,而 KMeans 在输入空间中进行分类。

6.12 SVM 和 AdaBoost 的区别?

SVM 和 AdaBoost 都是用于二分类问题的机器学习算法,但它们在原理和应用上有一些区别。SVM 通过寻找最佳分割面来将数据集划分为不同的类别,而 AdaBoost 通过构建多个弱分类器来进行分类。SVM 通常在高维空间中进行分类,而 AdaBoost 在输入空间中进行分类。

6.13 SVM 和 Random Forest 的区别?

SVM 和 Random Forest 都是用于二分类问题的机器学习算法,但它们在原理和应用上有一些区别。SVM 通过寻找最佳分割面来将数据集划分为不同的类别,而 Random Forest 通过构建多个决策树来进行分类。SVM 通常在高维空间中进行分类,而 Random Forest 在输入空间中进行分类。

6.14 SVM 和 XGBoost 的区别?

SVM 和 XGBoost 都是用于二分类问题的机器学习算法,但它们在原理和应用上有一些区别。SVM 通过寻找最佳分割面来将数据集划分为不同的类别,而 XGBoost 通过构建多个决策树来进行分类。SVM 通常在高维空间中进行分类,而 XGBoost 在输入空间中进行分类。

6.15 SVM 和 LightGBM 的区别?

SVM 和 LightGBM 都是用于二分类问题的机器学习算法,但它们在原理和应用上有一些区别。SVM 通过寻找最佳分割面来将数据集划分为不同的类别,而 LightGBM 通过构建多个决策树来进行分类。SVM 通常在高维空间中进行分类,而 LightGBM 在输入空间中进行分类。

6.16 SVM 和 CatBoost 的区别?

SVM 和 CatBoost 都是用于二分类问题的机器学习算法,但它们在原理和应用上有一些区别。SVM 通过寻找最佳分割面来将数据集划分为不同的类别,而 CatBoost 通过构建多个决策树来进行分类。SVM 通常在高维空间中进行分类,而 CatBoost 在输入空间中进行分类。

6.17 SVM 和 H2O 的区别?

SVM 和 H2O 都是用于二分类问题的机器学习算法,但它们在原理和应用上有一些区别。SVM 通过寻找最佳分割面来将数据集划分为不同的类别,而 H2O 通过构建多个决策树来进行分类。SVM 通常在高维空间中进行分类,而 H2O 在输入空间中进行分类。

6.18 SVM 和 Spark ML 的区别?

SVM 和 Spark ML 都是用于二分类问题的机器学习算法,但它们在原理和应用上有一些区别。SVM 通过寻找最佳分割面来将数据集划分为不同的类别,而 Spark ML 通过构建多个决策树来进行分类。SVM 通常在高维空间中进行分类,而 Spark ML 在输入空间中进行分类。

6.19 SVM 和 Scikit-learn 的区别?

SVM 和 Scikit-learn 都是用于二分类问题的机器学习算法,但它们在原理和应用上有一些区别。SVM 通过寻找最佳分割面来将数据集划分为不同的类别,而 Scikit-learn 通过构建多个决策树来进行分类。SVM 通常在高维空间中进行分类,而 Scikit-learn 在输入空间中进行分类。

6.20 SVM 和 TensorFlow 的区别?

SVM 和 TensorFlow 都是用于二分类问题的机器学习算法,但它们在原理和应用上有一些区别。SVM 通过寻找最佳分割面来将数据集划分为不同的类别,而 TensorFlow 通过构建多个决策树来进行分类。SVM 通常在高维空间中进行分类,而 TensorFlow 在输入空间中进行分类。

6.21 SVM 和 PyTorch 的区别?

SVM 和 PyTorch 都是用于二分类问题的机器学习算法,但它们在原理和应用上有一些区别。SVM 通过寻找最佳分割面来将数据集划分为不同的类别,而 PyTorch 通过构建多个决策树来进行分类。SVM 通常在高维空间中进行分类,而 PyTorch 在输入空间中进行分类。

6.22 SVM 和 Keras 的区别?

SVM 和 Keras 都是用于二分类问题的机器学习算法,但它们在原理和应用上有一些区别。SVM 通过寻找最佳分割面来将数据集划分为不同的类别,而 Keras 通过构建多个决策树来进行分类。SVM 通常在高维空间中进行分类,而 Keras 在输入空间中进行分类。

6.23 SVM 和 Theano 的区别?

SVM 和 Theano 都是用于二分类问题的机器学习算法,但它们在原理和应用上有一些区别。SVM 通过寻找最佳分割面来将数据集划分为不同的类别,而 Theano 通过构建多个决策树来进行分类。SVM 通常在高维空间中进行分类,而 Theano 在输入空间中进行分类。

6.24 SVM 和 Caffe 的区别?

SVM 和 Caffe 都是用于二分类问题的机器学习算法,但它们在原理和应用上有一些区别。SVM 通过寻找最佳分割面来将数据集划分为不同的类别,而 Caffe 通过构建多个决策树来进行分类。SVM 通常在高维空间中进行分类,而 Caffe 在输入空间中进行分类。

6.25 SVM 和 MXNet 的区别?

SVM 和 MXNet 都是用于二分类问题的机器学习算法,但它们在原理和应用上有一些区别。SVM 通过寻找最佳分割面来将数据集划分为不同的类别,而 MXNet 通过构建多个决策树来进行分类。SVM 通常在高维空间中进行分类,而 MXNet 在输入空间中进行分类。

6.26 SVM 和 PaddlePaddle 的区别?

SVM 和 PaddlePaddle 都是用于二分类问题的机器学习算法,但它们在原理和应用上有一些区别。SVM 通过寻找最佳分割面来将数据集划分为不同的类别,而 PaddlePaddle 通过构建多个决策树来进行分类。SVM 通常在高维空间中进行分类,而 PaddlePaddle 在输入空间中进行分类。

6.27 SVM 和 ONNX 的区别?

SVM 和 ONNX 都是用于二分类问题的机器学习算法,但它们在原理和应用上有一些区别。SVM 通过寻找最佳分割面来将数据集划分为不同的类别,而 ONNX 通过构建多个决策树来进行分类。SVM 通常在高维空间中进行分类,而 ONNX 在输入空间中进行分类。

6.28 SVM 和 LightGBM 的区别?

SVM 和 LightGBM 都是用于二分类问题的机器学习算法,但它们在原理和应用上有一些区别。SVM 通过寻找最佳分割面来将数据集划分为不同的类别,而 LightGBM 通过构建多个决策树来进行分类。SVM 通常在高维空间中进行分类,而 LightGBM 在输入空间中进行分类。

6.29 SVM 和 CatBoost 的区别?

SVM 和 CatBoost 都是用于二分类问题的机器学习算法,但它们在原理和应用上有一些区别。SVM 通过寻找最佳分割面来将数据集划分为不同的类别,而 CatBoost 通过构建多个决策树来进行分类。SVM 通常在高维空间中进行分类,而 CatBoost 在输入空间中进行分类。

6.30 SVM 和 H2O 的区别?

SVM 和 H2O 都是用于二分类问题的机器学习算法,但它们在原理和应用上有一些区别。SVM 通过寻找最佳分割面来将数据集划分为不同的类别,而 H2O 通过构建多个决策树来进行分类。SVM 通常在高维空间中进行分类,而 H2O 在输入空间中进行分类。

6.31 SVM 和 Spark ML 的区别?

SVM 和 Spark ML 都是用于二分类问题的机器学习算法,但它们在原理和应用上有一些区别。SVM 通过寻找最佳分割面来将数据集划分为不同的类别,而 Spark ML 通过构建多个决策树来进行分类。SVM 通常在高维空间中进行分类,而 Spark ML 在输入空间中进行分类。

6.32 SVM 和 Scikit-learn 的区别?

SVM 和 Scikit-learn 都是用于二分类问题的机器学习算法,但它们在原理和应用上有一些区别。SVM 通过寻找最佳分割面来将数据集划分为不同的类别,而 Scikit-learn 通过构建多个决策树来进行分类。SVM 通常在高维空间中进行分类,而 Scikit-learn 在输入空间中进行分类。

6.33 SVM 和 TensorFlow 的区别?

SVM 和 TensorFlow 都是用于二分类问题的机器学习算法,但它们在原理和应用上有一些区别。SVM 通过寻找最佳分割面来将数据集划分为不同的类别,而 TensorFlow 通过构建多个决策树来进行分类。SVM 通常在高维空间中进行分类,而 TensorFlow 在输入空间中进行分类。

6.34 SVM 和 PyTorch 的区别?

SVM 和 PyTorch 都是用于二分类问题的机器学习算法,但它们在原理和应用上有一些区别。SVM 通过寻找最佳分割面来将数据集划分为不同的类别,而 PyTorch 通过构建多个决策树来进行分类。SVM 通常在高维空间中进行分类,而 PyTorch 在输入空间中进行分类。

6.35 SVM 和 Keras 的区别?

SVM 和 Keras 都是用于二分类问题的机器学习算法,但它们

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/universsky2015/article/details/137304086

智能推荐

18个顶级人工智能平台-程序员宅基地

文章浏览阅读1w次,点赞2次,收藏27次。来源:机器人小妹  很多时候企业拥有重复,乏味且困难的工作流程,这些流程往往会减慢生产速度并增加运营成本。为了降低生产成本,企业别无选择,只能自动化某些功能以降低生产成本。  通过数字化..._人工智能平台

electron热加载_electron-reloader-程序员宅基地

文章浏览阅读2.2k次。热加载能够在每次保存修改的代码后自动刷新 electron 应用界面,而不必每次去手动操作重新运行,这极大的提升了开发效率。安装 electron 热加载插件热加载虽然很方便,但是不是每个 electron 项目必须的,所以想要舒服的开发 electron 就只能给 electron 项目单独的安装热加载插件[electron-reloader]:// 在项目的根目录下安装 electron-reloader,国内建议使用 cnpm 代替 npmnpm install electron-relo._electron-reloader

android 11.0 去掉recovery模式UI页面的选项_android recovery 删除 部分菜单-程序员宅基地

文章浏览阅读942次。在11.0 进行定制化开发,会根据需要去掉recovery模式的一些选项 就是在device.cpp去掉一些选项就可以了。_android recovery 删除 部分菜单

mnn linux编译_mnn 编译linux-程序员宅基地

文章浏览阅读3.7k次。https://www.yuque.com/mnn/cn/cvrt_linux_mac基础依赖这些依赖是无关编译选项的基础编译依赖• cmake(3.10 以上)• protobuf (3.0 以上)• 指protobuf库以及protobuf编译器。版本号使用 protoc --version 打印出来。• 在某些Linux发行版上这两个包是分开发布的,需要手动安装• Ubuntu需要分别安装 libprotobuf-dev 以及 protobuf-compiler 两个包•..._mnn 编译linux

利用CSS3制作淡入淡出动画效果_css3入场效果淡入淡出-程序员宅基地

文章浏览阅读1.8k次。CSS3新增动画属性“@-webkit-keyframes”,从字面就可以看出其含义——关键帧,这与Flash中的含义一致。利用CSS3制作动画效果其原理与Flash一样,我们需要定义关键帧处的状态效果,由CSS3来驱动产生动画效果。下面讲解一下如何利用CSS3制作淡入淡出的动画效果。具体实例可参考刚进入本站时的淡入效果。1. 定义动画,名称为fadeIn@-webkit-keyf_css3入场效果淡入淡出

计算机软件又必须包括什么,计算机系统应包括硬件和软件两个子系统,硬件和软件又必须依次分别包括______?...-程序员宅基地

文章浏览阅读2.8k次。计算机系统应包括硬件和软件两个子系统,硬件和软件又必须依次分别包括中央处理器和系统软件。按人的要求接收和存储信息,自动进行数据处理和计算,并输出结果信息的机器系统。计算机是脑力的延伸和扩充,是近代科学的重大成就之一。计算机系统由硬件(子)系统和软件(子)系统组成。前者是借助电、磁、光、机械等原理构成的各种物理部件的有机组合,是系统赖以工作的实体。后者是各种程序和文件,用于指挥全系统按指定的要求进行..._计算机系统包括硬件系统和软件系统 软件又必须包括

随便推点

进程调度(一)——FIFO算法_进程调度fifo算法代码-程序员宅基地

文章浏览阅读7.9k次,点赞3次,收藏22次。一 定义这是最早出现的置换算法。该算法总是淘汰最先进入内存的页面,即选择在内存中驻留时间最久的页面予以淘汰。该算法实现简单,只需把一个进程已调入内存的页面,按先后次序链接成一个队列,并设置一个指针,称为替换指针,使它总是指向最老的页面。但该算法与进程实际运行的规律不相适应,因为在进程中,有些页面经常被访问,比如,含有全局变量、常用函数、例程等的页面,FIFO 算法并不能保证这些页面不被淘汰。这里,我_进程调度fifo算法代码

mysql rownum写法_mysql应用之类似oracle rownum写法-程序员宅基地

文章浏览阅读133次。rownum是oracle才有的写法,rownum在oracle中可以用于取第一条数据,或者批量写数据时限定批量写的数量等mysql取第一条数据写法SELECT * FROM t order by id LIMIT 1;oracle取第一条数据写法SELECT * FROM t where rownum =1 order by id;ok,上面是mysql和oracle取第一条数据的写法对比,不过..._mysql 替换@rownum的写法

eclipse安装教程_ecjelm-程序员宅基地

文章浏览阅读790次,点赞3次,收藏4次。官网下载下载链接:http://www.eclipse.org/downloads/点击Download下载完成后双击运行我选择第2个,看自己需要(我选择企业级应用,如果只是单纯学习java选第一个就行)进入下一步后选择jre和安装路径修改jvm/jre的时候也可以选择本地的(点后面的文件夹进去),但是我们没有11版本的,所以还是用他的吧选择接受安装中安装过程中如果有其他界面弹出就点accept就行..._ecjelm

Linux常用网络命令_ifconfig 删除vlan-程序员宅基地

文章浏览阅读245次。原文链接:https://linux.cn/article-7801-1.htmlifconfigping <IP地址>:发送ICMP echo消息到某个主机traceroute <IP地址>:用于跟踪IP包的路由路由:netstat -r: 打印路由表route add :添加静态路由路径routed:控制动态路由的BSD守护程序。运行RIP路由协议gat..._ifconfig 删除vlan

redux_redux redis-程序员宅基地

文章浏览阅读224次。reduxredux里要求把数据都放在公共的存储区域叫store里面,组件中尽量少放数据,假如绿色的组件要给很多灰色的组件传值,绿色的组件只需要改变store里面对应的数据就行了,接着灰色的组件会自动感知到store里的数据发生了改变,store只要有变化,灰色的组件就会自动从store里重新取数据,这样绿色组件的数据就很方便的传到其它灰色组件里了。redux就是把公用的数据放在公共的区域去存..._redux redis

linux 解压zip大文件(解决乱码问题)_linux 7za解压中文乱码-程序员宅基地

文章浏览阅读2.2k次,点赞3次,收藏6次。unzip版本不支持4G以上的压缩包所以要使用p7zip:Linux一个高压缩率软件wget http://sourceforge.net/projects/p7zip/files/p7zip/9.20.1/p7zip_9.20.1_src_all.tar.bz2tar jxvf p7zip_9.20.1_src_all.tar.bz2cd p7zip_9.20.1make && make install 如果安装失败,看一下报错是不是因为没有下载gcc 和 gcc ++(p7_linux 7za解压中文乱码