按照定义slice切片p指针切片结构体部+数组区域其部结构定义:struct Slice{ // must not move anythingbyte* array// actual datauintgo len// number of elementsuintgo cap// allocated number of elements}slice返其实部值返函数内外址同导致主程序ss与pp同ss新配pp则与程序testInterfaceslice相同简单修改代码通输比非清晰:package mainimport ("fmt")func testInterface() (slice interface{}, p interface{}) {slice = make([]int, 10)p = slicefmt.Println("debug:testInterface")fmt.Println(slice)//两址应该相同fmt.Println(p) //两址应该相同return slice, p}func main() {fmt.Println("debug:main")ss, pp := testInterface()fmt.Println(ss)fmt.Println(pp) //应该与程序输致}另外第问题用解释依值指针同如果在一个有N个
元素的数组内,删除下标为K的元素:
for(int i=Ki<N-1i++)
a[i]=a[i+1]
N--
printf("删除元素后:\n")
for(i=0i<Ni++)
printf("%d ",a[i])
这是pascal的
for i:=1 to n do
if a[i]=5 then a[i]=maxint
(过一遍 ,把5元素的标出来,maxint可换为一些特殊的数据)
for i:=2 to n do
if a[i]<>maxint then (本身不是maxint前移)
while a[i-1]=maxint then
begin
a[i-1]:=a[i]
a[i]:=maxint(连续操作,只要前面的是标出的就前移,
end 直到前面的不是maxint)
(后面非5的前移)
(下次使用的时候到maxint不操作)
总的说就可以实现了
初学 有些烦 但也可以不前移,操作是若是maxint不操作