C语言实现给函数加锁 c语言实现读写锁

今天自学了C语言函数一章,大体有个了解。但是还有很多问题,麻烦高手给我解释下!先谢谢各位了!

第一段代码只要把

创新互联于2013年开始,先为安塞等服务建站,安塞等地企业,进行企业商务咨询服务。为安塞企业网站制作PC+手机+微官网三网同步一站式服务解决您的所有建站问题。

int a[4]={"1,2,3,4"}; 改为 int a[4]={1,2,3,4};

就正确了

运行的结果是输入 1

第二段代码除了要把引号改掉外,

Han(a[4]); 也要改为 Han(a); 运行的结果是输出1,或者 Han(a[4]);运行的结果是输出4

c语言static的作用和用法

static在c语言中是私有、静态意思。

用于在函数中声明“静态变量”用,在每一次调用后,该变量并不在函数返回时立即释放,变量中保存的值,可以保留到下一次调用时继续有效。

私有就是隐藏。static函数只能声明后的本文中调用。static全局变量只能声明后的本文中调用。static局部变量只能声明后的本函数调用

静态就是一直存在,相对于每次调用动态分配而言。static函数未验证是否每次调用代码地址都是一致的。static全局变量生命周期到程序或进程结束。static局部变量生命周期到程序或进程结束。

static的使用和作用

静态全局变量。全局变量前加static,修饰全局变量为静态全局变量,改变全局变量的可见性。静态局部变量。局部变量前加static,修饰局部变量为静态局部变量,改变局部变量的销毁时期。静态函数。函数返回类型前加static,修饰函数为静态函数,改变函数的可见性。

类的静态成员。类成员前加static,修饰类的成员为类的静态成员,实现多个对象之间的数据共享,并且使用静态成员不会破坏封装性,也保证了安全性。类的静态函数,类函数前加static,修饰类的函数为静态函数,减少资源消耗,不需要实例化就可以使用。

如何用c语言实现CString的构造函数,析构函数和赋值函数

1、首先C语言没办法实现构造函数和析构函数,因为C语言是面向过程的语言,没有定义面向对象的class概念。C++语言是以C语言为基础扩展出来的一种编程语言,它在继承了C语言的基础上,增加了面向对象的编程方法,其中就包含了class。

2、如果你所描述的c语言是指C++语言,那么是可以自已定义并实现CString类的一些功能。因为CString类是微软VC++ MFC实现的基础类,而非C++标准类库,所以CString类定义中使用了一些AFX函数,依赖于MFC环境,所以想自定义一个完全取代CString的类很困难,也无意义。

3、如果只是需要学习CString的构造函数、析构函数及赋值函数,可以参考MFC类库源文件:

\MICROSOFT VISUAL STUDIO\VC98\MFC\Include\AFX.INL

\MICROSOFT VISUAL STUDIO\VC98\MFC\SRC\STRCORE.CPP

\MICROSOFT VISUAL STUDIO\VC98\MFC\SRC\WINSTR.CPP

C语言编写

#includestdio.h

#define N 20

int fun(char a[])

{

int i,j,num=0;

char b[N];

for(i=0,j=0; iN; i++)

{

if(a[i]='0' a[i]='9')

num++;

else

{b[j]=a[i]; j++;}

}

printf("删除数字字符后的数组:\n",b);

printf("%s\n",b);

return num;

}

void main()

{

char c[N];

int num=0;

printf("输入字符串:");

scanf("%s",c);

num=fun(c);

printf("删除数字字符的个数为:%d\n",num);

}

C语言调用函数怎么让调用的函数可控性

我想,你只要看了C语言上关于传值函数调用的测试题,一切都会了然于胸:

1. 考题一:程序代码如下:

void Exchg1(int x, int y)

{

int tmp;

tmp=x;

x=y;

y=tmp;

printf(“x=%d,y=%d/n”,x,y)

}

void main()

{

int a=4,b=6;

Exchg1 (a,b) ;

printf(“a=%d,b=%d/n”,a,b)

}

输出的结果:

x=____, y=____

a=____, b=____

问下划线的部分应是什么,请完成。

2. 考题二:代码如下。

Exchg2(int *px, int *py)

{

int tmp=*px;

*px=*py;

*py=tmp;

print(“*px=%d,*py=%d/n”,*px,*py);

}

main()

{

int a=4;

int b=6;

Exchg2(a,b);

Print(“a=%d,b=%d/n”, a, b);

}

输出的结果为:

*px=____, *py=____

a=____, b=____

问下划线的部分应是什么,请完成。

3. 考题三:

Exchg2(int x, int y)

{

int tmp=x;

x=y;

y=tmp;

print(“x=%d,y=%d/n”,x,y);

}

main()

{

int a=4;

int b=6;

Exchg2(a,b);

Print(“a=%d,b=%d/n”, a, b);

}

二. 函数参数传递方式之一:值传递

1. 值传递的一个错误认识

先看题一中Exchg1函数的定义:

void Exchg1(int x, int y) //定义中的x,y变量被称为Exchg1函数的形式参数

{

int tmp;

tmp=x;

x=y;

y=tmp;

printf(“x=%d,y=%d/n”,x,y)

}

问:你认为这个函数是在做什么呀?

答:好像是对参数x,y的值对调吧?

请往下看,我想利用这个函数来完成对a,b两个变量值的对调,程序如下:

void main()

{

int a=4,b=6;

Exchg1 (a,b) //a,b变量为Exchg1函数的实际参数。

/ printf(“a=%d,b=%d/n”,a,b)

}

我问:Exchg1 ()里头的 printf(“x=%d,y=%d/n”,x,y)语句会输出什么啊?

我再问:Exchg1 ()后的 printf(“a=%d,b=%d/n”,a,b)语句输出的是什么?

程序输出的结果是:

x=6 , y=4

a=4 , b=6 //为什么不是a=6,b=4呢?

奇怪,明明我把a,b分别代入了x,y中,并在函数里完成了两个变量值的交换,为什么a,b变量值还是没有交换(仍然是a==4,b==6,而不是a==6,b==4)?如果你也会有这个疑问,那是因为你跟本就不知实参a,b与形参x,y的关系了。

2. 一个预备的常识

为了说明这个问题,我先给出一个代码:

int a=4;

int x;

x=a;

x=x+3;

看好了没,现在我问你:最终a值是多少,x值是多少?

(怎么搞的,给我这个小儿科的问题。还不简单,不就是a==4 x==7嘛!)

在这个代码中,你要明白一个东西:虽然a值赋给了x,但是a变量并不是x变量哦。我们对x任何的修改,都不会改变a变量。呵呵!虽然简单,并且一看就理所当然,不过可是一个很重要的认识喔。

3. 理解值传递的形式

看调用Exch1函数的代码:

main()

{

int a=4,b=6;

Exchg1(a,b) //这里调用了Exchg1函数

printf(“a=%d,b=%d”,a,b)

}

Exchg1(a,b)时所完成的操作代码如下所示。

int x=a;//←

int y=b;//←注意这里,头两行是调用函数时的隐含操作

int tmp;

tmp=x;

x=y;

y=tmp;

请注意在调用执行Exchg1函数的操作中我人为地加上了头两句:

int x=a;

int y=b;

这是调用函数时的两个隐含动作。它确实存在,现在我只不过把它显式地写了出来而已。问题一下就清晰起来啦。(看到这里,现在你认为函数里面交换操作的是a,b变量或者只是x,y变量呢?)

原来 ,其实函数在调用时是隐含地把实参a,b

的值分别赋值给了x,y,之后在你写的Exchg1函数体内再也没有对a,b进行任何的操作了。交换的只是x,y变量。并不是a,b。当然a,b的值没有

改变啦!函数只是把a,b的值通过赋值传递给了x,y,函数里头操作的只是x,y的值并不是a,b的值。这就是所谓的参数的值传递了。

哈哈,终于明白了,正是因为它隐含了那两个的赋值操作,才让我们产生了前述的迷惑(以为a,b已经代替了x,y,对x,y的操作就是对a,b的操作了,这是一个错误的观点啊!)。

三. 函数参数传递方式之二:地址传递

继续——地址传递的问题!

看题二的代码:

Exchg2(int *px, int *py)

{

int tmp=*px;

*px=*py;

*py=tmp;

print(“*px=%d,*py=%d/n”,*px,*py);

}

main()

{

int a=4;

int b=6;

Exchg2(a,b);

Print(“a=%d,b=%d/n”, a, b);

}

它的输出结果是:

*px=6,*py=4

a=6,b=4

看函数的接口部分:Exchg2(int *px,int *py),请注意:参数px,py都是指针。

再看调用处:Exchg2(a, b);

它将a的地址(a)代入到px,b的地址(b)代入到py。同上面的值传递一样,函数调用时作了两个隐含的操作:将a,b的值赋值给了px,py。

px=a;

py=b;

呵呵!我们发现,其实它与值传递并没有什么不同,只不过这里是将a,b的地址值传递给了px,py,而不是传递的a,b的内容,而(请好好地在比较比较啦)

整个Exchg2函数调用是如下执行的:

px=a; //

py=b; //请注意这两行,它是调用Exchg2的隐含动作。

int tmp=*px;

*px=*py;

*py=tmp;

print(“*px=%d,*py=%d/n”,*px,*py);

这样,有了头两行的隐含赋值操作。我们现在已经可以看出,指针px,py的值已经分别是a,b变量的地址值了。接下来,对*px,*py的操作当然也就是

对a,b变量本身的操作了。所以函数里头的交换就是对a,b值的交换了,这就是所谓的地址传递(传递a,b的地址给了px,py),你现在明白了吗?

四. 函数参数传递方式之三:引用传递

看题三的代码:

Exchg3(int x, int y) //注意定义处的形式参数的格式与值传递不同

{

int tmp=x;

x=y;

y=tmp;

print(“x=%d,y=%d/n”,x,y);

}

main()

{

int a=4;

int b=6;

Exchg3(a,b); //注意:这里调用方式与值传递一样

Print(“a=%d,b=%d/n”, a, b);

}

输出结果:

x=6, y=4

a=6, b=4 //这个输出结果与值传递不同。

看到没有,与值传递相比,代码格式上只有一处是不同的,即在定义处:

Exchg3(int x, int y)。

但是我们发现a与b的值发生了对调。这说明了Exchg3(a,b)里头修改的是a,b变量,而不只是修改x,y了。

我们先看Exchg3函数的定义处Exchg3(int x,int

y)。参数x,y是int的变量,调用时我们可以像值传递(如: Exchg1(a,b); )一样调用函数(如: Exchg3(a,b);

)。但是x,y前都有一个取地址符号。有了这个,调用Exchg3时函数会将a,b

分别代替了x,y了,我们称x,y分别引用了a,b变量。这样函数里头操作的其实就是实参a,b本身了,也就是说函数里是可以直接修改到a,b的值了。

最后对值传递与引用传递作一个比较:

1. 在函数定义格式上有不同:

值传递在定义处是:Exchg1(int x, int y);

引用传递在这义处是:Exchg1(int x, int y);

2. 调用时有相同的格式:

值传递:Exchg1(a,b);

引用传递:Exchg3(a,b);

3. 功能上是不同的:

值传递的函数里操作的不是a,b变量本身,只是将a,b值赋给了x,y函数里操作的只是x,y变量而不是a,b,显示a,b的值不会被Exchg1函数所修改。

引用传递Exchg3(a,b)函数里是用a,b分别代替了x,y。函数里操作的是a,b。

新闻名称:C语言实现给函数加锁 c语言实现读写锁
标题URL:https://www.cdcxhl.com/article2/docoeoc.html

成都网站建设公司_创新互联,为您提供外贸建站移动网站建设软件开发电子商务定制开发建站公司

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

网站建设网站维护公司