Apa artinya "statis" dalam C?


1138

Saya telah melihat kata yang staticdigunakan di berbagai tempat dalam kode C; apakah ini seperti fungsi / kelas statis di C # (di mana implementasi dibagikan di seluruh objek)?



15
Apa alasan untuk menghapus "dalam program C" dari akhir judul, @Lundin? Ini sedikit berlebihan di hadapan tag c , tetapi memungkinkan saya melihat kategorisasi lebih cepat, tanpa memeriksa tag. Redundansi ini sangat nyaman ketika saya mencapai pertanyaan dari arah yang mungkin juga berisi pertanyaan tentang bahasa lain, misalnya pencarian statis atau Google.
Palec

5
@Palec Ada kebijakan SO bahwa item yang ada dalam daftar tag berlebihan dalam judul. Situs akan secara otomatis menambahkan C ke situs web yang sebenarnya. Google untuk "C static" memberikan jawaban ini sebagai hit teratas. Alasan mengapa ini diubah adalah karena pertanyaan ini sekarang merupakan bagian dari FAQ bahasa SO C dan semua posting yang ditambahkan dipoles sedikit.
Lundin

1
@Lundin Saya lebih suka menyimpan "C" di judul, karena SO hanya menambahkan satu tag ke judul (yang paling umum?). Bagaimana jika suatu hari "sintaks" mencapai lebih banyak pertanyaan daripada C (karena itu adalah hal lintas bahasa)? Saya lebih suka menggunakan perilaku eksplisit :-) Edit: ah tapi ada pertanyaan meta yang mengatakan sebaliknya: meta.stackexchange.com/questions/19190/…
Ciro Santilli 郝海东 冠状 病 六四 六四 事件 法轮功

Jawaban:


1520
  1. Variabel statis di dalam fungsi menjaga nilainya di antara permintaan.
  2. Variabel global statis atau fungsi "terlihat" hanya di file yang dideklarasikan

(1) adalah topik yang lebih asing jika Anda seorang pemula, jadi inilah contohnya:

#include <stdio.h>

void foo()
{
    int a = 10;
    static int sa = 10;

    a += 5;
    sa += 5;

    printf("a = %d, sa = %d\n", a, sa);
}


int main()
{
    int i;

    for (i = 0; i < 10; ++i)
        foo();
}

Ini mencetak:

a = 15, sa = 15
a = 15, sa = 20
a = 15, sa = 25
a = 15, sa = 30
a = 15, sa = 35
a = 15, sa = 40
a = 15, sa = 45
a = 15, sa = 50
a = 15, sa = 55
a = 15, sa = 60

Ini berguna untuk kasus-kasus di mana fungsi perlu menjaga beberapa keadaan di antara permintaan, dan Anda tidak ingin menggunakan variabel global. Hati-hati, bagaimanapun, fitur ini harus digunakan dengan sangat hemat - itu membuat kode Anda tidak aman dan sulit untuk dipahami.

(2) Digunakan secara luas sebagai fitur "kontrol akses". Jika Anda memiliki file .c yang mengimplementasikan beberapa fungsi, biasanya hanya memperlihatkan beberapa fungsi "publik" kepada pengguna. Sisa dari fungsinya harus dibuat static, sehingga pengguna tidak akan dapat mengaksesnya. Ini enkapsulasi, praktik yang baik.

Mengutip Wikipedia :

Dalam bahasa pemrograman C, statis digunakan dengan variabel global dan fungsi untuk mengatur ruang lingkupnya ke file yang berisi. Dalam variabel lokal, statis digunakan untuk menyimpan variabel dalam memori yang dialokasikan secara statis alih-alih memori yang dialokasikan secara otomatis. Sementara bahasa tidak menentukan implementasi dari kedua jenis memori, memori yang dialokasikan secara statis biasanya dicadangkan di segmen data program pada waktu kompilasi, sedangkan memori yang dialokasikan secara otomatis biasanya diimplementasikan sebagai tumpukan panggilan sementara.

Dan untuk menjawab pertanyaan kedua Anda, tidak seperti di C #.

Dalam C ++, bagaimanapun, staticjuga digunakan untuk mendefinisikan atribut kelas (dibagi antara semua objek dari kelas yang sama) dan metode. Di C tidak ada kelas, jadi fitur ini tidak relevan.


179
Pax, OP tidak tahu tentang statis, jadi Anda sarankan menjebaknya ke dalam perbedaan antara unit kompilasi dan file? :-)
Eli Bendersky

138
Unit kompilasi adalah file tunggal yang dilihat oleh kompiler. File .c Anda mungkin termasuk file .c lainnya, tetapi setelah preprocessor memilah termasuk, kompiler akhirnya hanya melihat satu "unit kompilasi".
Eli Bendersky

81
@robUK: kompiler bahkan tidak tahu tentang file .h - ini digabungkan ke dalam file .c di pra-prosesor. Jadi ya Anda dapat mengatakan bahwa file .c, dengan semua header dimasukkan ke dalamnya, adalah satu unit kompilasi.
Eli Bendersky

6
@ TonyD mungkin membingungkan, tetapi cara kerjanya kompilasi. Ini biasanya satu .cdan banyak file header, tetapi iblis selalu dalam apa yang tidak khas.
peterph

7
@ TonyD Compiler melakukan kompilasi. Preprocessor melakukan preprocessing. Memanggil toolchain 'kompiler' tidak mengubah apa itu atau apa fungsinya.
Miles Rout

231

Ada satu lagi penggunaan yang tidak dibahas di sini, dan itu adalah sebagai bagian dari deklarasi tipe array sebagai argumen untuk suatu fungsi:

int someFunction(char arg[static 10])
{
    ...
}

Dalam konteks ini, ini menetapkan bahwa argumen yang diteruskan ke fungsi ini harus berupa array tipe chardengan setidaknya 10 elemen di dalamnya. Untuk info lebih lanjut lihat pertanyaan saya di sini .


3
Saya tidak berpikir C punya argumen array? Linus Torvalds marah tentang orang yang melakukan ini.
suprjami

13
@jamieb: C tidak memiliki argumen array, tapi sintaks ini berarti tertentu bahwa mengharapkan fungsi arg[0]melalui arg[9]memiliki nilai-nilai (yang juga menyiratkan bahwa fungsi tidak menerima null pointer). Kompiler dapat memanfaatkan informasi ini entah bagaimana untuk optimasi, dan analisa statis dapat memanfaatkan informasi ini untuk memastikan bahwa fungsi tidak pernah diberi pointer nol (atau jika itu bisa mengatakan, array dengan elemen lebih sedikit daripada yang ditentukan).
dreamlax

19
@Qix - Ini adalah arti kelebihan baru yang diberikan staticpada C99. Sudah lebih dari satu setengah dekade, tetapi tidak semua penulis kompiler telah menggunakan semua fitur C99 - jadi C99 secara keseluruhan sebagian besar masih belum diketahui.
Happy Green Kid Naps

@suprjami Saya tidak 100% yakin apa yang Anda maksud dengan "argumen array" , tetapi jika Anda maksud int arr[n];, maka itu adalah VLA (variabel-panjang array) , yang ditambahkan dalam C99. Apakah itu yang kamu maksud?
RastaJedi

170

Jawaban singkat ... itu tergantung.

  1. Variabel lokal yang ditentukan statis tidak kehilangan nilainya di antara panggilan fungsi. Dengan kata lain mereka adalah variabel global, tetapi mencakup fungsi lokal tempat mereka didefinisikan.

  2. Variabel global statis tidak terlihat di luar file C tempat mereka didefinisikan.

  3. Fungsi statis tidak terlihat di luar file C tempat mereka didefinisikan.


8
Jadi apakah "fungsi statis" dan "fungsi pribadi" memiliki arti yang sama? Demikian pula apakah "variabel global statis" dan "variabel global pribadi" adalah hal yang sama?
user1599964

40
Ini tentang C. Tidak ada pribadi / umum di C.
chris

19
@ user1599964 meskipun tidak ada privatedalam C, analogi Anda baik: statis membuat hal-hal "pribadi" ke file yang diberikan. Dan file dalam C sering dipetakan ke kelas di C ++.
Ciro Santilli 郝海东 冠状 病 六四 事件 法轮功

67

Contoh lingkup variabel multi-file

Di sini saya menggambarkan bagaimana statis mempengaruhi ruang lingkup definisi fungsi di beberapa file.

ac

#include <stdio.h>

/*
Undefined behavior: already defined in main.
Binutils 2.24 gives an error and refuses to link.
/programming/27667277/why-does-borland-compile-with-multiple-definitions-of-same-object-in-different-c
*/
/*int i = 0;*/

/* Works in GCC as an extension: https://stackoverflow.com/a/3692486/895245 */
/*int i;*/

/* OK: extern. Will use the one in main. */
extern int i;

/* OK: only visible to this file. */
static int si = 0;

void a() {
    i++;
    si++;
    puts("a()");
    printf("i = %d\n", i);
    printf("si = %d\n", si);
    puts("");
}

main.c

#include <stdio.h>

int i = 0;
static int si = 0;

void a();    

void m() {
    i++;
    si++;
    puts("m()");
    printf("i = %d\n", i);
    printf("si = %d\n", si);
    puts("");
}

int main() {
    m();
    m();
    a();
    a();
    return 0;
}

GitHub hulu .

Kompilasi dan jalankan:

gcc -c a.c -o a.o
gcc -c main.c -o main.o
gcc -o main main.o a.o

Keluaran:

m()
i = 1
si = 1

m()
i = 2
si = 2

a()
i = 3
si = 1

a()
i = 4
si = 2

Penafsiran

  • ada dua variabel terpisah untuk si, satu untuk setiap file
  • ada variabel tunggal yang dibagikan untuk i

Seperti biasa, semakin kecil cakupannya, semakin baik, jadi selalu deklarasikan variabel staticjika Anda bisa.

Dalam pemrograman C, file sering digunakan untuk mewakili "kelas", dan staticvariabel mewakili anggota statis kelas pribadi.

Apa standar katakan tentang itu

C99 N1256 konsep 6.7.1 " Penentu kelas penyimpanan" mengatakan bahwa itu staticadalah " penentu kelas penyimpanan".

6.2.2 / 3 "Tautan pengidentifikasi" kata staticmenyiratkan internal linkage:

Jika deklarasi pengidentifikasi lingkup file untuk objek atau fungsi berisi statis specifier kelas penyimpanan, pengidentifikasi memiliki tautan internal.

dan 6.2.2 / 2 mengatakan bahwa internal linkageberperilaku seperti pada contoh kita:

Dalam himpunan unit terjemahan dan pustaka yang merupakan keseluruhan program, setiap deklarasi pengidentifikasi tertentu dengan tautan eksternal menunjukkan objek atau fungsi yang sama. Dalam satu unit terjemahan, setiap deklarasi pengidentifikasi dengan tautan internal menunjukkan objek atau fungsi yang sama.

di mana "unit terjemahan adalah file sumber setelah preprocessing.

Bagaimana GCC mengimplementasikannya untuk ELF (Linux)?

Dengan STB_LOCALmengikat.

Jika kami kompilasi:

int i = 0;
static int si = 0;

dan bongkar tabel simbol dengan:

readelf -s main.o

output berisi:

Num:    Value          Size Type    Bind   Vis      Ndx Name
  5: 0000000000000004     4 OBJECT  LOCAL  DEFAULT    4 si
 10: 0000000000000000     4 OBJECT  GLOBAL DEFAULT    4 i

jadi pengikatan adalah satu-satunya perbedaan yang signifikan di antara mereka. Valuehanya offset mereka ke dalam .bssbagian, jadi kami perkirakan berbeda.

STB_LOCALdidokumentasikan pada spesifikasi ELF di http://www.sco.com/developers/gabi/2003-12-17/ch4.symtab.html :

STB_LOCAL Simbol lokal tidak terlihat di luar file objek yang berisi definisi mereka. Simbol lokal dengan nama yang sama mungkin ada dalam beberapa file tanpa mengganggu satu sama lain

yang membuatnya menjadi pilihan yang tepat untuk diwakili static.

Variabel tanpa statis adalah STB_GLOBAL, dan spesifikasi mengatakan:

Ketika editor tautan menggabungkan beberapa file objek yang dapat dipindahkan, itu tidak memungkinkan beberapa definisi simbol STB_GLOBAL dengan nama yang sama.

yang koheren dengan kesalahan tautan pada beberapa definisi non statis.

Jika kita menghidupkan optimasi dengan -O3, sisimbol dihapus seluruhnya dari tabel simbol: itu tidak dapat digunakan dari luar. TODO mengapa menyimpan variabel statis di tabel simbol sama sekali ketika tidak ada optimasi? Bisakah mereka digunakan untuk apa saja? Mungkin untuk debugging.

Lihat juga

C ++ ruang nama anonim

Dalam C ++, Anda mungkin ingin menggunakan ruang nama anonim alih-alih statis, yang mencapai efek yang serupa, tetapi lebih lanjut menyembunyikan definisi tipe: Ruang nama tidak bernama / anonim vs. fungsi statis


39

Tergantung:

int foo()
{
   static int x;
   return ++x;
}

Fungsi akan mengembalikan 1, 2, 3, dll --- variabel tidak pada stack.

ac:

static int foo()
{
}

Ini berarti bahwa fungsi ini hanya memiliki ruang lingkup di file ini. Jadi ac dan bc dapat memiliki foo()s yang berbeda , dan foo tidak terkena objek yang dibagikan. Jadi, jika Anda mendefinisikan foo in ac, Anda tidak dapat mengaksesnya dari b.catau dari tempat lain.

Di sebagian besar pustaka C semua fungsi "pribadi" bersifat statis dan sebagian besar "publik" tidak.


18
+1 untuk menyebutkan x tidak pada tumpukan atau tumpukan. Ada di ruang memori statis.
Gob00st

1
@ Ruang memori statis Gob00st? Anda berarti "Segmen Data" ...?
Yousha Aleayoub

24

Orang-orang terus mengatakan bahwa 'statis' dalam C memiliki dua arti. Saya menawarkan cara lain untuk melihatnya yang memberikan makna tunggal:

  • Menerapkan 'statis' pada suatu item memaksa item tersebut memiliki dua properti: (a) Tidak terlihat di luar cakupan saat ini; (B) Ini gigih.

Alasan yang tampaknya memiliki dua arti adalah bahwa, dalam C, setiap item yang 'statis' dapat diterapkan sudah memiliki salah satu dari dua properti ini , jadi sepertinya penggunaan tertentu itu hanya melibatkan yang lain.

Misalnya, pertimbangkan variabel. Variabel yang dideklarasikan di luar fungsi sudah memiliki kegigihan (di segmen data), jadi menerapkan 'statis' hanya dapat membuatnya tidak terlihat di luar lingkup saat ini (unit kompilasi). Sebaliknya, variabel yang dideklarasikan di dalam fungsi sudah memiliki non-visibilitas di luar lingkup saat ini (fungsi), sehingga penerapan 'statis' hanya dapat membuatnya tetap ada.

Menerapkan 'statis' ke fungsi sama seperti menerapkannya ke variabel global - kode harus persisten (setidaknya dalam bahasa), jadi hanya visibilitas yang dapat diubah.

CATATAN: Komentar ini hanya berlaku untuk C. Dalam C ++, menerapkan metode 'statis' ke kelas benar-benar memberikan arti berbeda pada kata kunci. Demikian pula untuk ekstensi argumen-array C99.


(A) Anda mubazir. Tidak ada variabel apa pun yang terlihat di luar cakupannya. Itu hanya definisi ruang lingkup. Yang Anda maksud adalah tautan dalam Standar C. staticmemberikan tautan internal ke pengidentifikasi.
Jens

16

Dari Wikipedia:

Dalam bahasa pemrograman C, statis digunakan dengan variabel global dan fungsi untuk mengatur ruang lingkupnya ke file yang berisi. Dalam variabel lokal, statis digunakan untuk menyimpan variabel dalam memori yang dialokasikan secara statis alih-alih memori yang dialokasikan secara otomatis. Sementara bahasa tidak menentukan implementasi dari kedua jenis memori, memori yang dialokasikan secara statis biasanya dicadangkan di segmen data program pada waktu kompilasi, sedangkan memori yang dialokasikan secara otomatis biasanya diimplementasikan sebagai tumpukan panggilan sementara.


16

static berarti berbagai hal dalam konteks yang berbeda.

  1. Anda dapat mendeklarasikan variabel statis dalam fungsi C. Variabel ini hanya terlihat dalam fungsinya namun berperilaku seperti global karena hanya diinisialisasi satu kali dan mempertahankan nilainya. Dalam contoh ini, setiap kali Anda memanggilnya foo()akan mencetak semakin banyak. Variabel statis diinisialisasi hanya sekali.

    void foo ()
    {
    static int i = 0;
    printf("%d", i); i++
    }
  2. Penggunaan statis lainnya adalah ketika Anda mengimplementasikan suatu fungsi atau variabel global dalam file .c tetapi tidak ingin simbolnya terlihat di luar yang .objdihasilkan oleh file tersebut. misalnya

    static void foo() { ... }

8

Jika Anda mendeklarasikan variabel dalam fungsi statis, nilainya tidak akan disimpan di tumpukan panggilan fungsi dan masih akan tersedia saat Anda memanggil fungsi lagi.

Jika Anda mendeklarasikan variabel global statis, cakupannya akan dibatasi dalam file yang Anda nyatakan. Ini sedikit lebih aman daripada global biasa yang dapat dibaca dan dimodifikasi di seluruh program Anda.


8

Saya benci menjawab pertanyaan lama, tetapi saya rasa tidak ada yang menyebutkan bagaimana K&R menjelaskannya di bagian A4.1 dari "Bahasa Pemrograman C".

Singkatnya, kata statis digunakan dengan dua makna:

  1. Statis adalah salah satu dari dua kelas penyimpanan (yang lainnya otomatis). Objek statis menjaga nilainya di antara doa. Objek yang dinyatakan di luar semua blok selalu statis dan tidak dapat dibuat otomatis.
  2. Tetapi, ketika static kata kunci (penekanan besar pada itu digunakan dalam kode sebagai kata kunci) digunakan dengan deklarasi, itu memberi tautan internal objek sehingga hanya dapat digunakan dalam unit terjemahan itu. Tetapi jika kata kunci digunakan dalam suatu fungsi, itu mengubah kelas penyimpanan objek (objek itu hanya akan terlihat dalam fungsi itu). Kebalikan dari statis adalah externkata kunci, yang memberikan objek hubungan eksternal.

Peter Van Der Linden memberikan dua arti ini dalam "Pemrograman C Ahli":

  • Di dalam suatu fungsi, pertahankan nilainya di antara panggilan.
  • Di tingkat fungsi, hanya terlihat di file ini.

Ada kelas penyimpanan ketiga, daftar . Beberapa orang juga membuat kasing untuk kelas penyimpanan keempat, yang dialokasikan , untuk penyimpanan yang dikembalikan oleh malloc dan teman-teman.
Jens

@Jens 'register' hanyalah petunjuk bagi kompiler; penyimpanan register tidak dapat dipaksakan dari dalam sumber C. Jadi saya tidak akan menganggapnya sebagai kelas penyimpanan.
GermanNerd

1
@GermanNerd aku takut tidak setuju ISO C Standard dengan pandangan Anda, karena jelas membuat registersebuah specifier penyimpanan kelas (C99 6.7.1 specifier penyimpanan kelas). Dan itu lebih dari sekadar petunjuk, misalnya Anda tidak dapat menerapkan alamat-operator &pada objek dengan kelas penyimpanan registerterlepas dari apakah kompiler mengalokasikan register atau tidak.
Jens

@ Jean Terima kasih telah mengingatkan saya tentang &. Saya mungkin telah melakukan terlalu banyak C ++ ..... Bagaimanapun, ketika 'register' adalah specifier kelas penyimpanan, pada kenyataannya kompiler kemungkinan akan membuat kode mesin yang sama untuk specifier 'otomatis' (tidak berguna) seperti untuk 'register' 'specifier. Jadi satu-satunya yang tersisa adalah pembatasan level kode sumber tidak bisa mengambil alamat. BTW, diskusi kecil ini membuat saya menemukan bug di Netbeans; sejak pembaruan terakhir saya, ini default ke rantai alat g ++ pada proyek C baru!
GermanNerd

6

Dalam C, statis memiliki dua arti, tergantung pada ruang lingkup penggunaannya. Dalam lingkup global, ketika suatu objek dideklarasikan pada level file, itu berarti objek itu hanya terlihat di dalam file itu.

Pada lingkup lain apa pun itu menyatakan objek yang akan mempertahankan nilainya antara waktu yang berbeda bahwa ruang lingkup tertentu dimasukkan. Misalnya, jika sebuah int dibuat dalam prosedur:

void procedure(void)
{
   static int i = 0;

   i++;
}

nilai 'i' diinisialisasi ke nol pada panggilan pertama ke prosedur, dan nilai dipertahankan setiap kali prosedur disebut. jika 'i' dicetak maka akan menghasilkan urutan 0, 1, 2, 3, ...


5

Penting untuk dicatat bahwa variabel statis dalam fungsi dapat diinisialisasi pada entri pertama ke dalam fungsi itu dan tetap ada bahkan setelah panggilan mereka selesai; dalam hal fungsi rekursif, variabel statis hanya diinisialisasi satu kali dan tetap ada di atas semua panggilan rekursif dan bahkan setelah panggilan fungsi selesai.

Jika variabel telah dibuat di luar fungsi, itu berarti bahwa pemrogram hanya dapat menggunakan variabel dalam file sumber yang telah dideklarasikan.


5

Jika Anda mendeklarasikan ini dalam mytest.cfile:

static int my_variable;

Maka variabel ini hanya bisa dilihat dari file ini. Variabel tidak dapat diekspor ke tempat lain.

Jika Anda mendeklarasikan di dalam fungsi, nilai variabel akan mempertahankan nilainya setiap kali fungsi dipanggil.

Fungsi statis tidak dapat diekspor dari luar file. Jadi dalam sebuah *.cfile, Anda menyembunyikan fungsi dan variabel jika Anda menyatakannya statis.


4

Variabel statis dalam C memiliki masa pakai program.

Jika didefinisikan dalam suatu fungsi, mereka memiliki cakupan lokal, yaitu mereka hanya dapat diakses di dalam fungsi-fungsi tersebut. Nilai variabel statis dipertahankan antara panggilan fungsi.

Sebagai contoh:

void function()
{
    static int var = 1;
    var++;
    printf("%d", var);
}

int main()
{
    function(); // Call 1
    function(); // Call 2
}

Dalam program di atas, vardisimpan di segmen data. Masa hidupnya adalah keseluruhan program C.

Setelah panggilan fungsi 1, varmenjadi 2. Setelah panggilan fungsi 2, varmenjadi 3.

Nilai vartidak dihancurkan antara fungsi panggilan.

Jika varmemiliki antara variabel non-statis dan lokal, itu akan disimpan dalam segmen stack dalam program C. Karena susunan bingkai fungsi dihancurkan setelah fungsi kembali, nilai varjuga dihancurkan.

Variabel statis yang diinisialisasi disimpan dalam segmen data dari program C sedangkan variabel yang tidak diinisialisasi disimpan dalam segmen BSS.

Informasi lain tentang statis: Jika suatu variabel bersifat global dan statis, ia memiliki masa pakai program C, tetapi memiliki cakupan file. Itu hanya terlihat di file itu.

Untuk mencoba ini:

file1.c

static int x;

int main()
{
    printf("Accessing in same file%d", x):
}

file2.c

    extern int x;
    func()
    {
        printf("accessing in different file %d",x); // Not allowed, x has the file scope of file1.c
    }

run gcc -c file1.c

gcc -c file2.c

Sekarang coba tautkan mereka menggunakan:

gcc -o output file1.o file2.o

Itu akan memberikan kesalahan linker karena x memiliki lingkup file file1.c dan linker tidak akan dapat menyelesaikan referensi ke variabel x yang digunakan dalam file2.c.

Referensi:

  1. http://en.wikipedia.org/wiki/Translation_unit_(programming)
  2. http://en.wikipedia.org/wiki/Call_stack

Saya mengerti bahwa data ini persisten, artinya tidak akan hilang setelah setiap panggilan fungsi, tetapi mengapa tidak static int var = 1;mengubah nilai kembali ke masing-masing kali
Eames

3

Variabel statis adalah variabel khusus yang dapat Anda gunakan dalam suatu fungsi, dan itu menyimpan data di antara panggilan, dan itu tidak menghapusnya di antara panggilan. Sebagai contoh:

void func(){
    static int count; // If you don't declare its value, the value automatically initializes to zero
    printf("%d, ", count);
    ++count;
}

void main(){
    while(true){
        func();
    }
}

Hasil:

0, 1, 2, 3, 4, 5, ...


Anda dapat mengganti printf("%d, ", count); count++;dengan `printf ("% d, ", hitung ++) (tidak penting: P).
RastaJedi

2

Nilai variabel statis tetap ada di antara berbagai fungsi panggilan dan cakupannya terbatas pada blok lokal yang selalu diinisialisasi dengan nilai statis 0


2

Ada 2 kasus:

(1) Variabel lokal yang dideklarasikan static: Dialokasikan dalam segmen data alih-alih tumpukan. Nilainya tetap dipertahankan saat Anda memanggil fungsi lagi.

(2) Variabel atau fungsi global yang dideklarasikan static: Unit kompilasi luar yang tak terlihat (yaitu simbol lokal dalam tabel simbol selama penautan).


1

Variabel statis memiliki properti untuk mempertahankan nilainya bahkan setelah mereka berada di luar ruang lingkupnya! Oleh karena itu, variabel statis mempertahankan nilai sebelumnya dalam ruang lingkup sebelumnya dan tidak diinisialisasi lagi dalam ruang lingkup baru.

Lihat ini misalnya - variabel int statis tetap ada dalam memori saat program sedang berjalan. Variabel normal atau otomatis dihancurkan ketika fungsi memanggil tempat variabel itu dinyatakan selesai.

#include<stdio.h> 
int fun() 
{ 
  static int count = 0; 
  count++; 
  return count; 
} 

int main() 
{ 
  printf("%d ", fun()); 
  printf("%d ", fun()); 
  return 0; 
}

Ini akan menampilkan: 1 2

Seperti 1 tetap dalam memori seperti yang dinyatakan statis

Variabel statis (seperti variabel global) diinisialisasi sebagai 0 jika tidak diinisialisasi secara eksplisit. Misalnya dalam program di bawah ini, nilai x dicetak sebagai 0, sedangkan nilai y adalah sesuatu yang sampah. Lihat ini untuk lebih jelasnya.

#include <stdio.h> 
int main() 
{ 
    static int x; 
    int y; 
    printf("%d \n %d", x, y); 
}

Ini akan menampilkan: 0 [some_garbage_value]

Ini adalah yang utama yang saya temukan yang tidak dijelaskan di atas untuk pemula!


-1

Dalam pemrograman C, staticadalah kata kunci khusus yang mengontrol masa pakai dan visibilitas. Jika kita mendeklarasikan variabel sebagai statis di dalam suatu fungsi maka itu hanya akan terlihat di seluruh fungsi itu. Dalam penggunaan ini, masa pakai variabel statis ini akan mulai ketika fungsi memanggil dan akan dimusnahkan setelah eksekusi fungsi itu. Anda dapat melihat contoh berikut:

#include<stdio.h> 
int counterFunction() 
{ 
  static int count = 0; 
  count++; 
  return count; 
} 

int main() 
{ 
  printf("First Counter Output = %d\n", counterFunction()); 
  printf("Second Counter Output = %d ", counterFunction()); 
  return 0; 
}

Program di atas akan memberi kami Output ini:

First Counter Output = 1 
Second Counter Output = 1 

Karena begitu kita memanggil fungsi itu akan menginisialisasi count = 0. Dan sementara kita mengeksekusi counterFunctionitu akan menghancurkan variabel count.


2
> Program di atas akan memberi kita Output ini: Counter Pertama Output = 1 Counter Kedua Output = 1 <Tidak benar. Variabel statis dapat diinisialisasi hanya sekali. Jadi outputnya adalah 1, kemudian 2, dan seterusnya.
GermanNerd
Dengan menggunakan situs kami, Anda mengakui telah membaca dan memahami Kebijakan Cookie dan Kebijakan Privasi kami.
Licensed under cc by-sa 3.0 with attribution required.