深入探討JS中的數組排序函數sort()和reverse()

最近在研究Javascript發現了其中一些比較靈異的事情。有點讓人感到無語比如:

  alert(typeof( NaN == NaN));//結果為假。

  alert(typeof( NaN != NaN));//結果為真。

  嘿嘿,當然這個不是這篇文章要討論的!!開始我們的正文

  首先,我們來看一下JS中sort()和reverse()這兩個函數的函數吧

  reverse();這個函數是用來進行倒序,這個沒有什么可說的,所謂倒序就是大的在前面,小的在后面。

  比如:

  var array1 = [0,1,5,10,15];

  array1.reverse();//結果為:15,10,5,1,0

  sort([參數]);這個函數是用來對數組進行正序排列的,但是,我發現了,大家好像都比較常規的把這個函數給大多數語言一樣的使用!!但是,沒錯,你發現了這個函數其實是有參數的。

  反正,在我們學習JS這門課程的時候,老師是沒有講解這個函數是有這個參數的。

  剛剛我已經說了,它給我們其它語言的正序排列函數是有區別的,給大家舉個例子吧.

  var array1 = [0,1,5,10,15];

  array1.sort();//結果為:0,1,10,15,5

  大家可以自己去試試看看是不是這個結果!!當我看到結果的時候,有點不知道為什么。難道,這個函數不是做正序排列,于是去網上找了相關資料,在W3CSchool中看到,這個函數的一些說明。如下圖

  

?

?

  大家仔細閱讀上圖中的解釋,其中我用紅線部分的地方,是這個函數在進行排序的過程影響其值的根本原因。(其實,在使用sort()進行排序的時候會調用toString()函數將其值轉換成字符串在進行比較,是按ASCII進行比較的)

  哪么不難理解:1的ASCII值肯定要比5的ASCII值小,由于是正序哪么越小的就越在前面!!哪么我們要怎么做才能正確的使其排序達到我們想要的效果 呢。這個時候,就會使用,sort()中的參數了。這參數指向的是一個函數!我相信大家看到上面的圖,我就不在做過多的解釋了。看一下,下面的代碼,我在 分析一下,他的實現過程吧。

  

?

function con(v1,v2) {if (v1<v2) {return -1;        }else if(v1>v2){return 1;}else{return 0;}
}

?

?

  注:sort() 方法可以接受一個 方法為參數 ,這個方法有兩個參數。分別代表每次排序比較時的兩個數組項。sort()排序時每次比較兩個數組項都回執行這個參數,并把兩個比較的數組項作為參數傳遞 給這個函數。當函數返回值為1的時候就交換兩個數組項的順序,否則就不交換。

  首先,要說明一下!排序算法是離不開冒泡算法的!這里同樣是使用了冒泡算法,但是我們要怎么來理解這個算定義函數呢!

  這個算定義函數必須有兩個參數(這個在進行排序,換而言之就是誰大誰就在前面!!就是比較大小。)

  函數的的意思是,當v1<V2為-1,V1>v2為1,v1==v2為0

<V2為-1,V1>

<V2為-1,V1>

  根據冒泡算法:傳遞兩個值給v1和v2,array[0] ="0",array[1]="2" 那么,v1=0,v2=2,

  第一輪:按照上面的規定,不交換位置,那么第一次下來是:0,2,1,0.5因為0比任何的數都小所以第一輪結束,他始終在最前面我就不分析了

  第二輪:v1=2,v2=1;

  第一次:由于v1>v2所以v1和v2的值交換位置結果為:0,1,2,0.5;

  第二次:這個時候v1=1,v2=2進行比較結題為:0,1,2,0.5,

  第三次:這個時候v1=1,v2=0.5由于v1>v2所以v2和v2交換位置,其結果為:0,0.5,1,2

  第四次:這個時候v1=0.5,v2=2進行比較其結果為:0,0.5,1,2

  第三輪:v1=1,v2=2;

  第一次:進行比較其結果為0,0.5,1,2這個時候由于已經到數組的么尾了。退出函數。返回結果。

  好了,這個就是sort()函數的一個探討,希望,大家看完此文章對JS的排序函數有一個比較深入的了解。當然,我講解的這種寫法是一種比較通用的寫法, 大家也可以按照自己的需要寫一下,倒序,大、小寫等 等 ...這里就不在多說了!!可能有些許地方,講解得不夠好。希望大家能夠諒解。如果有什么疑問,請在文章下面留言。

轉載于:https://www.cnblogs.com/RuMengkai/p/6501408.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/372790.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/372790.shtml
英文地址,請注明出處:http://en.pswp.cn/news/372790.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

帶有謂詞的Java中的功能樣式-第1部分

您一直在聽到將要席卷全球的函數式編程&#xff0c;而您仍然堅持使用普通Java&#xff1f; 不用擔心&#xff0c;因為您已經可以在日常Java中添加一些功能樣式。 此外&#xff0c;它很有趣&#xff0c;可以節省許多代碼行并減少錯誤。 什么是謂詞&#xff1f; 實際上&#xff…

寶塔添加多占點_寶塔面板啟用WordPress多站點子域名、子目錄

其實在很早以前&#xff0c;陌小雨就聽說了 wordpress 的多站點功能&#xff0c;不過因為不清楚&#xff0c;所以懶得折騰&#xff0c;這不這幾天閑著蛋疼&#xff0c;好好研究了下這玩意&#xff0c;用起來的感覺還是相當不錯的&#xff0c;總結起來就是如果你準備開始用 word…

centos 6.5下安裝文件上傳下載服務

centos 6.5下安裝文件上傳下載服務 由于每次在CentOS中要下載一些配置文件到物理機&#xff0c;和上傳一些文件到服務器&#xff0c;導致來回的開啟ftp軟件有點麻煩&#xff0c;這里我們可以使用文件上傳下載服務&#xff0c;來解決上傳和下載的問題。 1.登錄服務器 2.執行命令…

Jenkins 入門系列--jenkins 介紹

第一章 Jenkins是什么&#xff1f; Jenkins 是一個可擴展的持續集成引擎。 主要用于&#xff1a; l 持續、自動地構建/測試軟件項目。 l 監控一些定時執行的任務。Jenkins擁有的特性包括&#xff1a; l 易于安裝-只要把jenkins.war部署到servlet容器&#xff0c;不需要數據庫支…

在方法參數上使用final關鍵字

經過一些自己的混淆&#xff0c;最終博客方法的具體含義&#xff08;最終聲明的方法參數&#xff09;將對此博客條目進行澄清。 至少可以將方法參數上的final關鍵字視為Java編譯器的指示符&#xff0c;表明該參數不能重新分配給另一個引用。 Java參數處理始終是“按值調用” &a…

PHP MySQLi 增刪改查

最近幾天&#xff0c;我們一直在學習利用MySQLi訪問數據庫并對其中的數據進行操作。今天給大家展現一個完整的例子&#xff0c;我們來制作一個新聞發布系統&#xff0c;利用MySQLi來操作數據庫&#xff0c;實現對新聞的添加、修改、刪除、查詢等基本功能。&#xff08;以下代碼…

20162303《程序設計與數據結構》第一周學習總結

學號 2016-2017-2 《程序設計與數據結構》第1周學習總結 教材學習內容總結 本周學習了基本的JAVA知識&#xff0c;雖然比較基礎&#xff0c;但是在實際過程中還是出現了許許多多的問題&#xff0c;代碼一遍遍的敲錯&#xff0c;又一遍遍的修改&#xff0c;剛開始甚至不會切換模…

Java EE與NoSQL的未來

自一段時間以來&#xff0c;我一直在關注NoSQL的近期發展勢頭&#xff0c;似乎這個流行語也引起了企業Java界的某種關注。 即EclipseLink 2.4開始支持MongoDB和Oracle NoSQL 。 將EclipseLink作為JPA參考實現&#xff0c;您可能想知道這對Java EE 7意味著什么。這里簡短說明&am…

【C/C++開發】C語言實現函數可變參數

函數原型: int printf(const char *format[,argument]...) 返 回 值: 成功則返回實際輸出的字符數&#xff0c;失敗返回-1. 函數說明: 在printf()函數中&#xff0c;format后面的參數個數不確定&#xff0c;且類型也不確定&#xff0c;這些參數都存放在棧內.調用…

java postgresql json_java – 將PostgreSQL JSON列映射到Hibernate值類...

See PgJDBC bug #265.PostgreSQL對數據類型轉換過于嚴格,非常嚴格.它不會隱式地將文本轉換為類似文本的值,例如xml和json.解決此問題的嚴格正確方法是編寫使用JDBC setObject方法的自定義Hibernate映射類型.這可能有點麻煩,所以你可能只想通過創建一個較弱的強制轉換來使Postgr…

面向接口編程詳解(三)——模式研究

通過前面兩篇&#xff0c;我想各位朋友對“面向接口編程”的思想有了一定認識&#xff0c;并通過第二篇的例子&#xff0c;獲得了一定的直觀印象。但是&#xff0c;第二篇中的例子旨在展示面向接口編程的實現方法&#xff0c;比較簡單&#xff0c;不能體現出面向接口編程的優勢…

錯誤學習:Java + OSGi

最近&#xff0c;我致力于在OSGi環境中使Apache Hive工作。 雖然沒有被證明是小菜一碟&#xff08;軟件對嗎&#xff1f;。。為什么我不感到驚訝&#xff1f; &#xff09;&#xff0c;它引導我解決了各種Java和OSGi錯誤。 在這里&#xff0c;我列出了其中一些讓我有些吃力的東…

iOS多Targets管理

序言&#xff1a; 個人不善于寫東西&#xff0c;就直奔主題了。 其實今天會注意到多targets這個東西&#xff0c;是因為在學習一個第三方庫FBMemoryProfiler的時候&#xff0c;用到了&#xff0c;所以就搜索了一些相關資料&#xff0c;就在這里記錄一下。 可能每個人都會遇到這…

優化的34條定律

1.Minimize HTTP Requests 減少HTTP請求 圖片、css、script、flash等等這些都會增加http請求數&#xff0c;減少這些元素的數量就能減少響應時間。把多個JS、CSS在可能的情況下寫進一個文件&#xff0c;頁面里直接寫入圖片也是不好的做法&#xff0c;應該寫進CSS里&#xff0c;…

休眠提示:排序和排序

讓我們介紹另一個休眠性能提示。 你還記得以前的休眠的模式后 &#xff1f; 我們有一個與一對多協會有關的星際飛船和軍官。 Entity public class Starship {Id GeneratedValue(strategyGenerationType.SEQUENCE) private Long id;public Long getId() {return id;}protected v…

java 基本類型 線程安全_java的基本類型和i++線程安全性的深入解析

在java中&#xff0c;除了long和double的8個字節、64位比特的變量外&#xff0c;其他的基本變量都是原子性的。java存儲模型要求獲取和存儲操作都為原子性&#xff0c;但是對于非volatile的long和double變量&#xff0c;jvm允許將64位的讀或寫劃分為兩個32位的操作。如果讀和寫…

MySQL配置文件mysql.ini參數詳解

my.ini&#xff08;Linux系統下是my.cnf&#xff09;&#xff0c;當mysql服務器啟動時它會讀取這個文件&#xff0c;設置相關的運行環境參數。 my.ini分為兩塊&#xff1a;Client Section和Server Section。 Client Section用來配置MySQL客戶端參數。 要查看配置參數可以用下面…

微信公眾平臺和微信開放平臺的區別

自己也剛開始做微信開發&#xff0c;先寫寫自己的認識&#xff1a; 用微信公眾平臺可以做手機端H5頁面的微信登錄&#xff0c;微信支付 用微信開放平臺可以做PC端網頁的微信登錄。 轉載于:https://www.cnblogs.com/mafeng/p/5610770.html

java 傳遞bean_如何將bean作為參數傳遞給JSP標記?

我ve created a custom JSP tag that is supposed to accept a list of products to render, but I我無法弄清楚如何將列表傳遞給標簽 . 產品列表作為頁面范圍的bean存在 . Web應用程序使用Struts taglib在Struts 1.2.x中編寫 .這是我的代碼的簡化版本&#xff1a;renderProduc…

Business Component(BC)和Business Object(BO)

Siebel應用架構的一個成功的地方就是在應用里引入了BC&#xff0c;BO的概念&#xff0c;從而使得幾千張關系數據表能夠按照業務的含義組織成業務對象&#xff0c;對于業務人員而言具有了業務上的含義&#xff0c;而不僅僅是從技術人員的觀點來對待數據&#xff08;就是關系表而…