(1)实现防火墙的主流技术有哪些?
实施防火墙主要采用哪些技术 - 服务器 - 亿速云 (yisu.com)
(2)
char arr[][2] = {'a', 'b', 'c', 'd'};
printf("%d", *(arr+1));
输出的是谁的地址?字符c
测试代码如下
char arr[][2] = {'a', 'b', 'c', 'd'};
printf("%d\n", *(arr+1));
printf("%x\n", *(arr+1));
printf("%d %c", &arr[1][0], arr[1][0]);输出结果如下:
-1454471282
a94e878e
-1454471282 c
(3)
int main()
{printf("%p", main);return(0);
}
上述代码会死循环吗?不会
(4)
int main()
{int a = 4;a += a*a<<1+2;printf("%d", a);return(0);
}
输出132,a = 4 + (4*4)<<(1+2) = 132
算数运算优先级大于移位运算符>赋值运算符
(5)如果两个动态库包含一个同名的全局函数,则他们不能同时链接?
C 多个动态库存在同名函数问题处理方法:-fvisibility=hidden_c语言库函数重名_万能菜道人的博客-CSDN博客 C/C++多个链接库含有同名函数,编译会报错吗_c 语言连接两个静态库方法一样没有报错_杰特JET的博客-CSDN博客
(6)
int main()
{int ii = 0;printf("%d,%d,%d", ++ii, ++ii, ++ii);return(0);
}
输出3,3,3
(7)
void fun(char a[100]) {char b[100];printf("%d, %d", sizeof(a), sizeof(b));
}int main()
{char a[100];fun(a);return(0);
}
64位系统中输出8,100
(8)内核空间和用户空间都属于虚拟内存空间吗?内核为系统所有进程共享吗?
虚拟内存、内核空间和用户空间_optics_ts的博客-CSDN博客
linux虚拟内存与物理内存,内核态与用户态_物理内存被分为内核和用户?_selfsongs的博客-CSDN博客
(9)
union x{
int a;
char b[2];
}t;int main()
{t.b[0] = 10;t.b[1] = 1;printf("%d", t.a);return(0);
}
输出266
(10)
#include <iostream>using namespace std;class Base {virtual void method() {cout << "from Base" << endl;}
public:virtual ~Base() {method();}void baseMethod() {method();}
};class A : public Base {void method() { cout << "from A" << endl;}
public:~A() { method();}};
int main()
{Base* base = new A;// 基类指针调用非虚方法,则这里调用的是父类的baseMethod()方法// 父类方法中又调用了method(),而这个方法是虚方法,相当于指向子类的基类指针调用// method,发生多态,先调用子类的method方法,输出from Abase->baseMethod();// delete base,由于析构函数虚函数,所以会调用子类的析构函数输出from A// 然后调用父类的析构函数输出from Basedelete base;return 0;
}测试输出:(以上是个人理解,不对之处,请指出)
from A
from A
from Base
(11)
int main()
{// 然后调用父类的析构函数输出from Basechar* str = "hello, world";str[1] = 'a';printf("%s", str);return 0;
}
段错误,通过char* str = 字符串这种方式定义的,字符串在常量区,不能原地修改。
C语言:字符串内容的修改_c语言修改字符串_不吃饭就会放大招的博客-CSDN博客
(12)对文件的操作模式中,a和a+、w和w+、r和r+有什么区别
r只读模式,文件必须存在;
r+读写模式,文件必须存在;
a追加模式,文件存在则追加,文件不存在则创建;
w写模式,文件存在则覆盖,文件不存在则创建;
w+读写模式,文件存在则覆盖,文件不存在则创建;
a+读写模式,和a一样;
如果以二进制模式,则rb+,或者r+b,
(13)
int main()
{char* p_string = "0123456789";printf("sizeof(p_string):%d\n", sizeof(p_string));printf("sizeof(*p_string):%d\n", sizeof(*p_string));printf("char:%c\n", *p_string);printf("p_string=%s\n", p_string);printf("strlen(p_string):%d\n", strlen(p_string));return 0;
}输出:
sizeof(p_string):8
sizeof(*p_string):1
char:0
p_string=0123456789
strlen(p_string):10
(14)
int g_inta;
static int g_intb;
void fun() {static int intc;int intd;printf("%d,%d,%d,%d", g_inta, g_intb, intc, intd);
}
int main()
{fun();return 0;
}输出0,0,0,0
(15)
int main()
{char str[] = {'1', 49};printf("%d,%d,%c,%c", str[0], str[1], str[0], str[1]);return 0;
}
输出49,49,1,1
(16)
class A {
public:A() {cout << "A()" << endl;};A(int val) {cout << "A(int val)" << endl;}
};
int main()
{A a, b(3), *p;return 0;
}
输出
A()
A(int val)
调用两次构造函数
(17)
void fun(char* str) {str = (char*)malloc(10*sizeof(char));strcpy(str, "hello");}
int main()
{char* str = "world";fun(str);printf("%s\n", str);return 0;
}
输出world
(18)
int main()
{int val=100, *p=&val;printf("%d", *p);return 0;
}
输出100
(19)double(*(*(*fp)(int))[5])(char) 中定义的fp是什么类型?
以下来自chatgpt回答:
表达式 `double(*(*(*fp)(int))[5])(char)` 定义了一个名为 `fp` 的函数指针,该函数指针指向一个函数,该函数具有以下特征:
1. 接受一个 `int` 类型的参数。
2. 返回一个指向数组的指针,该数组包含5个元素。
3. 每个数组元素都是一个指向函数的指针,这些函数接受一个 `char` 参数并返回 `double`。
总的来说,`fp` 是一个指向复杂函数签名的函数指针类型。这种类型的声明可能在某些高级的应用中使用,但通常很难理解和维护,因为它包含了多层指针和函数指针的组合。
单循环比赛生成网站:赢生科技 - 在线单循环赛编排 (16win.cn)
单循环比赛的编排方法 - 知乎 (zhihu.com)