首頁 資料庫 mysql教程 通过案例学调优之--和SHAREDPOOL相关的主要Latch

通过案例学调优之--和SHAREDPOOL相关的主要Latch

Jun 07, 2016 pm 02:53 PM
l 主要 案例 相關 透過

通过案例学调优之--和 SHARED POOL 相关的主要 Latch 3.1 、和 SHARED POOL 相关的主要 Latch 有: Latch: shared pool Latch: library cache 我们知道 Oracle 通过 SHARED POOL 来实现 SQL 共享,减少硬解析等。而 SQL 的相关信息,如: SQL 语句文本, SQL 执行

通过案例学调优之--和 SHARED POOL 相关的主要 Latch

3.1、和 SHARED POOL 相关的主要 Latch 有:
Latch: shared pool
Latch: library cache

我们知道 Oracle 通过 SHARED POOL 来实现 SQL 共享,减少硬解析等。而 SQL 的相关信息, 如:SQL 语句文本,SQL 执行计划等都存放在 SHARED POOL Library Cache 部分。

3.2、其中 Library Cache 的结构如下图:

wKioL1RkGtWg3qX4AAMVCoYd3pI249.jpg

      可以看到其结构和 BUFFER CACHE 类似,为了能够在 Library Cache 中快速的查找到对应的 SQL, 也是通过将不同的 SQL 语句通过 HASH 函数 HASH 后放置到对应 Hash Bucket 来保存的。 

下面看看图中***的块(右上角标注着:Object Handle):
1) 这个块也就是所谓的 Library Cache Object Handle,这个 Handle 描述 Library Cache 中对象
的一些属性,如名称(Name),所属的命名空间(Namespace)、标记(Flags)、指向对象所处的内存地址的指针(Heap 0)等。对应 SQL 来说,这个可以算是父游标。

2) Heap 0 用来存放与对象有直接关系的一些信息,比如对象类型、对象相关的表、实际的执行计划等。

3) 同一个 Hash Bucket 中的 Object Handle 相互链接形成一条 Chain
关于
Library Cache 更详细的可以查阅 Julian Dyke Library Cache Internals.ppt

Eygle 网站上也有一张简洁的图:

wKiom1RkGtzz2Kf-AAGj-k3jkoQ459.jpg

3.3下面先看SQL的的整个执行过程来,然后再看看执行过程中是怎么用到SHARED POOL的相 关 Latch

  1. 1)  当客户端执行一条 SQL,这时候 Oracle 首先将 SQL 文本转换成 ASCII 值,然后根据 HASH函数计算该 SQL 对应的 Hash Value

  2. 2)  根据得到的 Hash Value Library Cache 中查找对应的 Bucket,然后查找 Bucket 里是否存

    在该 SQL?
    (Y)
    如果存在,则接下来查找对应的子游标,这个时候将一直持有 Library Cache Latch,直到找到对应的执行计划。然后释放 Latch。(软解析)
    (N) 如果不存在,就要去 SHARE POOL 里面获得可用空间,来生生成对应的 Library Cache 对象。这个时候就要获得 Shared Pool Latch SHARE POOL Free Lis(SHRAE POOL 通过 Free List 管理 Free Chunk)查找可用的空间,之后释放 Shared Pool Latch。 接下来就开始进行硬解析过程,将执行解析后的执行计划等信息记录到 Library Cache 中,这个整个过程消耗大量的 CPU,同时将一直持有 Library Cache Latch,一 直到硬解析结束。(硬解析)

  3. 3)  根据获得的执行计划,开始执行 SQL,如:到 BUFFER CACHE 查询数据等。

3.4 整个逻辑如下如:

wKiom1RkGzzA6588AAG5zh2DItM951.jpg

3.5 当出现Latch竞争严重的时候:
3.5.1如果同时出现大量的 Share Pool Latch Library Cache Latch 的话,根据上面的逻辑那说明数 据库中存在大量的硬解析,这个时候就要查找那些 SQL 没有绑定变量。
3.5.2如果只是出现大量的 Library Cache Latch 的话,那么可能有两种情况:
1) 当持有 Library Cache Latch 查找 Bucket 对应的 Chain 时候,发现存在高 Version SQL,
这个时候就要扫描这些对应的子游标,整个过程将一直持有 Latch,导致其他会话获取不到 Latch 进行操作。

2) 大量的并发请求,而且不能实现 SQL 一次 Parse Call 多次 Execution。 


案例分析:

3.6 测试模拟为硬解析和 SQL Version Count 高的情况。
3.6.1Oracle 10g 有方法可以让 SQL 产生很多的子游标,必须具备下面几种的条件:

1)cursor_sharing = similar
2
)收集了列上的 histogram
3
)SQL 中使用到了此列作为条件,并且条件是“等于”
4)这个 SQL 是没有绑定变量的
这时候,
Oracle 会认为每条 SQL literal 变量都是 unsafe 的,因此就不重用以前的 cursor而新产生一个 version,也就会重新硬解析一次。

10:56:01 SCOTT@ prod >show parameter cursor
NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
cursor_sharing                       string      similar
cursor_space_for_time                boolean     FALSE
open_cursors                         integer     300
session_cached_cursors               integer     50

1、session1:以scott建立测试表
11:44:26 SYS@ prod >conn scott/tiger
Connected.

11:01:41 SCOTT@ prod >select * from v$mystat where rownum=1;
       SID STATISTIC#      VALUE
---------- ---------- ----------
         1          0          0
         
10:56:09 SCOTT@ prod >create table test as select rownum as col1 ,rownum col2 from user_objects
10:58:38   2  ;
Table created.

2、建立测试表直方图
10:58:51 SCOTT@ prod >exec dbms_stats.gather_table_stats(user,'TEST',method_opt=>'for columns col1 size 3');
PL/SQL procedure successfully completed.

10:59:36 SCOTT@ prod >select column_name,num_buckets,histogram from user_tab_col_statistics
11:00:43   2   where table_name='TEST';
COLUMN_NAME                    NUM_BUCKETS HISTOGRAM
------------------------------ ----------- ---------------
COL1                                     3 HEIGHT BALANCED

11:01:35 sys@ prod >ALTER SYSTem flush shared_pool;
System altered.

3、session 2:以scott建立另一个会话
11:03:44 SCOTT@ prod >select * from v$mystat where rownum=1;
       SID STATISTIC#      VALUE
---------- ---------- ----------
        44          0          0

11:04:01 SCOTT@ prod >create table test1 as select rownum as col1 ,rownum col2 from user_objects;
Table created.

11:04:36 SCOTT@ prod >exec dbms_stats.gather_table_stats(user,'TEST1',method_opt=>'for columns col1 size 3');
PL/SQL procedure successfully completed.

11:05:04 SCOTT@ prod >select column_name,num_buckets,histogram from user_tab_col_statistics
11:05:19   2  where table_name='TEST1';
COLUMN_NAME                    NUM_BUCKETS HISTOGRAM
------------------------------ ----------- ---------------
COL1                                     3 HEIGHT BALANCED

11:05:30 sys@ prod >ALTER SYSTem flush shared_pool;
System altered.

4、在session 1执行以下操作
11:02:42 SCOTT@ prod >begin
11:06:28   2  for i in 1..50000 loop
11:06:40   3  execute immediate 'select * from test where col1='||i;
11:07:08   4  end loop;
11:07:11   5  end;
11:07:13   6  /

   在session 2执行同样地操作
11:07:57 SCOTT@ prod >begin
11:08:01   2  for i in 1..50000 loop
11:08:01   3    execute immediate 'select * from test1 where col1='||i;
11:08:01   4   end loop;
11:08:01   5   end;
11:08:02   6  /

5、查看session event
11:11:36 sys@ prod > select sid,event,p1,p1text,p2,p2text from v$session where sid in (1,44)
       SID EVENT                                  P1 P1TEXT                                 P2 P2TEXT
---------- ------------------------------ ---------- ------------------------------ ---------- ------------------------------
         1 latch: shared pool              537557404 address                               293 number
        44 latch: shared pool              537557404 address                               293 number
Elapsed: 00:00:00.00
11:11:38 sys@ prod >/
       SID EVENT                                  P1 P1TEXT                                 P2 P2TEXT
---------- ------------------------------ ---------- ------------------------------ ---------- ------------------------------
         1 latch: shared pool              537557404 address                               293 number
        44 latch: row cache objects        828539960 address                               270 number
Elapsed: 00:00:00.00
11:11:39 sys@ prod >/
       SID EVENT                                  P1 P1TEXT                                 P2 P2TEXT
---------- ------------------------------ ---------- ------------------------------ ---------- ------------------------------
         1 latch: shared pool              537557404 address                               293 number
        44 latch: shared pool              537557404 address                               293 number
Elapsed: 00:00:00.00
11:11:41 sys@ prod >/
       SID EVENT                                  P1 P1TEXT                                 P2 P2TEXT
---------- ------------------------------ ---------- ------------------------------ ---------- ------------------------------
         1 latch: shared pool              537557404 address                               293 number
        44 latch: row cache objects        828007508 address                               270 number
Elapsed: 00:00:00.00
11:11:42 sys@ prod >/
       SID EVENT                                  P1 P1TEXT                                 P2 P2TEXT
---------- ------------------------------ ---------- ------------------------------ ---------- ------------------------------
         1 latch: shared pool              537557404 address                               293 number
        44 latch: shared pool              537557404 address                               293 number
11:12:32 sys@ prod >/
       SID EVENT                                  P1 P1TEXT                                 P2 P2TEXT
---------- ------------------------------ ---------- ------------------------------ ---------- ------------------------------
         1 latch free                      821793596 address                               274 number
        44 latch: shared pool              537557404 address                               293 number
 
 sys@ prod >select sid,event,p1,p1text,p2,p2text from v$session where sid in (1,44)
       SID EVENT                                  P1 P1TEXT                                 P2 P2TEXT
---------- ------------------------------ ---------- ------------------------------ ---------- ------------------------------
         1 latch: shared pool              537557404 address                               293 number
        44 library cache: mutex X         1307903034 idn                                 65536 value
11:14:58 sys@ prod >select sid,event,p1,p1text,p2,p2text from v$session where sid in (1,44)
       SID EVENT                                  P1 P1TEXT                                 P2 P2TEXT
---------- ------------------------------ ---------- ------------------------------ ---------- ------------------------------
         1 library cache: mutex X         3413592168 idn                               2883584 value
        44 latch: row cache objects        828539960 address                               270 number
11:15:18 sys@ prod >select sid,event,p1,p1text,p2,p2text from v$session where sid in (1,44)
       SID EVENT                                  P1 P1TEXT                                 P2 P2TEXT
---------- ------------------------------ ---------- ------------------------------ ---------- ------------------------------
         1 SQL*Net message from client    1650815232 driver id                               1 #bytes
        44 SQL*Net message from client    1650815232 driver id                               1 #bytes					
从上面的过程可以看到,大量的硬解析将导致严重的 library cache latch(mutex) 和 shared pool latch竞争。

6、查看Library cache中sql情况
sys@ prod >select *
  2           from (select sql_id,child_number,child_latch,executions,sql_text
  3                      from v$sql
  4                  where sql_text like '%select * from test1 where col1%'
  5                       and sql_text not like '%v$sql%'
  6                       and sql_text not like '%begin%'
  7                   order by child_number desc)
  8*      where rownum <10
SQL_ID        CHILD_NUMBER CHILD_LATCH EXECUTIONS SQL_TEXT
------------- ------------ ----------- ---------- --------------------------------------------------
6tsrjxza4gvur         1987           0          1 select * from test1 where col1=:"SYS_B_0"
6tsrjxza4gvur         1988           0          1 select * from test1 where col1=:"SYS_B_0"
6tsrjxza4gvur         1989           0          1 select * from test1 where col1=:"SYS_B_0"
6tsrjxza4gvur         1990           0          1 select * from test1 where col1=:"SYS_B_0"
6tsrjxza4gvur         1991           0          1 select * from test1 where col1=:"SYS_B_0"
6tsrjxza4gvur         1992           0          1 select * from test1 where col1=:"SYS_B_0"
6tsrjxza4gvur         1993           0          1 select * from test1 where col1=:"SYS_B_0"
6tsrjxza4gvur         1994           0          1 select * from test1 where col1=:"SYS_B_0"
6tsrjxza4gvur         1995           0          1 select * from test1 where col1=:"SYS_B_0"
6tsrjxza4gvur         1996           0          1 select * from test1 where col1=:"SYS_B_0"
6tsrjxza4gvur         1997           0          1 select * from test1 where col1=:"SYS_B_0"
6tsrjxza4gvur         1998           0          1 select * from test1 where col1=:"SYS_B_0"
6tsrjxza4gvur         1999           0          1 select * from test1 where col1=:"SYS_B_0"
6tsrjxza4gvur         2000           0          1 select * from test1 where col1=:"SYS_B_0"
6tsrjxza4gvur         2001           0          1 select * from test1 where col1=:"SYS_B_0"
6tsrjxza4gvur         2002           0          1 select * from test1 where col1=:"SYS_B_0"
6tsrjxza4gvur         2003           0          1 select * from test1 where col1=:"SYS_B_0"

11:46:50 SYS@ prod >select sql_id,hash_value,address,version_count from v$sqlarea where sql_id='6tsrjxza4gvur';
SQL_ID        HASH_VALUE ADDRESS  VERSION_COUNT
------------- ---------- -------- -------------
6tsrjxza4gvur 3561484119 2E8CF368          3885
登入後複製

可以看到 SQL Version_Count 很高,而且 V$SQL 视图里面也能查到对应的子游标。


案例分析:

模拟高并发下,对 Version Count SQL 查询:

  • session 1:

  • 11:42:41 SYS@ prod >conn scott/tiger
    Connected.
    12:05:10 SCOTT@ prod >select * from v$mystat where rownum=1;
           SID STATISTIC#      VALUE
    ---------- ---------- ----------
            38          0          0
    
    12:06:03 SCOTT@ prod >begin
    12:06:23   2  for i in 1..500000 loop
    12:06:23   3   execute immediate 'select * from test1 where col1=1';
    12:06:23   4    end loop;
    12:06:23   5    end;
    12:06:23   6   /
    PL/SQL procedure successfully completed.
    登入後複製
  • session 2:
    11:30:32 SYS@ prod >conn scott/tiger
    Connected.
    12:05:15 SCOTT@ prod >select * from v$mystat where rownum=1;
           SID STATISTIC#      VALUE
    ---------- ---------- ----------
            39          0          0
    
    12:06:11 SCOTT@ prod >begin
    12:06:29   2  for i in 1..500000 loop
    12:06:29   3   execute immediate 'select * from test1 where col1=1';
    12:06:29   4    end loop;
    12:06:29   5    end;
    12:06:29   6   /
    PL/SQL procedure successfully completed.
    登入後複製
  • 12:07:17 SYS@ prod >col event for a30
    12:07:27 SYS@ prod >col p1text for a20
    12:07:33 SYS@ prod >col p2text for a20
    12:07:38 SYS@ prod >select sid,event,p1,p1text,p2,p2text from v$session where sid in (38,39)
           SID EVENT                                  P1 P1TEXT                       P2 P2TEXT
    ---------- ------------------------------ ---------- -------------------- ---------- --------------------
            38 library cache: mutex X         3561484119 idn                     2621440 value
            39 cursor: mutex S                3561484119 idn                     2490369 value
    Elapsed: 00:00:00.00
    12:07:38 SYS@ prod >/
           SID EVENT                                  P1 P1TEXT                       P2 P2TEXT
    ---------- ------------------------------ ---------- -------------------- ---------- --------------------
            38 library cache: mutex X         3561484119 idn                     2621440 value
            39 library cache: mutex X         3561484119 idn                     2490368 value
    Elapsed: 00:00:00.00
    12:07:43 SYS@ prod >/
           SID EVENT                                  P1 P1TEXT                       P2 P2TEXT
    ---------- ------------------------------ ---------- -------------------- ---------- --------------------
            38 library cache: mutex X         3561484119 idn                     2555904 value
            39 cursor: mutex S                3561484119 idn                     2490368 value
    Elapsed: 00:00:00.00
    12:07:45 SYS@ prod >/
           SID EVENT                                  P1 P1TEXT                       P2 P2TEXT
    ---------- ------------------------------ ---------- -------------------- ---------- --------------------
            38 latch: shared pool              537557404 address                     293 number
            39 library cache: mutex X         3561484119 idn                     2490368 value
    Elapsed: 00:00:00.00
    12:07:46 SYS@ prod >/
           SID EVENT                                  P1 P1TEXT                       P2 P2TEXT
    ---------- ------------------------------ ---------- -------------------- ---------- --------------------
            38 library cache: mutex X         3561484119 idn                     2621440 value
            39 library cache: mutex X         3561484119 idn                     2621440 value
    Elapsed: 00:00:00.00
    12:07:47 SYS@ prod >/
           SID EVENT                                  P1 P1TEXT                       P2 P2TEXT
    ---------- ------------------------------ ---------- -------------------- ---------- --------------------
            38 library cache: mutex X         3561484119 idn                     2621440 value
            39 cursor: mutex S                3561484119 idn                     2490368 value
    Elapsed: 00:00:00.00
    12:07:49 SYS@ prod >/
           SID EVENT                                  P1 P1TEXT                       P2 P2TEXT
    ---------- ------------------------------ ---------- -------------------- ---------- --------------------
            38 library cache: mutex X         3561484119 idn                     2621440 value
            39 library cache: mutex X         3561484119 idn                     2621440 value
    Elapsed: 00:00:00.00
    12:07:50 SYS@ prod >/
           SID EVENT                                  P1 P1TEXT                       P2 P2TEXT
    ---------- ------------------------------ ---------- -------------------- ---------- --------------------
            38 library cache: mutex X         3561484119 idn                     2621440 value
            39 library cache: mutex X         3561484119 idn                     2490368 value
    Elapsed: 00:00:00.00
    12:07:51 SYS@ prod >/
           SID EVENT                                  P1 P1TEXT                       P2 P2TEXT
    ---------- ------------------------------ ---------- -------------------- ---------- --------------------
            38 library cache: mutex X         3561484119 idn                     2555904 value
            39 cursor: mutex S                3561484119 idn                     2490368 value
    Elapsed: 00:00:00.01
    12:08:11 SYS@ prod >/
           SID EVENT                                  P1 P1TEXT                       P2 P2TEXT
    ---------- ------------------------------ ---------- -------------------- ---------- --------------------
            38 cursor: pin S                  3561484119 idn                     2555905 value
            39 library cache: mutex X         3561484119 idn                     2490368 value
    Elapsed: 00:00:00.00
    12:08:15 SYS@ prod >/
           SID EVENT                                  P1 P1TEXT                       P2 P2TEXT
    ---------- ------------------------------ ---------- -------------------- ---------- --------------------
            38 library cache: mutex X         3561484119 idn                     2621440 value
            39 library cache: mutex X              64028 idn                     2490368 value
    12:09:04 SYS@ prod >/
           SID EVENT                                  P1 P1TEXT                       P2 P2TEXT
    ---------- ------------------------------ ---------- -------------------- ---------- --------------------
            38 cursor: mutex S                3561484119 idn                     2555904 value
            39 cursor: pin S                &n
    登入後複製
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
4 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

理想汽車L系列迎來新成員:理想L6定位中型五人座SUV 理想汽車L系列迎來新成員:理想L6定位中型五人座SUV Jul 02, 2023 pm 11:57 PM

6月30日消息,理想車旗下的L系列車型,包括L7、L8和L9,在各自的價格區間中取得了可觀的銷售成績。然而,據小編了解,理想汽車希望進一步提升銷量,焦點落在了另一款新車——理想L6的表現上。近日,一位部落客在高速服務區疑似拍到了理想L6的偽裝車。根據部落客所拍照片顯示,疑似理想L6的偽裝車並沒有正常行駛,而是停放在一輛拖車上。與旁邊的白色蔚來SUV相比,即使作為L系列中定位最低的車型,理想L6的體積也顯得相當龐大。據悉,理想L6被定位為一款中型五人座SUV。儘管這些照片未能提供太多有關外觀細節的信

常見Web標準及其實際案例解析 常見Web標準及其實際案例解析 Jan 13, 2024 pm 03:50 PM

了解常見的Web標準及其實際應用案例在當今數位化時代,萬維網已成為人們獲取資訊、進行交流和開展業務活動的重要平台。而Web標準則是確保網頁在不同瀏覽器上正常顯示並穩定運作的基礎。本文將介紹一些常見的Web標準,並透過實際應用案例來說明它們的重要性。首先,HTML(超文本標記語言)是Web標準中最基礎的一部分,用來描述網頁的結構和內容。 HTML使用標籤來定義不

解決系統重裝時的環境偵測問題 解決系統重裝時的環境偵測問題 Jan 08, 2024 pm 03:33 PM

重裝系統時環境偵測未通過如何解決需要進行改寫的原因是:手機中毒了,可以安裝手機管家等防毒軟體進行防毒軟體進行防毒2、手機內部儲存了許多垃圾文件,導致手機運作記憶體被佔用。只要清理手機快取即可解決這個問題3、手機記憶體被保存的軟體和檔案佔用太多,需要經常刪除不需要的檔案和軟體沒問題,只要你的硬體設定符合安裝要求,你可以直接使用新的系統磁碟重新安裝系統!你可以使用U盤或硬碟來進行安裝,速度非常快。但是關鍵是要使用相容性好的系統碟(支援IDE、ACHI、RAID模式的安裝),並且能夠自動永久激活,已經經過驗證的。這樣

連續四年發布物聯網案例,高通與生態夥伴共繪數實融合時代新藍圖 連續四年發布物聯網案例,高通與生態夥伴共繪數實融合時代新藍圖 Oct 13, 2023 pm 08:25 PM

在繁忙的生產線上,機械手臂高效協作,操作人員透過遠端即時控制輕鬆掌控整個流程。在礦井下,技術專家戴著AR眼鏡,透過眼鏡中即時顯示的資訊與遠在千里之外的技術團隊快速解決設備問題。在園區內,無人配送車穿梭自如,用戶足不出戶就能取到包裹。這些場景並非虛構,而是出現在高通近期發布的《2023高通賦能企業數位轉型案例集》中的真實案例高通連續四年發布了針對物聯網行業的重點發展方向和亮點落地場景的“物聯網應用案例集”,以多角度立體化展示行業最新的技術方向和創新生態合作模式。今年的案例集聚焦於中國企業利用高通物

詳細介紹Nginx伺服器的原生模組和第三方插件的整合和使用方法 詳細介紹Nginx伺服器的原生模組和第三方插件的整合和使用方法 Aug 06, 2023 pm 09:13 PM

Nginx伺服器是一款高效能的Web伺服器軟體,它的擴充性非常強大,支援原生模組和第三方插件的整合。本文將詳細介紹Nginx伺服器的原生模組和第三方外掛程式的整合和使用方法,並附上程式碼範例,以幫助讀者更好地理解和應用。一、Nginx原生模組Nginx的原生模組是指由Nginx官方開發和維護的功能模組,包括核心模組、HTTP模組、mail模組等。在Nginx的配置

在C++中,將以下內容翻譯為中文:計算在L和R之間與P互質的數字數 在C++中,將以下內容翻譯為中文:計算在L和R之間與P互質的數字數 Aug 26, 2023 pm 09:33 PM

在電腦程式設計領域,找到給定範圍內與特定數字互質的數字數量可能是常見的任務。互質數,也稱為相對質數,是指除了1以外沒有其他公因數的數字。在本文中,我們將透過使用C++語言來探討在給定整數L和R之間找到與特定數字P互質的數字數。語法我們將首先概述我們在接下來的程式碼範例中將使用的方法的語法-intcountCoprimes(intL,intR,intP);演算法我們將使用的演算法來計算互質數的數量如下所示−將變數count初始化為0,用於儲存互質數的計數。從L開始迭代每個數字num,直到R。對於每個

盤點一些Linux實用小技巧 盤點一些Linux實用小技巧 Mar 12, 2024 pm 01:49 PM

Linux是一個強大的作業系統,有許多實用的指令​​和技巧可以幫助你更有效率地使用它。 1.查看檔案校驗值在檔案複製或傳輸過程中,可能會出現損壞或修改的情況,此時可以透過校驗值來進行驗證確認。通常,我們在工作中需要使用由其他團隊提供的一些介面程式。每當這些程式的運作結果與預期不符時,我們會比對雙方的md5校驗值以確認資料的一致性。產生檔案的校驗值的方法有很多種,常用的有md5sum校驗、crc校驗、sum校驗等。指令分別為:md5sumfile_namecksumfile_namesum演算法參數file

PHP開發案例:製作一個線上問答社區 PHP開發案例:製作一個線上問答社區 Oct 27, 2023 am 11:25 AM

在網路時代的今天,越來越多的人喜歡在網路上尋找答案和交流問題。於是,各種線上問答社群應運而生。這些社群為使用者提供了一個平台,可以在這裡提問、回答問題,同時也可以互相交流經驗和知識。今天,我們將介紹一個基於PHP開發的線上問答社群的製作過程。首先,我們需要明確的是,一個線上問答社群需要具備哪些功能。通常來說,它應該包括以下幾個方面:用戶註冊、登陸、提問、回

See all articles