- 冒泡、选择、插入排序:三大基础排序算法深度解析(C语言实现)
xienda
算法排序算法数据结构
在算法学习道路上,排序算法是每位程序员必须掌握的基石。本文将深入解析冒泡排序、选择排序和插入排序这三种基础排序算法,通过C语言代码实现和对比分析,帮助读者彻底理解它们的差异与应用场景。算法原理与代码实现1.冒泡排序(BubbleSort)工作原理:通过重复比较相邻元素,将较大元素逐步"冒泡"到数组末尾。voidbubbleSort(intarr[],intn){ for(inti=0;iarr[
- 算法学习笔记:11.冒泡排序——从原理到实战,涵盖 LeetCode 与考研 408 例题
在排序算法的大家族中,冒泡排序是最基础也最经典的算法之一。它的核心思想简单易懂,通过重复地走访待排序序列,一次比较两个相邻的元素,若它们的顺序错误就把它们交换过来,直到没有需要交换的元素为止。虽然冒泡排序的时间复杂度较高,在大规模数据排序中并不常用,但它是理解排序算法思想的绝佳入门案例,也是计算机考研408和算法学习中的基础内容。冒泡排序的基本概念冒泡排序(BubbleSort)之所以被称为“冒泡
- C++排序算法全解析(加强版)
你的冰西瓜
排序算法c++算法
排序算法目录C++排序算法全解析冒泡排序(BubbleSort)一、引言二、冒泡排序的基本原理1.算法思想2.算法步骤三、C++实现代码示例代码解释四、性能分析与优化1.时间复杂度2.空间复杂度3.稳定性4.优化方法五、适用场景与总结1.适用场景2.总结选择排序(SelectionSort)一、引言二、选择排序的基本原理1.算法思想2.算法步骤三、C++实现代码示例代码解释四、性能分析与优化1.时
- 冒泡排序算法详解(含Python代码实现)
算法_小学生
算法
冒泡排序(BubbleSort)是最基础的排序算法之一,通常用于学习排序算法的入门理解。本文将通过Python代码实现冒泡排序,并详细讲解其原理、执行流程、复杂度分析及适用情况。✨一、算法简介冒泡排序的核心思想是:相邻两个元素比较,将较大的元素不断“冒泡”至右侧,最终实现排序。其基本过程是重复比较相邻的元素,如果顺序错误就交换,重复这一过程,直到没有任何需要交换的为止。二、Python代码实现下面
- 冒泡排序及其四种优化方式
GNUC
冒泡排序优化
冒泡排序及其四种优化方式一、冒泡排序一版代码使用双循环来进行排序。外部循环控制所有的回合,内部循环代表每一轮的交换处理。先进行元素比较,再进行元素交换voidBubbleSort(inta[],intn){for(inti=1;ia[j+1]){intt=a[j];a[j]=a[j+1];a[j+1]=t;}}}}二、冒泡排序二版在循环过程中若判断出数列已经有序,做出标记,可提早结束循环在一版
- 冒泡排序及其优化方式详解(JavaScript实现)
碧海蓝天·
javascript开发语言ecmascriptJavaScript
冒泡排序是一种简单但效率较低的排序算法,它通过多次迭代比较相邻元素,并交换它们的位置,使得每一轮迭代都将最大(或最小)的元素移动到末尾。本文将以JavaScript代码和动画的方式详细解释冒泡排序的工作原理,并介绍一些优化方式。冒泡排序的基本实现下面是使用JavaScript实现冒泡排序的基本代码:functionbubbleSort(arr){constlen=arr.length;for(<
- 冒泡排序及其优化方式
一、基本概念冒泡排序(BubbleSort)是一种简单的比较排序算法,它重复地遍历要排序的数列,一次比较两个元素,如果它们的顺序错误就把它们交换过来。核心思想:通过相邻元素的比较和交换,将较大的元素逐渐"浮"到数列的末端二、基础实现基础冒泡排序算法Java实现publicclassBubbleSort{publicstaticvoidbubbleSort(int[]arr){//外层循环控制排序轮
- 【数据结构】排序算法:冒泡与快速
nanguochenchuan
数据结构排序算法数据结构算法
引言:排序算法的重要性排序算法是计算机科学的基础核心,直接影响程序性能和资源消耗。在C语言开发中,理解不同排序算法的特性对编写高效代码至关重要。本文将深入分析两种经典排序算法:简单直观的冒泡排序和高效快速的快速排序,并提供完整的C语言实现。冒泡排序:简单但低效基本思想冒泡排序通过相邻元素比较交换,使较大元素逐渐移动到数组末端,如同气泡上浮。C语言实现#includevoidbubbleSort(i
- python 几种排序方法与二分查找
愤怒的玉米棒
python学习小结python
#选择排序defselectionSort(arr):#-1虽然有n个数字但是没有第n轮最多n-1轮foriinrange(0,len(arr)-1):forjinrange(i+1,len(arr)):ifarr[i]>arr[j]:arr[i],arr[j]=arr[j],arr[i]print(arr)#冒泡排序defbubbleSort(arr):#-1虽然有n个数字但是没有第n轮最多n-
- 常见排序方法大全
实相无相
算法排序算法数据结构
这篇文章主要讨论各种常见的排序算法,包括冒泡排序、插入排序、选择排序、快速排序、堆排序、希尔排序、归并排序、基数排序等。每种排序算法都有它自己的特点。本文将对这些算法的工作原理、特点、时间复杂度等方面进行介绍,并且给出实现示例。一:基本定义冒泡排序(BubbleSort):是一种简单的排序算法,它重复地走访过要排序的数列,一次比较两个元素,如果它们的顺序错误就把它们交换过来。插入排序(Insert
- 排序算法总结
高小秋
排序算法算法数据结构
稳定排序算法稳定排序保证相等元素的相对顺序在排序后不变。常见算法包括:冒泡排序○通过相邻元素比较和交换,相等元素不会交换位置。时间复杂度为O(n²),适合教学演示和小规模数据排序。publicclassBubbleSort{publicstaticvoidbubbleSort(int[]arr){intn=arr.length;for(inti=0;iarr[j+1]){//交换相邻元素
- 【Python 算法零基础 4.排序 ⑪ 十大排序算法总结】
L_cl
排序算法算法python
目录一、选择排序回顾二、冒泡排序回顾三、插入排序回顾四、计数排序回顾五、归并排序回顾六、快速排序回顾七、桶排序回顾八、基数排序九、堆排序十、希尔排序十一、十大排序算法对比十二、各算法详解与应用场景1.选择排序(SelectionSort)2.冒泡排序(BubbleSort)3.插入排序(InsertionSort)4.计数排序(CountingSort)5.归并排序(MergeSort)6.快速排
- 十大排序法1
小小桃核
c语言
一、冒泡排序原理:相邻元素比较,大的往后“冒泡”。voidbubbleSort(intarr[],intn){inti,j,temp;for(i=0;iarr[j+1]){//升序排列,降序改=0&&arr[j]>key){//升序,降序改<arr[j+1]=arr[j];j--;}arr[j+1]=key;}}
- 八大内部排序
Stillsings
数据结构数据结构排序算法算法八大排序内部排序
八大排序前言排序,就是重新排列表中的元素,使得表中元素满足按关键字有序的过程。排序有许多种,常用的八大内部排序为冒泡排序、插入排序、选择排序、希尔排序、快速排序、归并排序、基数排序、堆排序这几种排序没有绝对的优劣,每种排序都有他们适用范围一、冒泡排序冒泡排序每一趟排序可以确定一个元素的最终位置,若一次扫描并没有元素进行交换,则说明表已有序。voidbubbleSort(ElemTypea[],in
- 排序算法(冒泡、选择、插入、快速、归并、计数、基数、桶)
real宝
排序算法算法
一、冒泡排序核心思想依次比较相邻的两个元素,将较大的元素“冒泡”到序列末端。每一趟遍历,都会把当前未排序部分的最大元素放到该区域的尾。稳定(相等元素不会改变相对次序)伪代码functionbubbleSort(A[0..n-1]):forifrom0ton-2:swapped=false//标记本趟是否发生过交换forjfrom0ton-2-i:ifA[j]>A[j+1]:swapA[j],A[j
- 常见排序算法的优缺点及实际案例分析
TLuoQiu
算法python
排序算法在计算机科学中扮演着重要角色,常用于数据整理、查找和优化。本文将介绍几种常见的排序算法,包括冒泡排序、选择排序、插入排序、快速排序和归并排序,并分析它们的优缺点以及实际应用案例。1.冒泡排序(BubbleSort)优点:实现简单,易于理解。适用于小规模数据的排序。缺点:时间复杂度为O(n^2),对于大规模数据效率低下。每次遍历都要进行多次比较,耗时较长。实际案例:在一个小型程序中需要对十个
- 【排序算法】典型排序算法 Java实现
五步晦暝
Java排序算法java算法
以下是典型的排序算法分类及对应的Java实现,包含时间复杂度、稳定性说明和核心代码示例:一、比较类排序(通过元素比较)1.交换排序①冒泡排序时间复杂度:O(n²)(优化后最优O(n))稳定性:稳定publicstaticvoidbubbleSort(int[]arr){booleanswapped;for(inti=0;iarr[j+1]){inttemp=arr[j];arr[j]=arr[j+
- 数据结构 -- 交换排序(冒泡排序和快速排序)
_安晓
数据结构数据结构排序算法java
冒泡排序基于“交换”的排序:根据序列中两个元素关键字的比较结果来对换这两个记录在序列中的位置//交换voidswap(int&a,int&b){inttemp=a;a=b;b=temp;}//冒泡排序voidBubbleSort(intA[],intn){for(inti=0;ii;j--)if(A[j-1]>A[j]){swap(A[j-1],A[j]);flag=true;}if(flag==
- undefined reference to‘ 函数名(std::vector<int, std::allocator<int>>)‘
吃瓜太狼
c++
今天复习排序,心血来潮想用面向对象的形式来写,然后就写出了bug,记录一下,我觉得我以后不会再犯这个错误了,希望各位看官注意!链接时候报了这个错。如下是头文件SortAlgorithm.htemplateboolbubble_sort(std::vectorvec);如下是.cc实现文件#include"SortAlgorithm.h"voidSortAlgorithm::BubbleSort(s
- C语言复习 冒泡排序法
8678778
c语言排序算法算法
冒泡排序(BubbleSort)也是一种简单直观的排序算法。它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。这个算法的名字由来是因为越小的元素会经由交换慢慢"浮"到数列的顶端。作为最简单的排序算法之一,冒泡排序给我的感觉就像Abandon在单词书里出现的感觉一样,每次都在第一页第一位,所以最
- 常见排序算法整理(Java实现)
Fanxt_Ja
算法排序算法java算法
1.冒泡排序(BubbleSort)原理重复遍历数组,比较相邻元素,若顺序错误则交换。每趟将最大元素"冒泡"到末尾。每次遍历保证了最大元素被放在最后,所以内层循环不需要遍历到最后的位置。代码实现publicstaticvoidbubbleSort(int[]arr){intn=arr.length;for(inti=0;iarr[j+1]){//交换相邻元素inttemp=arr[j];arr[j
- leetcodehot100刷题——排序算法总结
姬公子521
力扣刷题专栏排序算法算法数据结构c++
排序算法总结冒泡排序介绍步骤(以升序排序为例)算法实现复杂度分析时间复杂度空间复杂度是否为稳定排序:是稳定排序的定义选择排序介绍步骤(以升序排序为例)算法实现复杂度分析时间复杂度空间复杂度是否为稳定排序:否举个栗子!今天先总结这俩,明天接着补~冒泡排序介绍冒泡排序(BubbleSort)是一种简单的比较排序算法,其工作原理类似于气泡在水中上升的过程。它通过重复遍历要排序的列表,比较相邻的两个元素,
- C/C++实践(十)C语言冒泡排序深度解析:发展历史、技术方法与应用场景
技术流浪者
#C/C++算法排序算法数据结构c++c语言
一、发展历史冒泡排序(BubbleSort)作为计算机科学领域最基础的排序算法之一,其历史可追溯至计算机编程的早期阶段。尽管具体起源时间难以考证,但它在20世纪50年代至60年代间被广泛讨论和应用。冒泡排序的名称来源于其独特的排序特性:较小的元素会像气泡一样逐渐“浮”到序列的顶端,而较大的元素则逐渐“沉”到底部。早期发展背景:在计算机科学初期,内存和计算资源极其有限,算法设计需兼顾简单性与效率。冒
- 排序算法解析实现与时间复杂度分析
zhxup606
数据结构与算法排序算法算法java
排序算法是计算机科学中的基础内容,用于将一组数据按特定顺序排列。以下是对常见排序算法的详细解析,包括实现代码(以Python为例)、时间复杂度分析以及特点。算法按复杂度递增顺序介绍,涵盖简单排序、进阶排序和特殊场景优化排序。---1.冒泡排序(BubbleSort)原理冒泡排序通过重复比较相邻元素并交换位置,逐步将最大(或最小)元素“冒泡”到数组一端。实现```pythondefbubble_so
- C 语言数组排序:深入理解与实现冒泡排序 (Bubble Sort)
web安全工具库
2025C++学习状态模式
各类资料学习下载合集https://pan.quark.cn/s/8c91ccb5a474C语言数组排序:深入理解与实现冒泡排序(BubbleSort)在日常编程中,对数据进行排序是一项非常常见的任务。排序算法有很多种,各有其特点和适用场景。对于初学者来说,冒泡排序(BubbleSort)是一个非常直观且易于理解的入门级排序算法。本文将详细讲解冒泡排序的原理、工作机制,并通过C语言代码实现它,展示
- 【Hot 100】 148. 排序链表
海码007
算法链表排序算法hot100C++数据结构
目录引言十大排序算法1.冒泡排序(BubbleSort)2.选择排序(SelectionSort)3.插入排序(InsertionSort)4.希尔排序(ShellSort)简单代码说明关键特点5.归并排序(MergeSort)6.快速排序(QuickSort)7.堆排序(HeapSort)8.计数排序(CountingSort)9.桶排序(BucketSort)10.基数排序(RadixSort
- 【万字超精品】一篇文章搞清楚全部排序(冒泡排序插入排序希尔排序选择排序堆排序快速排序(递归非递归)归并排序(递归非递归)计数排序)
爱吃生蚝的于勒
数据结构初阶启动!!!!!!C语言成长之路算法排序算法数据结构c语言学习开发语言linux
文章目录简介冒泡冒泡优化直接插入希尔选择排序堆排快排非递归归并排序非递归计数排序时间复杂度+稳定性选择合适排序算法**==谢谢观看,写的真的很累很累,点点赞评个论也会去阁下文章称赞的。==**简介排序是计算机领域最基础且重要的算法,将一组数据按降序或升序重新排列,如网购网站价格排序等等。广泛用于==数据库查询,数据分析,搜索算法,==等等。冒泡voidBubbleSort(int*a,intn){
- 数据结构与算法-常用排序算法
砥砺前行~
数据结构与算法排序算法c++
承接Qt/C++软件开发项目,高质量交付,灵活沟通,长期维护支持。需求所寻,技术正适,共创完美,欢迎私信联系!一、常用排序说明当涉及排序算法时,理解每个算法的工作原理、时间复杂度和空间复杂度是至关重要的。下面对常用排序算法进行详细说明:1、冒泡排序(BubbleSort):工作原理:比较相邻的元素并交换,每一轮将最大(或最小)的元素移动到数组末尾(或开头)。时间复杂度:平均情况和最坏情况均为O(n
- 八大排序——冒泡排序(Java实现)
Q&B
算法java开发语言排序算法数据结构算法
在计算机科学中,排序算法是一种将一组数据项按照某种顺序排列的算法。排序算法在数据处理中起着至关重要的作用,它们被广泛应用于各种软件和系统中。冒泡排序(BubbleSort)是一种简单的排序算法,它重复地遍历待排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。遍历数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。一、冒泡排序的基本思想冒泡排序的基本思想是:通过相邻
- c语言数据结构-------------交换排序
javaisC
数据结构c语言算法
#includevoidswap(int*,int*);intPartition(intA[],intlow,inthigh);//冒泡排序voidBubbleSort(intA[],intn){for(inti=0;iA[j+1]){swap(&A[j],&A[j+1]);flag++;}}if(flag==0){break;}}}voidswap(int*a,int*b){intt=*a;*a
- jvm调优总结(从基本概念 到 深度优化)
oloz
javajvmjdk虚拟机应用服务器
JVM参数详解:http://www.cnblogs.com/redcreen/archive/2011/05/04/2037057.html
Java虚拟机中,数据类型可以分为两类:基本类型和引用类型。基本类型的变量保存原始值,即:他代表的值就是数值本身;而引用类型的变量保存引用值。“引用值”代表了某个对象的引用,而不是对象本身,对象本身存放在这个引用值所表示的地址的位置。
- 【Scala十六】Scala核心十:柯里化函数
bit1129
scala
本篇文章重点说明什么是函数柯里化,这个语法现象的背后动机是什么,有什么样的应用场景,以及与部分应用函数(Partial Applied Function)之间的联系 1. 什么是柯里化函数
A way to write functions with multiple parameter lists. For instance
def f(x: Int)(y: Int) is a
- HashMap
dalan_123
java
HashMap在java中对很多人来说都是熟的;基于hash表的map接口的非同步实现。允许使用null和null键;同时不能保证元素的顺序;也就是从来都不保证其中的元素的顺序恒久不变。
1、数据结构
在java中,最基本的数据结构无外乎:数组 和 引用(指针),所有的数据结构都可以用这两个来构造,HashMap也不例外,归根到底HashMap就是一个链表散列的数据
- Java Swing如何实时刷新JTextArea,以显示刚才加append的内容
周凡杨
java更新swingJTextArea
在代码中执行完textArea.append("message")后,如果你想让这个更新立刻显示在界面上而不是等swing的主线程返回后刷新,我们一般会在该语句后调用textArea.invalidate()和textArea.repaint()。
问题是这个方法并不能有任何效果,textArea的内容没有任何变化,这或许是swing的一个bug,有一个笨拙的办法可以实现
- servlet或struts的Action处理ajax请求
g21121
servlet
其实处理ajax的请求非常简单,直接看代码就行了:
//如果用的是struts
//HttpServletResponse response = ServletActionContext.getResponse();
// 设置输出为文字流
response.setContentType("text/plain");
// 设置字符集
res
- FineReport的公式编辑框的语法简介
老A不折腾
finereport公式总结
FINEREPORT用到公式的地方非常多,单元格(以=开头的便被解析为公式),条件显示,数据字典,报表填报属性值定义,图表标题,轴定义,页眉页脚,甚至单元格的其他属性中的鼠标悬浮提示内容都可以写公式。
简单的说下自己感觉的公式要注意的几个地方:
1.if语句语法刚接触感觉比较奇怪,if(条件式子,值1,值2),if可以嵌套,if(条件式子1,值1,if(条件式子2,值2,值3)
- linux mysql 数据库乱码的解决办法
墙头上一根草
linuxmysql数据库乱码
linux 上mysql数据库区分大小写的配置
lower_case_table_names=1 1-不区分大小写 0-区分大小写
修改/etc/my.cnf 具体的修改内容如下:
[client]
default-character-set=utf8
[mysqld]
datadir=/var/lib/mysql
socket=/va
- 我的spring学习笔记6-ApplicationContext实例化的参数兼容思想
aijuans
Spring 3
ApplicationContext能读取多个Bean定义文件,方法是:
ApplicationContext appContext = new ClassPathXmlApplicationContext(
new String[]{“bean-config1.xml”,“bean-config2.xml”,“bean-config3.xml”,“bean-config4.xml
- mysql 基准测试之sysbench
annan211
基准测试mysql基准测试MySQL测试sysbench
1 执行如下命令,安装sysbench-0.5:
tar xzvf sysbench-0.5.tar.gz
cd sysbench-0.5
chmod +x autogen.sh
./autogen.sh
./configure --with-mysql --with-mysql-includes=/usr/local/mysql
- sql的复杂查询使用案列与技巧
百合不是茶
oraclesql函数数据分页合并查询
本片博客使用的数据库表是oracle中的scott用户表;
------------------- 自然连接查询
查询 smith 的上司(两种方法)
&
- 深入学习Thread类
bijian1013
javathread多线程java多线程
一. 线程的名字
下面来看一下Thread类的name属性,它的类型是String。它其实就是线程的名字。在Thread类中,有String getName()和void setName(String)两个方法用来设置和获取这个属性的值。
同时,Thr
- JSON串转换成Map以及如何转换到对应的数据类型
bijian1013
javafastjsonnet.sf.json
在实际开发中,难免会碰到JSON串转换成Map的情况,下面来看看这方面的实例。另外,由于fastjson只支持JDK1.5及以上版本,因此在JDK1.4的项目中可以采用net.sf.json来处理。
一.fastjson实例
JsonUtil.java
package com.study;
impor
- 【RPC框架HttpInvoker一】HttpInvoker:Spring自带RPC框架
bit1129
spring
HttpInvoker是Spring原生的RPC调用框架,HttpInvoker同Burlap和Hessian一样,提供了一致的服务Exporter以及客户端的服务代理工厂Bean,这篇文章主要是复制粘贴了Hessian与Spring集成一文,【RPC框架Hessian四】Hessian与Spring集成
在
【RPC框架Hessian二】Hessian 对象序列化和反序列化一文中
- 【Mahout二】基于Mahout CBayes算法的20newsgroup的脚本分析
bit1129
Mahout
#!/bin/bash
#
# Licensed to the Apache Software Foundation (ASF) under one or more
# contributor license agreements. See the NOTICE file distributed with
# this work for additional information re
- nginx三种获取用户真实ip的方法
ronin47
随着nginx的迅速崛起,越来越多公司将apache更换成nginx. 同时也越来越多人使用nginx作为负载均衡, 并且代理前面可能还加上了CDN加速,但是随之也遇到一个问题:nginx如何获取用户的真实IP地址,如果后端是apache,请跳转到<apache获取用户真实IP地址>,如果是后端真实服务器是nginx,那么继续往下看。
实例环境: 用户IP 120.22.11.11
- java-判断二叉树是不是平衡
bylijinnan
java
参考了
http://zhedahht.blog.163.com/blog/static/25411174201142733927831/
但是用java来实现有一个问题。
由于Java无法像C那样“传递参数的地址,函数返回时能得到参数的值”,唯有新建一个辅助类:AuxClass
import ljn.help.*;
public class BalancedBTree {
- BeanUtils.copyProperties VS PropertyUtils.copyProperties
诸葛不亮
PropertyUtilsBeanUtils
BeanUtils.copyProperties VS PropertyUtils.copyProperties
作为两个bean属性copy的工具类,他们被广泛使用,同时也很容易误用,给人造成困然;比如:昨天发现同事在使用BeanUtils.copyProperties copy有integer类型属性的bean时,没有考虑到会将null转换为0,而后面的业
- [金融与信息安全]最简单的数据结构最安全
comsci
数据结构
现在最流行的数据库的数据存储文件都具有复杂的文件头格式,用操作系统的记事本软件是无法正常浏览的,这样的情况会有什么问题呢?
从信息安全的角度来看,如果我们数据库系统仅仅把这种格式的数据文件做异地备份,如果相同版本的所有数据库管理系统都同时被攻击,那么
- vi区段删除
Cwind
linuxvi区段删除
区段删除是编辑和分析一些冗长的配置文件或日志文件时比较常用的操作。简记下vi区段删除要点备忘。
vi概述
引文中并未将末行模式单独列为一种模式。单不单列并不重要,能区分命令模式与末行模式即可。
vi区段删除步骤:
1. 在末行模式下使用:set nu显示行号
非必须,随光标移动vi右下角也会显示行号,能够正确找到并记录删除开始行
- 清除tomcat缓存的方法总结
dashuaifu
tomcat缓存
用tomcat容器,大家可能会发现这样的问题,修改jsp文件后,但用IE打开 依然是以前的Jsp的页面。
出现这种现象的原因主要是tomcat缓存的原因。
解决办法如下:
在jsp文件头加上
<meta http-equiv="Expires" content="0"> <meta http-equiv="kiben&qu
- 不要盲目的在项目中使用LESS CSS
dcj3sjt126com
Webless
如果你还不知道LESS CSS是什么东西,可以看一下这篇文章,是我一朋友写给新人看的《CSS——LESS》
不可否认,LESS CSS是个强大的工具,它弥补了css没有变量、无法运算等一些“先天缺陷”,但它似乎给我一种错觉,就是为了功能而实现功能。
比如它的引用功能
?
.rounded_corners{
- [入门]更上一层楼
dcj3sjt126com
PHPyii2
更上一层楼
通篇阅读完整个“入门”部分,你就完成了一个完整 Yii 应用的创建。在此过程中你学到了如何实现一些常用功能,例如通过 HTML 表单从用户那获取数据,从数据库中获取数据并以分页形式显示。你还学到了如何通过 Gii 去自动生成代码。使用 Gii 生成代码把 Web 开发中多数繁杂的过程转化为仅仅填写几个表单就行。
本章将介绍一些有助于更好使用 Yii 的资源:
- Apache HttpClient使用详解
eksliang
httpclienthttp协议
Http协议的重要性相信不用我多说了,HttpClient相比传统JDK自带的URLConnection,增加了易用性和灵活性(具体区别,日后我们再讨论),它不仅是客户端发送Http请求变得容易,而且也方便了开发人员测试接口(基于Http协议的),即提高了开发的效率,也方便提高代码的健壮性。因此熟练掌握HttpClient是很重要的必修内容,掌握HttpClient后,相信对于Http协议的了解会
- zxing二维码扫描功能
gundumw100
androidzxing
经常要用到二维码扫描功能
现给出示例代码
import com.google.zxing.WriterException;
import com.zxing.activity.CaptureActivity;
import com.zxing.encoding.EncodingHandler;
import android.app.Activity;
import an
- 纯HTML+CSS带说明的黄色导航菜单
ini
htmlWebhtml5csshovertree
HoverTree带说明的CSS菜单:纯HTML+CSS结构链接带说明的黄色导航
在线体验效果:http://hovertree.com/texiao/css/1.htm代码如下,保存到HTML文件可以看到效果:
<!DOCTYPE html >
<html >
<head>
<title>HoverTree
- fastjson初始化对性能的影响
kane_xie
fastjson序列化
之前在项目中序列化是用thrift,性能一般,而且需要用编译器生成新的类,在序列化和反序列化的时候感觉很繁琐,因此想转到json阵营。对比了jackson,gson等框架之后,决定用fastjson,为什么呢,因为看名字感觉很快。。。
网上的说法:
fastjson 是一个性能很好的 Java 语言实现的 JSON 解析器和生成器,来自阿里巴巴的工程师开发。
- 基于Mybatis封装的增删改查实现通用自动化sql
mengqingyu
DAO
1.基于map或javaBean的增删改查可实现不写dao接口和实现类以及xml,有效的提高开发速度。
2.支持自定义注解包括主键生成、列重复验证、列名、表名等
3.支持批量插入、批量更新、批量删除
<bean id="dynamicSqlSessionTemplate" class="com.mqy.mybatis.support.Dynamic
- js控制input输入框的方法封装(数字,中文,字母,浮点数等)
qifeifei
javascript js
在项目开发的时候,经常有一些输入框,控制输入的格式,而不是等输入好了再去检查格式,格式错了就报错,体验不好。 /** 数字,中文,字母,浮点数(+/-/.) 类型输入限制,只要在input标签上加上 jInput="number,chinese,alphabet,floating" 备注:floating属性只能单独用*/
funct
- java 计时器应用
tangqi609567707
javatimer
mport java.util.TimerTask; import java.util.Calendar; public class MyTask extends TimerTask { private static final int
- erlang输出调用栈信息
wudixiaotie
erlang
在erlang otp的开发中,如果调用第三方的应用,会有有些错误会不打印栈信息,因为有可能第三方应用会catch然后输出自己的错误信息,所以对排查bug有很大的阻碍,这样就要求我们自己打印调用的栈信息。用这个函数:erlang:process_display (self (), backtrace).需要注意这个函数只会输出到标准错误输出。
也可以用这个函数:erlang:get_s