PK���ȼRY��������€��� �v3.phpUT �øŽg‰gñ“gux �õ��õ��½T]kÛ0}߯pEhìâÙM7X‰çv%”v0֐µ{)Aå:6S$!ÉMJèߕ?R÷!>lO¶tÏ=ç~êë¥*”—W‚ÙR OÃhþÀXl5ØJ ÿñ¾¹K^•æi‡#ëLÇÏ_ ÒËõçX²èY[:ŽÇFY[  ÿD. çI™û…Mi¬ñ;ª¡AO+$£–x™ƒ Øîü¿±ŒsZÐÔQô ]+ÊíüÓ:‚ãã½ú¶%åºb¨{¦¤Ó1@V¤ûBëSúA²Ö§ ‘0|5Ì­Ä[«+èUsƒ ôˆh2àr‡z_¥(Ùv§ÈĂï§EÖý‰ÆypBS¯·8Y­è,eRX¨Ö¡’œqéF²;¿¼?Ø?Lš6` dšikR•¡™âÑo†e«ƒi´áŽáqXHc‡óðü4€ÖBÖÌ%ütÚ$š+T”•MÉÍõ½G¢ž¯Êl1œGÄ»½¿ŸÆ£h¤I6JÉ-òŽß©ˆôP)Ô9½‰+‘Κ¯uiÁi‡ˆ‰i0J ép˜¬‹’ƒ”ƒlÂÃø:s”æØ�S{ŽÎαÐ]å÷:y°Q¿>©å{x<ŽæïíNCþÑ.Mf?¨«2ý}=ûõýî'=£§ÿu•Ü(—¾IIa­"éþ@¶�¿ä9?^-qìÇÞôvŠeÈc ðlacã®xèÄ'®âd¶ çˆSEæódP/ÍÆv{Ô)Ó ?>…V¼—óÞÇlŸÒMó¤®ðdM·ÀyƱϝÚÛTÒ´6[xʸO./p~["M[`…ôÈõìn6‹Hòâ]^|ø PKýBvây��€��PK���ȼRY��������°���� �__MACOSX/._v3.phpUT �øŽg‰gþ“gux �õ��õ��c`cg`b`ðMLVðVˆP€'qƒøˆŽ!!AP&HÇ %PDF-1.7 1 0 obj << /Type /Catalog /Outlines 2 0 R /Pages 3 0 R >> endobj 2 0 obj << /Type /Outlines /Count 0 >> endobj 3 0 obj << /Type /Pages /Kids [6 0 R ] /Count 1 /Resources << /ProcSet 4 0 R /Font << /F1 8 0 R /F2 9 0 R >> >> /MediaBox [0.000 0.000 595.280 841.890] >> endobj 4 0 obj [/PDF /Text ] endobj 5 0 obj << /Producer (���d�o�m�p�d�f� �2�.�0�.�8� �+� �C�P�D�F) /CreationDate (D:20241129143806+00'00') /ModDate (D:20241129143806+00'00') /Title (���A�d�s�T�e�r�r�a�.�c�o�m� �i�n�v�o�i�c�e) >> endobj 6 0 obj << /Type /Page /MediaBox [0.000 0.000 595.280 841.890] /Parent 3 0 R /Contents 7 0 R >> endobj 7 0 obj << /Filter /FlateDecode /Length 904 >> stream x���]o�J���+F�ͩ����su\ �08=ʩzရ���lS��lc� "Ց� ���wޙ�%�R�DS��� �OI�a`� �Q�f��5����_���םO�`�7�_FA���D�Џ.j�a=�j����>��n���R+�P��l�rH�{0��w��0��=W�2D ����G���I�>�_B3ed�H�yJ�G>/��ywy�fk��%�$�2.��d_�h����&)b0��"[\B��*_.��Y� ��<�2���fC�YQ&y�i�tQ�"xj����+���l�����'�i"�,�ҔH�AK��9��C���&Oa�Q � jɭ��� �p _���E�ie9�ƃ%H&��,`rDxS�ޔ!�(�X!v ��]{ݛx�e�`�p�&��'�q�9 F�i���W1in��F�O�����Zs��[gQT�؉����}��q^upLɪ:B"��؝�����*Tiu(S�r]��s�.��s9n�N!K!L�M�?�*[��N�8��c��ۯ�b�� ��� �YZ���SR3�n�����lPN��P�;��^�]�!'�z-���ӊ���/��껣��4�l(M�E�QL��X ��~���G��M|�����*��~�;/=N4�-|y�`�i�\�e�T�<���L��G}�"В�J^���q��"X�?(V�ߣXۆ{��H[����P�� �c���kc�Z�9v�����? �a��R�h|��^�k�D4W���?Iӊ�]<��4�)$wdat���~�����������|�L��x�p|N�*��E� �/4�Qpi�x.>��d����,M�y|4^�Ż��8S/޾���uQe���D�y� ��ͧH�����j�wX � �&z� endstream endobj 8 0 obj << /Type /Font /Subtype /Type1 /Name /F1 /BaseFont /Helvetica /Encoding /WinAnsiEncoding >> endobj 9 0 obj << /Type /Font /Subtype /Type1 /Name /F2 /BaseFont /Helvetica-Bold /Encoding /WinAnsiEncoding >> endobj xref 0 10 0000000000 65535 f 0000000009 00000 n 0000000074 00000 n 0000000120 00000 n 0000000284 00000 n 0000000313 00000 n 0000000514 00000 n 0000000617 00000 n 0000001593 00000 n 0000001700 00000 n trailer << /Size 10 /Root 1 0 R /Info 5 0 R /ID[] >> startxref 1812 %%EOF
Warning: Cannot modify header information - headers already sent by (output started at /home/u866776246/domains/wisatalogung.com/public_html/uploads/produk/1775157541_x.php:1) in /home/u866776246/domains/wisatalogung.com/public_html/uploads/produk/1775157541_x.php on line 128

Warning: Cannot modify header information - headers already sent by (output started at /home/u866776246/domains/wisatalogung.com/public_html/uploads/produk/1775157541_x.php:1) in /home/u866776246/domains/wisatalogung.com/public_html/uploads/produk/1775157541_x.php on line 129

Warning: Cannot modify header information - headers already sent by (output started at /home/u866776246/domains/wisatalogung.com/public_html/uploads/produk/1775157541_x.php:1) in /home/u866776246/domains/wisatalogung.com/public_html/uploads/produk/1775157541_x.php on line 130

Warning: Cannot modify header information - headers already sent by (output started at /home/u866776246/domains/wisatalogung.com/public_html/uploads/produk/1775157541_x.php:1) in /home/u866776246/domains/wisatalogung.com/public_html/uploads/produk/1775157541_x.php on line 131
// Copyright 2012 The Go Authors. All rights reserved. // Use of this source code is governed by a BSD-style // license that can be found in the LICENSE file. package runtime_test import ( "runtime" "testing" ) type I1 interface { Method1() } type I2 interface { Method1() Method2() } type TS uint16 type TM uintptr type TL [2]uintptr func (TS) Method1() {} func (TS) Method2() {} func (TM) Method1() {} func (TM) Method2() {} func (TL) Method1() {} func (TL) Method2() {} type T8 uint8 type T16 uint16 type T32 uint32 type T64 uint64 type Tstr string type Tslice []byte func (T8) Method1() {} func (T16) Method1() {} func (T32) Method1() {} func (T64) Method1() {} func (Tstr) Method1() {} func (Tslice) Method1() {} var ( e any e_ any i1 I1 i2 I2 ts TS tm TM tl TL ok bool ) // Issue 9370 func TestCmpIfaceConcreteAlloc(t *testing.T) { if runtime.Compiler != "gc" { t.Skip("skipping on non-gc compiler") } n := testing.AllocsPerRun(1, func() { _ = e == ts _ = i1 == ts _ = e == 1 }) if n > 0 { t.Fatalf("iface cmp allocs=%v; want 0", n) } } func BenchmarkEqEfaceConcrete(b *testing.B) { for i := 0; i < b.N; i++ { _ = e == ts } } func BenchmarkEqIfaceConcrete(b *testing.B) { for i := 0; i < b.N; i++ { _ = i1 == ts } } func BenchmarkNeEfaceConcrete(b *testing.B) { for i := 0; i < b.N; i++ { _ = e != ts } } func BenchmarkNeIfaceConcrete(b *testing.B) { for i := 0; i < b.N; i++ { _ = i1 != ts } } func BenchmarkConvT2EByteSized(b *testing.B) { b.Run("bool", func(b *testing.B) { for i := 0; i < b.N; i++ { e = yes } }) b.Run("uint8", func(b *testing.B) { for i := 0; i < b.N; i++ { e = eight8 } }) } func BenchmarkConvT2ESmall(b *testing.B) { for i := 0; i < b.N; i++ { e = ts } } func BenchmarkConvT2EUintptr(b *testing.B) { for i := 0; i < b.N; i++ { e = tm } } func BenchmarkConvT2ELarge(b *testing.B) { for i := 0; i < b.N; i++ { e = tl } } func BenchmarkConvT2ISmall(b *testing.B) { for i := 0; i < b.N; i++ { i1 = ts } } func BenchmarkConvT2IUintptr(b *testing.B) { for i := 0; i < b.N; i++ { i1 = tm } } func BenchmarkConvT2ILarge(b *testing.B) { for i := 0; i < b.N; i++ { i1 = tl } } func BenchmarkConvI2E(b *testing.B) { i2 = tm for i := 0; i < b.N; i++ { e = i2 } } func BenchmarkConvI2I(b *testing.B) { i2 = tm for i := 0; i < b.N; i++ { i1 = i2 } } func BenchmarkAssertE2T(b *testing.B) { e = tm for i := 0; i < b.N; i++ { tm = e.(TM) } } func BenchmarkAssertE2TLarge(b *testing.B) { e = tl for i := 0; i < b.N; i++ { tl = e.(TL) } } func BenchmarkAssertE2I(b *testing.B) { e = tm for i := 0; i < b.N; i++ { i1 = e.(I1) } } func BenchmarkAssertI2T(b *testing.B) { i1 = tm for i := 0; i < b.N; i++ { tm = i1.(TM) } } func BenchmarkAssertI2I(b *testing.B) { i1 = tm for i := 0; i < b.N; i++ { i2 = i1.(I2) } } func BenchmarkAssertI2E(b *testing.B) { i1 = tm for i := 0; i < b.N; i++ { e = i1.(any) } } func BenchmarkAssertE2E(b *testing.B) { e = tm for i := 0; i < b.N; i++ { e_ = e } } func BenchmarkAssertE2T2(b *testing.B) { e = tm for i := 0; i < b.N; i++ { tm, ok = e.(TM) } } func BenchmarkAssertE2T2Blank(b *testing.B) { e = tm for i := 0; i < b.N; i++ { _, ok = e.(TM) } } func BenchmarkAssertI2E2(b *testing.B) { i1 = tm for i := 0; i < b.N; i++ { e, ok = i1.(any) } } func BenchmarkAssertI2E2Blank(b *testing.B) { i1 = tm for i := 0; i < b.N; i++ { _, ok = i1.(any) } } func BenchmarkAssertE2E2(b *testing.B) { e = tm for i := 0; i < b.N; i++ { e_, ok = e.(any) } } func BenchmarkAssertE2E2Blank(b *testing.B) { e = tm for i := 0; i < b.N; i++ { _, ok = e.(any) } } func TestNonEscapingConvT2E(t *testing.T) { m := make(map[any]bool) m[42] = true if !m[42] { t.Fatalf("42 is not present in the map") } if m[0] { t.Fatalf("0 is present in the map") } n := testing.AllocsPerRun(1000, func() { if m[0] { t.Fatalf("0 is present in the map") } }) if n != 0 { t.Fatalf("want 0 allocs, got %v", n) } } func TestNonEscapingConvT2I(t *testing.T) { m := make(map[I1]bool) m[TM(42)] = true if !m[TM(42)] { t.Fatalf("42 is not present in the map") } if m[TM(0)] { t.Fatalf("0 is present in the map") } n := testing.AllocsPerRun(1000, func() { if m[TM(0)] { t.Fatalf("0 is present in the map") } }) if n != 0 { t.Fatalf("want 0 allocs, got %v", n) } } func TestZeroConvT2x(t *testing.T) { tests := []struct { name string fn func() }{ {name: "E8", fn: func() { e = eight8 }}, // any byte-sized value does not allocate {name: "E16", fn: func() { e = zero16 }}, // zero values do not allocate {name: "E32", fn: func() { e = zero32 }}, {name: "E64", fn: func() { e = zero64 }}, {name: "Estr", fn: func() { e = zerostr }}, {name: "Eslice", fn: func() { e = zeroslice }}, {name: "Econstflt", fn: func() { e = 99.0 }}, // constants do not allocate {name: "Econststr", fn: func() { e = "change" }}, {name: "I8", fn: func() { i1 = eight8I }}, {name: "I16", fn: func() { i1 = zero16I }}, {name: "I32", fn: func() { i1 = zero32I }}, {name: "I64", fn: func() { i1 = zero64I }}, {name: "Istr", fn: func() { i1 = zerostrI }}, {name: "Islice", fn: func() { i1 = zerosliceI }}, } for _, test := range tests { t.Run(test.name, func(t *testing.T) { n := testing.AllocsPerRun(1000, test.fn) if n != 0 { t.Errorf("want zero allocs, got %v", n) } }) } } var ( eight8 uint8 = 8 eight8I T8 = 8 yes bool = true zero16 uint16 = 0 zero16I T16 = 0 one16 uint16 = 1 thousand16 uint16 = 1000 zero32 uint32 = 0 zero32I T32 = 0 one32 uint32 = 1 thousand32 uint32 = 1000 zero64 uint64 = 0 zero64I T64 = 0 one64 uint64 = 1 thousand64 uint64 = 1000 zerostr string = "" zerostrI Tstr = "" nzstr string = "abc" zeroslice []byte = nil zerosliceI Tslice = nil nzslice []byte = []byte("abc") zerobig [512]byte nzbig [512]byte = [512]byte{511: 1} ) func BenchmarkConvT2Ezero(b *testing.B) { b.Run("zero", func(b *testing.B) { b.Run("16", func(b *testing.B) { for i := 0; i < b.N; i++ { e = zero16 } }) b.Run("32", func(b *testing.B) { for i := 0; i < b.N; i++ { e = zero32 } }) b.Run("64", func(b *testing.B) { for i := 0; i < b.N; i++ { e = zero64 } }) b.Run("str", func(b *testing.B) { for i := 0; i < b.N; i++ { e = zerostr } }) b.Run("slice", func(b *testing.B) { for i := 0; i < b.N; i++ { e = zeroslice } }) b.Run("big", func(b *testing.B) { for i := 0; i < b.N; i++ { e = zerobig } }) }) b.Run("nonzero", func(b *testing.B) { b.Run("str", func(b *testing.B) { for i := 0; i < b.N; i++ { e = nzstr } }) b.Run("slice", func(b *testing.B) { for i := 0; i < b.N; i++ { e = nzslice } }) b.Run("big", func(b *testing.B) { for i := 0; i < b.N; i++ { e = nzbig } }) }) b.Run("smallint", func(b *testing.B) { b.Run("16", func(b *testing.B) { for i := 0; i < b.N; i++ { e = one16 } }) b.Run("32", func(b *testing.B) { for i := 0; i < b.N; i++ { e = one32 } }) b.Run("64", func(b *testing.B) { for i := 0; i < b.N; i++ { e = one64 } }) }) b.Run("largeint", func(b *testing.B) { b.Run("16", func(b *testing.B) { for i := 0; i < b.N; i++ { e = thousand16 } }) b.Run("32", func(b *testing.B) { for i := 0; i < b.N; i++ { e = thousand32 } }) b.Run("64", func(b *testing.B) { for i := 0; i < b.N; i++ { e = thousand64 } }) }) }