首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

C语言中的强符号和弱符号

链接的核心是符号的重定位,在符号引用的地方找到符号定义的地方,包括函数产生的符号和全局变量产生的符号。 强符号:函数和初始化的全局变量所生成的符号。 弱符号:未初始化的全局变量所生成的符号。...//a.c int gdata = 10; //b.c int gdata = 20; #include int main(){ printf("gdata = %d\n",gdata...); return 0; } 这是很多新手容易犯的错误,若将a.c或b.c中全局变量gdata只初始化一次,则不会出现链接错误,并且会链接成功。...一个有趣的小例子再看强弱符号: //a.c int x; void func(){ x = 20; } //b.c #include short x = 10; short y...源文件是独立进行编译的 //a.c int x;//弱符号 void func(){ x = 20; //往x的内存上写20,写4个字节 编译阶段就完成的 } //b.c #include<

1.4K20
您找到你想要的搜索结果了吗?
是的
没有找到

C语言符号-取余取模运算

printf("%d\n", i); //结果是:-2 printf("%d\n", j); //结果是:2 return 0; } 注:运行结果并不是像我们想的四舍五入数学取整,在C语言中本质是向...return 0; } 对于负数取模 示例: int main() { int a = -10; int d = 3; printf("%d\n", a/d); //C语言中是...-3,python是-4 printf("%d\n", a%d);//C语言中是-1,python是2 return 0; } 为什么就有差异了呢?...对任何一个大于0的数,对其进行0向取整和-∞取整,取整方向是一致的,故取模等价于取余 对任何一个小于0的数,对其进行0向取整和-∞取整,取整方向是相反的,故取模不等价于取余 结论: 两个同符号数据参与取余...,取模等价于取余,不同语言余数相等 两个不符号数据参与取余,取模不等价于取余,余数大小需考虑语言取整规则

3K40

C语言符号意思(看了必懂系列)「建议收藏」

sizeof:计算数据类型长度 volatile:说明变量在程序执行中可被隐含地改变 do :循环语句的循环体 while :循环语句的循环条件 static :声明静态变量 if:条件语句 C语言中的符号...运算符的种类C语言的运算符可分为以下几类: 1.算术运算符 用于各类数值运算。...: 标志格式字符 标 志 意 义 – 结果左对齐,右边填空格 + 输出符号(正号或负号)空格输出值为正时冠以空格,为负时冠以负号 对c,s,d,u类无影响;对o类, 在输出时加前 缀o 对x类...竖向跳格 \b 退格 \r 回车 \f 走纸换页 \ 反斜线符”\” \’ 单引号符 \a 鸣铃 \ddd 1~3位八进制数所代表的字符 \xhh 1~2位十六进制数所代表的字符 广义地讲,C语言字符集中的任何一个字符均可用转义字符来表示...在C语言中,对变量的存储类型说明有以下四种: auto 自动变量 register 寄存器变量 extern 外部变量 static 静态变量 自动变量和寄存器变量属于动态存储方式, 外部变量和静态变量属于静态存储方式

1.2K20

成员访问符号(.和-)的详解c语言版:

成员访问符号(.和->)的详解: 一、成员访问符 成员访问符通常是指:用于访问结构体、类或对象的成员(属性或方法)的符号。 操作符名称: 点号(.)...箭头符号(->) 双冒号(::) 在大多数编程语言中都使用点号来访问结构体、类或对象的成员。 在CC++中,当通过指针访问结构体或类的成员时,需要使用箭头符号来代替点号。...一般用于C++中,在C++中,一般用于访问命名空间中的成员,也可以用于访问静态成员和嵌套的类。 在C语言中,我们主要使用前两种操作符,对于第三种我们在本文中不进行深入展开。...箭头符号(->) 通过结构体变量访问成员变量 通过(结构体) 指针 访问成员变量 代码如下: #include #include // 定义一个结构体 struct...person1; person1.age = 25; printf("Using dot operator: Age is %d\n", person1.age); // 使用箭头符号

13310

C语言进阶小技巧,弱符号和弱引用

符号和弱符号 在同一作用域下不能定义同一个变量或函数,很多C语言学习者都理所当然地这么认为。...这个其实是是有所偏颇的,GNU C对标准C语言进行了扩展,在GCC中,对于符号(在编译时,变量和函数都被抽象成符号)而言,存在着强符号和弱符号之分。...是的,是否支持这个特性是由不同的C语言标准决定的。 对于C/C++而言,编译器默认函数和已初始化的全局变量为强符号,而未初始化的全局变量为弱符号。...注意:C标准里根本没有提到强、弱符号。这只是GCC这个实现定义的特性,在MS C编译器里是不存在这个概念的。 本文系网络素材,版权归原作者所有,如有侵权,请联系删除。...为什么永远不会有语言取代 C / C++ ?

80020

C++函数定义 | 输出有参无参

C++无参函数的定义 函上一节小林已经讲过,从函数形式来看,函数分为无参函数和有参函数,那么他们有什么不同呢?...定义无参函数的一般形式为 类型标识符 函数名([void])//注意void可以省略不写 {   声明部分   语句 } C++有参函数的定义 有参函数,顾名思义,有参数的函数,和无参函数相比,有参函数多了参数...,定义如下所示 类型标识符 函数名(形式参数表列) {   声明部分   语句 } 学习了无参函数和有参函数的不同,接下来看一个例子巩固下知识点 经典案例:C++实现无参数和有参数函数,并输出相应文字描述...C++输出有参无参 更多案例可以go公众号:C语言入门到精通

1.3K2927

数字IC笔试题(6)——C语言符号数和无符号数【原码、反码、补码】【格式转换】

(数字IC中,对C语言的考察比较多,输入输出/进制转换/文件读写等) unsigned char a = -1, char b = 44, int c =a+b 以上程序运行后,c=() 答案:299...解析: 【有符号+无符号】,按照2个都是无符号算。...除了加法外,只要运算中存在有符号操作数和无符号操作数混用,都是将操作数转成无符号算。...(1)unsigned char a = -1,8位补码表示-1,首先用7-bit表示1,000_0001,取反后111_1110,加1后111_1111,加上符号位1111_1111,如果用这个8位的二进制数来表示无符号数...,为255; (2)char b = 44,本身就是正数,有符号中正数的原码、反码、补码相同,所以转成无符号数还是 44; (3)加法自动扩展成int去算,255+44=299;

1.2K10

C++ 中有符号类型到无符号类型的转换

参考链接: C++ strtoull() 我的主力博客:半亩方塘   为了更好地解释下面的代码,先来介绍一些背景知识,在我的计算机中, char 类型占 8 个比特位,那么, unsigned char...接下来看下面的代码:  这是我写在 Emacs 上的代码,运行结果如下图:    下面对上图的运行结果进行解释:   unsigned char 类型能表示的数的范围为 0 ~ 255,但是我们给属于此类型的 c...和 j 赋值分别为 -10 和 258,显然超过了此类型所能表示的数的范围,在此例中,有以下三种情况:   ( 一 )、 当我们所赋的值为 负值 时,如以上代码中变量 c 的情形,给它一个值 -10,最后将...c 的值赋给 d 后输出,得到 d = 246,即给 c 变量赋值 -10 后,它的值变为 246,这是为什么呢?...10 ) ,得 4294967264 ,符合最后得到的程序运行结果,关于这部分内容详见我的博客 C++ 无符号类型的运算对象参与的类型转换  最后我们还需要另外强调的一点是,  当我们给带符号类型赋予一个超过其表示范围的值时

1.2K00

【编程基础】c语言中获取整数和浮点数的符号

,或是计算结果的符号位变化。...而数值的符号位已经被存储在了数值的最高位,可以利用这点来避免条件判断。 2. 如何得到符号位 可能有很多种方法。但是通过移位来获得符号位是最直接想到的。...移位有左移右移, 右移因为有符号位的问题。所以,有2个情况,有符号右移和无符号右移。有符号右移空位补符号位,无符号右移空位补0。...当把有符号数,符号位移动到右边第一位的时候,结果-1就是负数,0就是正数。当把无符号数,符号位移动到右边第一位时候,结果1是负数,0正数。 3....这样我们就可以把最开始的例子写成这样: x = (x - 1) * MathUtils_SignBit(x)x *= MathUtils_SignBit(x) 转自(http://www.th7.cn/Program/c/

2K80

C++解析一些特殊符号tab、换行符号

while循环去匹配字符串里面的'\t'(tab键),'\n'(换行符号)等,然后用C标准库里面str函数,例如strncpy进行复制或者strstr去查找,类似于下面所示: int i, j...第二件事情,进行识别tab符号和换行符号之后进行分段 第三件事情,把分好的数据塞到一个vector容器里面,然后因为每一行都有五个数据,所以我们就可以按照0~5一组的数据进行分发给各处。.../ printf("[]%s,%s\n",words[i].c_str(),words[i+1].c_str(),words[i+3].c_str()); //} return...words; } 使用此代码解析LOG如下: 结语 这就是我分享的一个简单的C++解析一些特殊符号的实践,如果大家有更好的想法和需求,也欢迎大家加我好友交流分享哈。...‧‧‧‧‧‧‧‧‧‧‧‧‧‧‧‧ END ‧‧‧‧‧‧‧‧‧‧‧‧‧‧‧‧ 推荐阅读 【1】C++的智能指针你了解吗?

93300

C#小知识:“$”符号的作用

C#中符号是从C# 6.0版本开始推出的语法糖, 主要是对String.format()的简化,当然format也不是没有价值,本文将介绍C#中符及String.format的一些通用用法。...一:$符号的用法 $符号的作用相当于对String.format()的简化 例如我们需要输出一段包含name与age的字符串: using System; class Program { static...——注意与第一个"之前不能有空格 因为C#是美国人发明的,所以用$符号,那么如果是中国人发明的C#或许这个语法糖就使用¥符号了吧........Console.WriteLine(string.Format("{0:X}", 10));//A Console.WriteLine(string.Format("{0:x}", 10));//a //转换为当前国家的货币符号...("{0:C1}", 10.135));//¥10.1 //转换为百分分显示,默认保留2位小数,会四舍五入 Console.WriteLine(string.Format("{0:P}", 0.55

38520
领券