float和real資料型別的區別

2021-07-27 11:21:33 字數 2967 閱讀 7548

1樓:匿名使用者

一、主體不同

1、float:浮點型資料型別。

2、real:資料型別用於儲存單精度浮點數。

二、儲存資料不同

1、float:資料型別用於儲存單精度浮點數或雙精度浮點數。

2、real:資料型別儲存單精度浮點數。它是一種近似數字資料型別,在算術運算後容易產生舍入誤差。

三、表示範圍不同

1、float: float 型別提供了一個大約在 -3.4e+38 ~ 3.4e+38 之間的範圍。

2、real:取值範圍是 -3.402823e+38 到 3.402823e+38,最趨近於零的數為 1.175494351e-38。

2樓:

float(n) 所在範圍 精度 儲存大小

1-24 7 位數 4 位元組

25-53 15 位數 8 位元組

real=float(24)

numberic(p,s) - 10^38 +1 到 10^38 - 1

float 和 real 資料

float 和 real 資料型別被稱為近似的資料型別。在近似數字資料型別方面,float 和 real 資料的使用遵循 ieee 754 標準。

近似數字資料型別並不儲存為多數數字指定的精確值,它們只儲存這些值的最近似值。在很多應用程式中,指定值與儲存值之間的微小差異並不明顯。但有時這些差異也值得引起注意。

由於 float 和 real 資料型別的這種近似性,當要求精確的數字狀態時,比如在財務應用程式中,在那些需要舍入的操作中,或在等值核對的操作中,就不使用這些資料型別。這時就要用 integer、decimal、money 或 smallmone 資料型別。

在 where 子句搜尋條件中(特別是 = 和 <> 運算子),應避免使用 float 或 real 列。最好限制使用 float 和 real 列做 > 或 < 的比較。

ieee 754 規格提供了四種舍入模式:舍入到最接近的值、上舍入、下舍入和舍入到零。microsoft® sql server™ 使用上舍入。

所有的數值必須精確到確定的精度,但會產生細小的浮點值變化。因為浮點數字的二進位制表示法可以採用很多合法舍入規則中的任意一條,因此我們不可能可靠地量化一個浮點值。

ab的plc中,這些資料型別:int、dint、sint、real和bool,分別代表什麼意思?

3樓:本少獨行

1、int 16位整型 其值域為 -32768~+32767。

2、dint 32位整型 其值域為 -2147483648~+2147483647。

3、sint 8位整型 其值域為 -128~+127。

4、real 實型 其值域為-2的128次方~2的128次方。

5、bool 布林型 其值域為0或1。

擴充套件資料:

工作原理

掃描技術

當plc控制器投入執行後,其工作過程一般分為三個階段,即輸入取樣、使用者程式執行和輸出重新整理三個階段。完成上述三個階段稱作一個掃描週期。在整個執行期間,plc控制器的cpu以一定的掃描速度重複執行上述三個階段。

輸入取樣階段

在輸入取樣階段,plc控制器以掃描方式依次地讀入所有輸入狀態和資料,並將它們存入i/o映象區中的相應得單元內。輸入取樣結束後,轉入使用者程式執行和輸出重新整理階段。

在這兩個階段中,即使輸入狀態和資料發生變化,i/o映象區中的相應單元的狀態和資料也不會改變。因此,如果輸入是脈衝訊號,則該脈衝訊號的寬度必須大於一個掃描週期,才能保證在任何情況下,該輸入均能被讀入。

使用者程式執行階段

在使用者程式執行階段,plc控制器總是按由上而下的順序依次地掃描使用者程式(梯形圖)。在掃描每一條梯形圖時,又總是先掃描梯形圖左邊的由各觸點構成的控制線路,並按先左後右、先上後下的順序對由觸點構成的控制線路進行邏輯運算。

然後根據邏輯運算的結果,重新整理該邏輯線圈在系統ram儲存區中對應位的狀態;或者重新整理該輸出線圈在i/o映象區中對應位的狀態;或者確定是否要執行該梯形圖所規定的特殊功能指令。

即,在使用者程式執行過程中,只有輸入點在i/o映象區內的狀態和資料不會發生變化,而其他輸出點和軟裝置在i/o映象區或系統ram儲存區內的狀態和資料都有可能發生變化,而且排在上面的梯形圖。

其程式執行結果會對排在下面的凡是用到這些線圈或資料的梯形圖起作用;相反,排在下面的梯形圖,其被重新整理的邏輯線圈的狀態或資料只能到下一個掃描週期才能對排在其上面的程式起作用。

輸出重新整理階段

當掃描使用者程式結束後,plc控制器就進入輸出重新整理階段。在此期間,cpu按照i/o映象區內對應的狀態和資料重新整理所有的輸出鎖存電路,再經輸出電路驅動相應的外設。這時,才是plc控制器的真正輸出。

同樣的若干條梯形圖,其排列次序不同,執行的結果也不同。另外,採用掃描使用者程式的執行結果與繼電器控制裝置的硬邏輯並行執行的結果有所區別。當然,如果掃描週期所佔用的時間對整個執行來說可以忽略,那麼二者之間就沒有什麼區別了。

一般來說,plc控制器的掃描週期包括自診斷、通訊等,如下圖所示,即一個掃描週期等於自診斷、通訊、輸入取樣、使用者程式執行、輸出重新整理等所有時間的總和。

4樓:歲月不及你動人

資料縮寫代表的意思分別如下:

int    16位整型

其值域為  -32768~+32767

2. dint  32位整型   其值域為   -2147483648~+2147483647

3. sint  8位整型     其值域為   -128~+1274. real  實型     其值域為-2的128次方~2的128次方

5. bool 布林型   其值域為0或1plc就是可程式設計邏輯控制器,是種專門為在工業環境下應用而設計的數字運算操作電子系統。它採用一種可程式設計的儲存器,在其內部儲存執行邏輯運算、順序控制、定時、計數和算術運算等操作的指令,通過數字式或模擬式的輸入輸出來控制各種型別的機械裝置或生產過程。

C語言不同資料型別怎麼轉換成同一資料型別的

大概有三種bai 情況 1.表示式du中有幾種可計算zhi 型別時,自動向dao 高 看齊,即自動把位數回少的型別通答過填加無效0而達到表示式中位數最多的型別,計算結果也是 高 型別。這種轉換不需程式設計師干預,也不損失資料。2.通過賦值自動轉換,即自動將右邊表示式計算結果的型別轉換為表示式左邊變數...

oracle所有的資料型別有哪些

oracle資料庫的核心是表,表中的列使用到的常見資料型別如下 對應number型別的示例 對於日期型別,可以使用sysdate內建函式可以獲取當前的系統日期和時間,返回date型別,用systimestamp函式可以返回當前日期 時間和時區。oracle支援的資料型別有哪些 oracle 所有的資...

資料庫與C的資料型別轉換,C 與資料庫型別之間的轉換知多少

應該不存在這種事情 在資料庫裡表示字串型別用的就是 varchar,nvarchar,char nchar等等 而c 裡沒有這種型別,與他向替代的是string型別,如果出錯了,應該不會在這邊,你好好檢查一下其他型別呢 怎麼不匹配,我用過可以匹配的啊,具體東西帖出來看看 是不是有一種方式是 變數名....